QTERM(1) QTERM(1) 6 March 1998 NAME qterm - Query Terminal SYNOPSIS qterm [ +|-alt ] [ +|-always ] [ +|-longname ] [ -querystr string ] [ +|-quiet ] [ +|-real ] [ +|-sent ] [ +|-timeout ] [ +|-trycommon ] [ +|-usrtab ] [ +|-watch ] [ +|-systab ] [ -wait interval ] [ -file tabfile ] qterm -version DESCRIPTION Qterm is used to query a terminal to determine its name. This is done by sending a special query sequence to the terminal, reading in a response, and comparing it against a table of possible responses. The ``name'' printed to standard output should be one found in the termcap(5) (or terminfo(5) for System V systems) database. Qterm works by first reading all the appropriate qtermtab files. It then goes through and tries to query the terminal first using all of the entries that were specified as primary in the qtermtab file(s). Upon receiving a response to a query for a primary entry, qterm will then proceed to query the terminal using all entries marked as secondary which have a termname field which matches the primary's nextname field. Upon receiving a response to a secondary query, the secondary's nextname field will be used as the name printed to standard output. i.e. Given a matching primary entry with a termname of vt100 and a nextname of ansi, and a secondary entry with a termname of ansi and a nextname of xterm, qterm will output xterm as the terminal name to standard output. For csh(1) users, putting a line in your .login file such as: setenv TERM `qterm` should automagically set your terminal type. For sh(1) users, putting these lines in your .profile file should set your terminal type: TERM=`qterm` export TERM By default, qterm uses the system tab file /var/local/conf/qtermtab.v6 to obtain information for querying terminals. OPTIONS If the environment variable $QTERMOPTIONS is set, it is first parsed for any of the options listed below. Options specified on the command line override options from $QTERMOPTIONS. +alt Use the alternate string ``<ESCAPE>[c'' when asking the terminal to identify itself. This string is recognized by most ANSI compatible terminals. - 1 - MagniComp QTERM(1) QTERM(1) 6 March 1998 -alt Don't use the alternate string, but the string found in the tabfile being used. This is the default. +always Always send the terminal query string. Normally the query string is only sent if it differs from the last string sent. -always Only send the terminal query string if it differs from the last string sent. This is the default. -file tabfile Use <tabfile> to find information for querying the terminal. +longname Print only the long (verbose) terminal name. -longname Don't print the long (verbose) terminal name. This is the default. -querystr string Use string as the string to send to query the terminal. The default is the query field from qtermtab. +quiet Be quiet and only print the terminal name to standard output. -quiet Don't be quiet and only print the terminal name to standard output. This is the default. +real Determine the real name of a terminal by using secondary entries in qtermtab to query for the actual terminal type. -real Don't use secondary entries to determine the real type of terminal. Only primary entries will be used. This is the default. +watch Watch the characters sent and received to the terminal. -watch Don't watch the characters sent and received to the terminal. This is the default. +timeout Wait for timeout when listening for response string. This is useful if the first entry in a qtermtab doesn't have a response - 2 - MagniComp QTERM(1) QTERM(1) 6 March 1998 string with an ending character that is common with the rest of the qtermtab entries. -timeout Disable waiting for timeout when listening for response string. This is the default. +trycommon Try sending common query sequences. After each sequence is sent, qterm checks for a response. If a response is received, the normal terminal information is display. The common answerback sequences used are those defined by the comseq entry in qtermtab. -trycommon Don't try sending common query sequences. Only use those sequences specified in the qtermtab file(s). This is the default. -version Print version information and exit. +usrtab Use $HOME/.qtermtab to find information for querying the terminal. -usrtab Don't use $HOME/.qtermtab to find information for querying the terminal. This is the default. +sent Display the final response sent from the terminal in a ``nice'' fashion. -sent Don't display the final response sent from the terminal. This is the default. +systab Use /var/local/conf/qtermtab.v6 to find information for querying the terminal. This is the default -systab Don't use system tab file to find information for querying the terminal. -wait interval Set the wait (timeout) period to interval (in seconds). QTERMTAB The format of the file $HOME/.qtermtab and qterm's system tab file /var/local/conf/qtermtab.v6, consists fields seperated by white space - 3 - MagniComp QTERM(1) QTERM(1) 6 March 1998 (tabs and/or spaces). Blank lines or lines starting with the character ``#'' are ignored and may be used as comment lines. A character preceeded by a ``^'' is taken to mean the control character. (i.e. ``^['' is interpretted as an <ESCAPE>). Both the query and response fields may contain octal values preceeded by a `\'. (i.e. <ESCAPE> can be represented by `\033'.) The first field contains a keyword which indicates how the rest of the line should be parsed. Each keyword can be in upper and/or lower case and most can be appreviated to as few as 3 characters. primary and secondary Both primary and secondary lines consist of six fields: keyword The keyword primary or secondary. query The string to use to query the terminal. response The string to expect in response to a query. termname The name of the terminal (compatible with termcap(5) and terminfo(5)) to print to standard output (stdout). nextname The name of the next terminal entry to try. A ``-'' (dash) means none. description A description of the terminal to be printed to standard error (stderr). This field may contain white space (space and/or tab) characters. comseq List of common query sequences for use with the +trycommon option. Each sequence specified should be seperated by white space. If the first field does not match one of these keywords, then the line is assumed to be an old style entry containing four fields. The first field is the string that should be used to query the terminal. The second field is the string to expect in response to the query. The third field is the terminal name. The fourth field is the description of the terminal. The response field can be a regular expression denoted by a leading backslash (`\'). i.e. "^[[123" matches the string "^[[123", whereas "^[\[123]" matches "^[1" or "^[2" or "^[3". Each character in a - 4 - MagniComp QTERM(1) QTERM(1) 6 March 1998 regular expression must be prefixed with a leading backslash. See ed(1) for regular expression information. Below is a sample file: # # Common Send sequences for use with +trycommon # comseq ^[Z ^[[c ^[[0c ^[[>c ^[[<0I ^E # # #KEY SEND RECEIVE TERM NEXT DESCRIPTION prime ^[Z ^[[?1;0c vt100 vt100 DEC VT100 prime ^[Z ^[[?1;1c vt100 vt100 DEC VT100 with STP prime ^[Z ^[[?1;2c vt100 vt100 ANSI/VT100 Clone second ^[[>c ^[[?1;20;0c vt100 vt100 Real DEC VT100 or Clone second ^[[>c ^[[?1;2c vt100 xterm XTerm Workstation Emulator RETURN VALUES qterm exits with the following status: 0 Terminal was recognized. 1 General error. 2 Terminal not recognized. AUTHOR Michael A. Cooper, MagniComp Systems FILES /var/local/conf/qtermtab.v6 - System table $HOME/.qtermtab - User's table /etc/termcap - termcap(5) database SEE ALSO csh(1), ed(1), sh(1), termcap(5) DIAGNOSTICS Terminal not recognized - defaults to dumb. qterm did not receive a response from the terminal, or the response did not match any that qterm has stored internally. Use the +watch option to check to see which is the case. BUGS Many terminals do not send a response at all. - 5 - MagniComp