Before starting BRLTTY, you need to set up your braille display.
In most cases this is done simply
by connecting it to an available serial port,
and then turning it on.
After your display has been set up,
run BRLTTY simply by typing the command brltty at a shell prompt
(this must be done as root).
Check the
-d command line option,
the 
braille-device configuration file directive,
and the 
--with-braille-device build option
for alternatives regarding how to tell BRLTTY which device your display is connected to.
Check the
-b command line option,
the 
braille-driver configuration file directive,
and the 
--with-braille-driver build option
for alternatives regarding how to tell BRLTTY which kind of braille display you have.
Check the
-B command line option,
and the 
braille-parameters configuration file directive
for alternatives regarding how to pass parameters to the driver for your braille display.
A message giving the program name (BRLTTY) and its version number will appear briefly (see the -M command line option) on the braille display. The display will then show a small area of the screen including the cursor. By default, the cursor is represented as dots 7 and 8 superimposed on the character it is on.
Any screen activity will be reflected on the braille display. The display will also follow the progress of the cursor on the screen. This feature is known as cursor tracking.
Just typing on the keyboard and reading the display, however, isn't enough. Try entering a command which will cause an error, and pressing enter. The error appears on the screen, but, unless you have a multi-line display, the chances are that it isn't visible on the braille display. All you see thereon is another shell prompt. What's needed, then, is some way to move the braille window around the screen. The keys on the braille display itself can be used to send commands to BRLTTY which, in addition to a lot of other things, can also do exactly that.
Unfortunately, the various braille displays don't offer a standard set of controls. Some have the six standard dot keys, some have eight, and others have none. Some have thumb keys, but there's no standard number of them. Some have a button above each braille cell. Some have rocker switches. Some have an easy-to-reach bar which works much like a joystick. Most have varying combinations of the above. Because the nature and layout of each display is so different, please refer to the documentation for your particular display in order to find out exactly what its keys do.
BRLTTY commands are referred to by name within this manual.
If you forget which key(s) on your braille display to use
for a paticular command, then refer to its driver's help page.
The main key you should immediately commit to memory, therefore, is the one
for the 
HELP command.
Use the regular motion keys (as described below) to navigate the help page,
and press the help key again to quit.
See also the PRINDENT/NXINDENT routing key commands.
Go up/down one line. If identical line skipping has been activated (see the SKPIDLNS command), then these commands, rather than moving exactly one line, are aliases for the PRDIFLN/NXDIFLN commands.
Go up/down one window. If the window is only 1 line high then move 5 lines.
Go up/down to the nearest line with different content. If identical line skipping has been activated (see the SKPIDLNS command), then these commands, rather than skipping identical lines, are aliases for the LNUP/LNDN commands.
Go up/down to the nearest line with different attributes (character highlighting).
Go to the top/bottom line.
Go to the top-left/bottom-left corner.
Go to the nearest line of the previous/next paragraph (the first non-blank line beyond the nearest blank line). The current line is included when searching for the inter-paragraph space.
Go to the previous/next command prompt.
Search backward/forward for the nearest occurrence of the character string within the cut buffer (see Cut and Paste) which isn't within the braille window. The search proceeds to the left/right, starting at the character immediately to the left/right of the window, and wrapping at the edge of the screen. The search isn't case sensitive.
See also the SETLEFT routing key command.
Go left/right one character.
Go left/right half a window.
Go left/right one window. These commands are particularly useful because they automatically wrap when they reach the edge of the screen. Other features, like their ability to skip blank windows (see the SKPBLNKWINS command), further enhance their usefulness.
Go left/right to the nearest non-blank window.
Go to the beginning/end of the line.
See also the GOTOMARK routing key command.
Go to where the cursor is.
Go back to where the most recent motion command put the braille window. This is an easy way to get right back to where you were reading after an unexpected event (like cursor tracking) moves the braille window at an inopportune moment.
Each of these commands has three forms: activate (turn the feature on), deactivate (turn the feature off), and toggle (if it's off then turn it on, and if it's on then turn it off). Unless specifically noted, each of these features is initially off, and, when on, affects BRLTTY's operation as a whole. The initial setting of some of these features can be changed via the preferences menu.
Freeze the screen image. BRLTTY makes a copy of the screen (content and attributes) as of the moment when the screen image is frozen, and then ignores all updating of the screen until it's unfrozen. This feature makes it easy, for example, to sample the output of an application which writes too much too quickly.
Show the highlighting (the attributes) of each character within the braille window, rather than the characters themselves (the content). This feature is useful, for example, when you need to locate a highlighted item. When showing screen content, the text translation table is used (see the -t command line option, the text-table configuration file directive, and the --with-text-table build option). When showing screen attributes, the attributes translation table is used (see the -a command line option, the attributes-table configuration file directive, and the --with-attributes-table build option). This feature only affects the current virtual terminal.
Show characters using 6-dot, rather than 8-dot, braille. Dots 7 and 8 are still used by other features like cursor representation and highlighted character underlining. If a contraction table has been selected (see the -c command line option and the contraction-table configuration file directive), then it is used. This setting can also be changed with the Text Style preference.
If cursor tracking (see the CSRTRK command) is on, then, whenever the cursor moves too close to (or beyond) either end of the braille window, horizontally reposition the window such that the cursor, while remaining on that side, is nearer the centre. If this feature is off, then the braille window is always positioned such that its left end is a multiple of its width from the left edge of the screen. This setting can also be changed with the Sliding Window preference.
Rather than explicitly moving exactly one line either up or down, skip passed lines which have the same content as the current line. This feature affects the LNUP/LNDN commands, as well as the line wrapping feature of the FWINLT/FWINRT and FWINLTSKIP/FWINRTSKIP commands. This setting can also be changed with the Skip Identical Lines preference.
Skip passed blank windows when reading either forward or backward. This feature affects the FWINLT/FWINRT commands. This setting can also be changed with the Skip Blank Windows preference.
Show the cursor by superimposing a dot pattern (see the CSRSIZE command) on top of the character where it is. This feature is initially on. This setting can also be changed with the Show Cursor preference.
Hide the cursor (see the CSRVIS command) in order to accurately read the character beneath it. This feature only affects the current virtual terminal.
Track (follow) the cursor. If the cursor moves to a location which isn't within the braille window, then automatically move the braille window to the cursor's new location. You'll usually want this feature turned on since it minimizes the effects of screen scrolling, and since, during input, the region wherein you're currently typing is always visible. If this feature causes the braille window to jump at an inopportune moment, then use the BACK command to get back to where you were reading. You may need to turn this feature off when using an application which continually updates the screen while maintaining a fixed data layout. This feature is initially on. This feature only affects the current virtual terminal.
Represent the cursor with all eight dots (a solid block), rather than with just dots 7 and 8 (an underline). This setting can also be changed with the Cursor Style preference.
Blink (turn on and off according to a predefined interval) the symbol representing the cursor (see the CSRVIS command). This setting can also be changed with the Blinking Cursor preference.
Underline (with combinations of dots 7 and 8) highlighted characters.
White on black (normal), gray on black, white on blue, black on cyan.
Black on white (reverse video).
Everything else.
Blink (turn on and off according to a predefined interval) the attribute underline (see the ATTRVIS command). This feature is initially on. This setting can also be changed with the Blinking Attributes preference.
Blink (turn on and off according to a predefined interval) capital (uppercase) letters. This setting can also be changed with the Blinking Capitals preference.
Play a short predefined tune (see Alert Tunes) whenever a significant event occurs. This feature is initially on. This setting can also be changed with the Alert Tunes preference.
Automatically repeat a command at a regular interval after an initial delay while its key (combination) remains pressed. Only some drivers support this functionality, the primary limitation being that many braille displays don't signal both key presses and key releases as distinctly separate events. This feature is initially off. This setting can also be changed with the Autorepeat preference.
Automatically speak:
Switch to the braille display driver's help page.
This is where you can find an on-line summary of things like
what your braille display's keys do,
and how to interpret its status cells.
Use the regular 
vertical
and 
horizontal motion commands
to navigate the help page.
Invoke the help command again to return to the screen.
Switch to the status display (see section The Status Display for full details). It presents a summary including the position of the cursor, the position of the braille window, and the states of a number of BRLTTY's features. Invoke this command again to return to the screen.
Switch to command learn mode (see section Command Learn Mode for full details). This is how you can interactively learn what your braille display's keys do. Invoke this command again to return to the screen. This command isn't available if the --disable-learn-mode build option was specified.
Switch to the preferences menu (see The Preferences Menu for full details). Invoke this command again to return to normal operation. This command isn't available if the --disable-preferences-menu build option was specified.
Save the current preferences settings (see Preferences for full details).
Restore the most recently saved preferences settings (see Preferences for full details).
Go to the first/last item in the menu.
Go to the previous/next item in the menu.
Decrement/increment the current menu item's setting.
Speak the current line. The Say-Line Mode preference determines if pending speech is discarded first.
Speak the top portion of the screen (ending with the current line).
Speak the bottom portion of the screen (starting with the current line).
Stop speaking immediately.
Go to where the speech cursor is.
Decrease/increase the speech rate (see also the Speech Rate preference). This command is only available if a driver which supports it is being used.
Decrease/increase the speech volume (see also the Speech Volume preference). This command is only available if a driver which supports it is being used.
See also the SWITCHVT routing key command.
Switch to the previous/next virtual terminal.
Route (bring) the cursor to anywhere on the top line of the braille window (see Cursor Routing for full details). The cursor is moved by simulating vertical arrow-key presses. This command doesn't always work because some applications either move the cursor somewhat unpredictably or use the arrow keys for purposes other than cursor motion. It's somewhat safer than the other cursor routing commands, though, because it makes no attempt to simulate the left- and right-arrows.
Insert the characters within the cut buffer at the current cursor location (see Cut and Paste for full details).
Stop, and then restart the braille display driver.
Stop, and then restart the speech synthesizer driver.
Route (bring) the cursor to the character associated with the routing key (see Cursor Routing for full details). The cursor is moved by simulating arrow-key presses. This command doesn't always work because some applications either move the cursor somewhat unpredictably or use the arrow keys for purposes other than cursor motion.
Anchor the start of the cut block at the character associated with the routing key (see Cut and Paste for full details). This command clears the cut buffer.
Anchor the start of the cut block at the character associated with the routing key (see Cut and Paste for full details). This command doesn't clear the cut buffer.
Anchor the end of the cut block at the character associated with the routing key, and append the rectangular region to the cut buffer (see Cut and Paste for full details).
Anchor the end of the cut block at the character associated with the routing key, and append the linear region to the cut buffer (see Cut and Paste for full details).
Switch to the virtual terminal whose number (counting from 1) matches that of the routing key. See also the SWITCHVT_PREV/SWITCHVT_NEXT virtual terminal switching commands.
Go up/down to the nearest line which isn't indented more than the column associated with the routing key.
Momentarily (see the 
-M command line option)
display a message describing the character associated with the routing key.
It reveals
the decimal and hexadecimal values of the character,
the foreground and background colours,
and, when present, special attributes (bright and blink).
The message looks like this:
char 65 (0x41): white on black bright blink
Horizontally reposition the braille window so that its left edge is at the column associated with the routing key. This feature makes it very easy to put the window exactly where it's needed, and, therefore, for displays which have routing keys, almost eliminates the need for a lot of elementary window motion (like the CHRLT/CHRRT and HWINLT/HWINRT commands).
Mark (remember) the current position of the braille window in a register associated with the routing key. See the GOTOMARK command. This feature only affects the current virtual terminal.
Move the braille window to the position formerly marked (see the SETMARK command) with the same routing key. This feature only affects the current virtual terminal.
System defaults for many settings may be established within a configuration file.
The default name for this file is /etc/brltty.conf,
although it may be overridden with the
-f command line option.
It doesn't need to exist.
A template for it can be found within the DOCS subdirectory.
Blank lines are ignored.
A comment begin with a number sign (#),
and continues to the end of the line.
The following directives are recognized:
api-parameters name=value,...
 Specify parameters for the Application Programming Interrface. If the same parameter is specified more than once, then its rightmost assignment is used. For a description of the parameters accepted by the interface, please see the BrlAPI reference manual. See the --with-api-parameters build option for the defaults established during the build procedure. This directive can be overridden with the -A command line option.
attributes-table file
 Specify the attributes translation table
(see section 
Translation Tables for details).
If a relative path is supplied, then it's anchored at /etc/brltty
(see the 
--with-data-directory
and the 
--with-execute-root
build options for more details).
The .tbl extension is optional.
See the 
--with-attributes-table
build option for the default established during the build procedure.
This directive can be overridden with the
-a command line option.
braille-device device,...
 Specify the device to which the braille display is connected (see section Braille Device Specification). See the --with-braille-device build option for the default established during the build procedure. This directive can be overridden with the -d command line option.
braille-driver driver,...|auto
 Specify the braille display driver (see section Driver Specification). See the --with-braille-driver build option for the default established during the build procedure. This directive can be overridden with the -b command line option.
braille-parameters [driver:]name=value,...
 Specify parameters for the braille display drivers. If the same parameter is specified more than once, then its rightmost assignment is used. If a parameter name is qualified by a driver (see section Driver Identification Codes) then that setting only applies to that driver; if it isn't then it applies to all drivers. For a description of the parameters accepted by a specific driver, please see the documentation for that driver. See the --with-braille-parameters build option for the defaults established during the build procedure. This directive can be overridden with the -B command line option.
contraction-table file
 Specify the contraction table
(see section 
Contracted Braille for details).
If a relative path is supplied, then it's anchored at /etc/brltty
(see the 
--with-data-directory
and the 
--with-execute-root
build options for more details).
The .ctb extension is optional.
The contraction table is used when the 6-dot braille feature is activated
(see the 
SIXDOTS command
and the 
Text Style preference).
The default is to display uncontracted 6-dot braille.
This directive can be overridden with the
-c command line option.
It isn't available if the
--disable-contracted-braille build option was specified.
midi-device device
 Specify the device to use for the Musical Instrument Digital Interface (see section MIDI Device Specification). This directive can be overridden with the -m command line option. It isn't available if the --disable-midi-support build option was specified.
pcm-device device
 Specify the device to use for digital audio (see section PCM Device Specification). This directive can be overridden with the -p command line option. It isn't available if the --disable-pcm-support build option was specified.
screen-parameters name=value,...
 Specify parameters for the screen driver. If the same parameter is specified more than once, then its rightmost assignment is used. For a description of the parameters accepted by a specific driver, please see the documentation for that driver. See the --with-screen-parameters build option for the defaults established during the build procedure. This directive can be overridden with the -X command line option.
speech-driver driver,...|auto
 Specify the speech synthesizer driver (see section Driver Specification). See the --with-speech-driver build option for the default established during the build procedure. This directive can be overridden with the -s command line option. It isn't available if the --disable-speech-support build option was specified.
speech-fifo file
 Specify the FIFO (a special file which works like a pipe) which is to be used by other applications that wish to gain access to BRLTTY's speech driver. This directive can be overridden with the -F command line option. It isn't available if the --disable-speech-support build option was specified.
speech-parameters [driver:]name=value,...
 Specify parameters for the speech synthesizer drivers. If the same parameter is specified more than once, then its rightmost assignment is used. If a parameter name is qualified by a driver (see section Driver Identification Codes) then that setting only applies to that driver; if it isn't then it applies to all drivers. For a description of the parameters accepted by a specific driver, please see the documentation for that driver. See the --with-speech-parameters build option for the defaults established during the build procedure. This directive can be overridden with the -S command line option.
text-table file
 Specify the text translation table
(see section 
Translation Tables for details).
If a relative path is supplied, then it's anchored at /etc/brltty
(see the 
--with-data-directory
and the 
--with-execute-root
build options for more details).
The .tbl extension is optional.
For a simple file name, the text. prefix is optional.
See the 
--with-text-table
build option for the default established during the build procedure.
This directive can be overridden with the
-t command line option.
Many settings can be explicitly specified when invoking BRLTTY.
The brltty command accepts the following options:
-afile --attributes-table=file
 Specify the attributes translation table
(see section 
Translation Tables for details).
If a relative path is supplied, then it's anchored at /etc/brltty
(see the 
--with-data-directory
and the 
--with-execute-root
build options for more details).
The .tbl extension is optional.
See the 
attributes-table
configuration file directive for the default run-time setting.
This setting can be changed with the
Attributes Table preference.
-bdriver,...|auto --braille-driver=driver,...|auto
 Specify the braille display driver (see section Driver Specification). See the braille-driver configuration file directive for the default run-time setting.
-cfile --contraction-table=file
 Specify the contraction table
(see section 
Contracted Braille for details).
If a relative path is supplied, then it's anchored at /etc/brltty
(see the 
--with-data-directory
and the 
--with-execute-root
build options for more details).
The .ctb extension is optional.
The contraction table is used when the 6-dot braille feature is activated
(see the 
SIXDOTS command
and the 
Text Style preference).
See the 
contraction-table
configureation file directive for the default run-time setting.
This setting can be changed with the
Contraction Table preference.
This option isn't available if the
--disable-contracted-braille build option was specified.
-ddevice,... --braille-device=device,...
 Specify the device to which the braille display is connected (see section Braille Device Specification). See the braille-device configuration file directive for the default run-time setting.
-e --standard-error
 Write diagnostic messages to standard error.
The default is to record them via syslog.
-ffile --configuration-file=file
 Specify the location of the configuration file which is to be used for the establishing of default run-time settings.
-h --help
 Display a summary of the command line options accepted by BRLTTY, and then exit.
-llevel --log-level=level
 Specify the severity threshold for diagnostic message generation. The following levels are recognized.
emergency
alert
critical
error
warning
notice
information
debug
information is assumed
(see the 
-q option for more details).
-mdevice --midi-device=device
 Specify the device to use for the Musical Instrument Digital Interface (see section MIDI Device Specification). See the midi-device configuration file directive for the default run-time setting. This option isn't available if the --disable-midi-support build option was specified.
-n --no-daemon
 Specify that BRLTTY is to remain in the foreground. If not specified, then BRLTTY becomes a background process (daemon) after initializing itself but before starting any of the selected drivers.
-pdevice --pcm-device=device
 Specify the device to use for digital audio (see section PCM Device Specification). See the pcm-device configuration file directive for the default run-time setting. This option isn't available if the --disable-pcm-support build option was specified.
-q --quiet
 Log less information.
This option changes the default log level
(see the 
-l option)
to notice if
either the 
-v
or the 
-V
option is specified, and to warning otherwise.
-sdriver,...|auto --speech-driver=driver,...|auto
 Specify the speech synthesizer driver (see section Driver Specification). See the speech-driver configuration file directive for the default run-time setting. This option isn't available if the --disable-speech-support build option was specified.
-tfile --text-table=file
 Specify the text translation table
(see section 
Translation Tables for details).
If a relative path is supplied, then it's anchored at /etc/brltty
(see the 
--with-data-directory
and the 
--with-execute-root
build options for more details).
The .tbl extension is optional.
For a simple file name, the text. prefix is optional.
See the 
text-table
configureation file directive for the default run-time setting.
This setting can be changed with the
Text Table preference.
-v --verify
 Display the current versions of BRLTTY itself, of the server side of its application programming interface, and of the selected braille and speech drivers, and then exit. If the -q option isn't specified, then also display copyright information as well as the values of the options after all sources have been considered. If more than one braille driver (see the -b command line option) and/or more than one braille device (see the -d command line option) has been specified then braille display autodetection is performed. If more than one speech driver (see the -s command line option) has been specified then speech synthesizer autodetection is performed.
-Aname=value,... --api-parameters=name=value,...
 Specify parameters for the Application Programming Interface. If the same parameter is specified more than once, then its rightmost assignment is used. For a description of the parameters accepted by the interface, please see the BrlAPI reference manual. See the api-parameters configuration file directive for the default run-time settings.
-B[driver:]name=value,... --braille-parameters=[driver:]name=value,...
 Specify parameters for the braille display drivers. If the same parameter is specified more than once, then its rightmost assignment is used. If a parameter name is qualified by a driver (see section Driver Identification Codes) then that setting only applies to that driver; if it isn't then it applies to all drivers. For a description of the parameters accepted by a specific driver, please see the documentation for that driver. See the braille-parameters configuration file directive for the default run-time settings.
-E --environment-variables
 Recognize environment variables when determining the default settings for unspecified command line options (see section Command Line Options). If this option is specified, and if the environment variable associated with an unspecified option is defined, then the value of that environment variable is used. The names of these environment variables are based on the long names of the options they correspond to:
_) are used instead of minus signs (-).BRLTTY_ is added.BRLTTY_API_PARAMETERSParameters for the Application Programming Interface (see the -A command line option).
BRLTTY_ATTRIBUTES_TABLEThe attributes translation table (see the -a command line option).
BRLTTY_BRAILLE_DEVICEThe braille display device (see the -d command line option).
BRLTTY_BRAILLE_DRIVERThe braille display driver (see the -b command line option).
BRLTTY_BRAILLE_PARAMETERSParameters for the braille display driver (see the -B command line option).
BRLTTY_CONFIGURATION_FILEThe configuration file (see the -f command line option).
BRLTTY_CONTRACTION_TABLEThe contraction table (see the -c command line option).
BRLTTY_MIDI_DEVICEThe Musical Instrument Digital Interface device (see the -m command line option).
BRLTTY_PCM_DEVICEThe digital audio device (see the -p command line option).
BRLTTY_SCREEN_PARAMETERSParameters for the screen driver (see the -X command line option).
BRLTTY_SPEECH_DRIVERThe speech synthesizer driver (see the -s command line option).
BRLTTY_SPEECH_FIFOThe speech pass-through FIFO (see the -F command line option).
BRLTTY_SPEECH_PARAMETERSParameters for the speech synthesizer driver (see the -S command line option).
BRLTTY_TEXT_TABLEThe text translation table (see the -a command line option).
-Ffile --speech-fifo=file
 Specify the FIFO (a special file which works like a pipe) which is to be used by other applications that wish to gain access to BRLTTY's speech driver. If not specified, no FIFO is created. See the speech-fifo configuration file directive for the default run-time setting. This option isn't available if the --disable-speech-support build option was specified.
