packages icon



 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