[Previous] [Contents] [Index] [Next]

Setting up Terminals

This chapter covers the following topics:

Terminal capabilities

Two kinds of terminal capabilities files give programmers the freedom to write terminal-independent programs. Older full-screen programs rely on the control codes in the terminal capabilities file /etc/termcap to make use of a terminal's capabilities. Newer programs and utilities query the terminfo capabilities database (under /usr/lib/terminfo).

Setting the terminal type

The TERM environment variable specifies a terminal type. Initially, a program queries the TERM environment variable to determine what kind of terminal it's running on. Given a terminal type, the program would then look up the terminal's capabilities either in the termcap file or in the applicable terminfo file.

The terminal type setting is typically inherited from the environment through sinit immediately after boot:

sinit -r //$(bnode)/ TERM=qnx

As an alternative, the terminal type can be defined in a user's .profile file.

For hardwired terminals that run canned applications, you can preset the TERM environment variable when the application is launched:

TERM=vt100 on -t /dev/ser1 custom_application

But you can't do that for users logging in via login through tinit. If the type of terminal is known, tinit can be told to define the TERM environment variable before launching login:

tinit -c login -t /dev/ser1 TERM=ansi &

A word about dial-up access

Unless you restrict dial-up access to only a particular type of terminal, modem users will need to run the termdef utility to query for a terminal type. The termdef utility can display all of the supported terminal types and ask the user to select one:

tinit -c "modem -c termdef" -t /dev/ser1 &

Once a terminal type has been selected, termdef sets the TERM environment variable accordingly and presents the login prompt to the user.

The termcap database

Control codes in the QNX termcap file can define the input and output capabilities of a number of terminal types, including:

For a complete list of terminal types, see /etc/termcap.

Each entry in the termcap file begins with a line of terminal aliases. The remaining sequence of control codes is a list of terminal capabilities.

Each capability string can be identified by a two-character name. In general, a string describes the terminal's behavior when the user presses a key, or the visual effect displayed through program control. If there's more than one entry for the same terminal type, the first entry is used.

The terminfo database

The terminfo subdirectories /usr/lib/terminfo/... contain binary files. Each file in the terminfo database contains the capability definitions associated with a single terminal type. QNX is shipped with several of these files, including:

/usr/lib/terminfo/q/qnx (the QNX console)

/usr/lib/terminfo/v/vt100 (a VT100 terminal)

/usr/lib/terminfo/a/ansi (an ANSI terminal)

The corresponding source definitions for all QNX-supported terminal types are contained in /usr/lib/terminfo/terminfo.src.

The termcap and terminfo source files are similar in that they both contain descriptions of terminal capabilities. However, the capability names in a terminfo file can be two to five characters long. And because the terminfo files are compiled, they load and execute faster.

If you need to convert from terminfo to termcap (as is the case for some older applications), the infocmp utility has a -C option that generates a termcap entry from an existing terminfo definition. If there's more than one entry for the same terminal type in a terminfo file, the last entry is used.

If you don't have a terminfo file for your type of terminal, you could look for the appropriate terminfo file on any UNIX system, or create a new terminfo file through the infocmp and tic utilities.

Creating a terminfo file

To view or change the information in an existing terminfo capabilities file, you must first decompile the file through the infocmp utility. To use a modified source file, you must recompile it into binary form using tic, the terminfo compiler utility. Applications can extract the capabilities they need for a given terminal directly from the compiled version.


Note: You may want to choose capabilities from the higher-level library curses instead.

Extended capabilities for mouse events

The QNX termcap and terminfo files support many of the standard terminal capabilities. In addition to these, QNX supports the following extensions to the string and numeric capabilities to handle mouse events.

termcap name terminfo name Description:
ZZ mcud1 micro_down. Don't return press.
Za mcub1 micro_left. Return mouse movement.
Zb mcuf1 micro_right. Don't return mouse movement.
Zd mcuu1 micro_up. Don't report release.
Zf mcud parm_down_micro. Return ADJUST press.
Zg mcub parm_left_micro. Return SELECT press.
Zh mcuf parm_right_micro. Return MENU press.
Zi mcuu parm_up_micro. Report button release.
ZJ smicm enter_micro_mode. Report screen size changes.
ZT rmicm exit_micro_mode. Don't report screen size changes.
Yd maddr max_micro_address. Maximum value in micro_..._ address (a numeric capability).

For more information

For a complete list of capability names and their meanings, see the terminfo technote on QUICS. For more information about termcap and terminfo, we recommend termcap & terminfo, by Strang, Mui, & O'Reilly (ISBN 0-937175-22-6).


[Previous] [Contents] [Index] [Next]