-Mcsecs --message-delay=csecs
 Specify the amount of time (in hundredths of a second)
that BRLTTY keeps its own internally generated messages on the braille display.
If not specified, then 400 (4 seconds) is assumed.
-N --no-speech
 Don't automatically start the speech synthesizer driver. This option is unfortunately necessary on some systems when BRLTTY is started before the sound subsystem within the kernel has been initialized.
-Pfile --pid-file=file
 Specify the file wherein BRLTTY is to write its process identifier (pid). If not specified, BRLTTY doesn't write its process identifier anywhere.
-S[driver:]name=value,... --speech-parameters=[driver:]name=value,...
 Specify parameters for the speech synthesizer drivers. If the same parameter is specified more than once, then its rightmost assignment is used. If a parameter name is qualified by a driver (see section Driver Identification Codes) then that setting only applies to that driver; if it isn't then it applies to all drivers. For a description of the parameters accepted by a specific driver, please see the documentation for that driver. See the speech-parameters configuration file directive for the default run-time settings.
-Ucsecs --update-interval=csecs
 Specify the interval (in hundredths of a second)
at which the braille window is updated with new screen content.
If not specified, then 4 (40 milliseconds) is assumed.
-V --version
 Display the current versions of BRLTTY itself, of the server side of its application programming interface, and of those drivers which have been linked into its binary, and then exit. If the -q option isn't specified, then also display copyright information.
-Xname=value,... --screen-parameters=name=value,...
 Specify parameters for the screen driver. If the same parameter is specified more than once, then its rightmost assignment is used. For a description of the parameters accepted by a specific driver, please see the documentation for that driver. See the screen-parameters configuration file directive for the default run-time settings.