Name
Synopsis
Description
Options
Character Sets
Hosts Database
NVT (ANSI) Mode
Toggles
Status Line
Actions
Keymaps
The Meta or Alt Key
File Transfer
Scripts
Composite Characters
Printer Support
Passthru
Screen Size Switching
Resources
Files
See Also
Copyrights
Version
The full syntax for host is:
[prefix:]...[LUname@]hostname[:port]
Prepending a P: onto hostname causes the connection to go through the telnet-passthru service rather than directly to the host. See PASSTHRU below.
Prepending an S: onto hostname removes the "extended data stream" option reported to the host. See -tn below for further information.
Prepending an N: onto hostname turns off TN3270E support for the session.
Prepending an L: onto hostname causes c3270 to first create an SSL tunnel to the host, and then create a TN3270 session inside the tunnel. (This function is supported only if c3270 was built with SSL/TLS support). Note that TLS-encrypted sessions using the TELNET START-TLS option are negotiated with the host automatically; for these sessions the L: prefix should not be used.
A specific LU name to use may be specified by prepending it to the hostname with an `@'. Multiple LU names to try can be separated by commas. An empty LU can be placed in the list with an extra comma.
The hostname may optionally be placed inside square-bracket characters `[' and `]'. This will prevent any colon `:' characters in the hostname from being interpreted as indicating option prefixes or port numbers. This allows numeric IPv6 addresses to be used as hostnames.
On systems that support the forkpty library call, the hostname may be replaced with -e and a command string. This will cause c3270 to connect to a local child process, such as a shell.
The port to connect to defaults to telnet. This can be overridden with the -port option, or by appending a port to the hostname with a colon `:'. (For compatability with previous versions of c3270 and with tn3270(1), the port may also be specified as a second, separate argument.)
The first part is the base model, which is either 3278 or 3279. 3278 specifies a monochrome 3270 display; 3279 specifies a color 3270 display.
The second part is the model number, which specifies the number of rows and columns. Model 4 is the default.
Note: Technically, there is no such 3270 display as a 3279-4 or 3279-5, but most hosts seem to work with them anyway.
The default model for a color display is 3279-4. For a monochrome display, it is 3278-4.
Some hosts are confused by the -E suffix on the terminal name, and will ignore the extra screen area on models 3, 4 and 5. Prepending an s: on the hostname, or setting the "c3270.extended" resource to "false", removes the -E from the terminal name when connecting to such hosts.
The name can also be specified with the "c3270.termName" resource.
The default character set is bracket, which is useful for common IBM hosts which use EBCDIC codes 0xAD and 0xBD for the `[' and `]' characters, respectively.
You may specify a different ibm_hosts database with the "c3270.hostsFile" resource.
If the host later negotiates to stop functioning in 3270 mode, c3270 will return to ANSI emulation.
In NVT mode, c3270 supports both character-at-a-time mode and line mode operation. You may select the mode with a menu option. When in line mode, the special characters and operational characteristics are defined by resources:
Mode/Character | Resource | Default |
Translate CR to NL | c3270.icrnl | true |
Translate NL to CR | c3270.inlcr | false |
Erase previous character | c3270.erase | ^? |
Erase entire line | c3270.kill | ^U |
Erase previous word | c3270.werase | ^W |
Redisplay line | c3270.rprnt | ^R |
Ignore special meaning of next character | c3270.lnext | ^V |
Interrupt | c3270.intr | ^C |
Quit | c3270.quit | ^\ |
End of file | c3270.eof | ^D |
Separate keymaps can be defined for use only when c3270 is in 3270 mode or NVT mode. See KEYMAPS for details.
The names of the toggles for use with the -set and -clear options are as follows:
Option | Name |
Monocase | monoCase |
Blank Fill | blankFill |
Track Cursor | cursorPos |
Trace Data Stream | dsTrace |
Trace Events | eventTrace |
Save Screen(s) in File | screenTrace |
Wraparound | lineWrap |
These names are also used as the first parameter to the Toggle action.
Actions marked with an asterisk (*) may block, sending data to the host and possibly waiting for a response.
*Attn | attention key |
BackSpace | move cursor left (or send ASCII BS) |
BackTab | tab to start of previous input field |
CircumNot | input "^" in NVT mode, or "¬" in 3270 mode |
*Clear | clear screen |
Compose | next two keys form a special symbol |
*Connect(host) | connect to host |
*CursorSelect | Cursor Select AID |
Delete | delete character under cursor (or send ASCII DEL) |
DeleteField | delete the entire field |
DeleteWord | delete the current or previous word |
*Disconnect | disconnect from host |
Down | move cursor down |
Dup | duplicate field |
*Enter | Enter AID (or send ASCII CR) |
Erase | erase previous character (or send ASCII BS) |
EraseEOF | erase to end of current field |
EraseInput | erase all input fields |
Escape | escape to c3270> prompt |
Execute(cmd) | execute a command in a shell |
FieldEnd | move cursor to end of field |
FieldMark | mark field |
HexString(hex_digits) | insert control-character string |
Home | move cursor to first input field |
Insert | set insert mode |
*Interrupt | send TELNET IP to host |
Key(keysym) | insert key keysym |
Key(0xxx) | insert key with ASCII code xx |
Left | move cursor left |
Left2 | move cursor left 2 positions |
MonoCase | toggle uppercase-only mode |
MoveCursor(row, col) | move cursor to (row,col) |
Newline | move cursor to first field on next line (or send ASCII LF) |
NextWord | move cursor to next word |
*PA(n) | Program Attention AID (n from 1 to 3) |
*PF(n) | Program Function AID (n from 1 to 24) |
PreviousWord | move cursor to previous word |
Printer(Start[,lu]|Stop) | Start or stop printer session |
PrintText(command) | print screen text on printer |
Quit | exit c3270 |
Redraw | redraw window |
Reset | reset locked keyboard |
Right | move cursor right |
Right2 | move cursor right 2 positions |
*Script(command[,arg...]) | run a script |
*String(string) | insert string (simple macro facility) |
*SysReq | System Request AID |
Tab | move cursor to next input field |
Toggle(option[,set|clear]) | toggle an option |
ToggleInsert | toggle insert mode |
ToggleReverse | toggle reverse-input mode |
*Transfer(option=value...) | file transfer |
Up | move cursor up |
ignore | do nothing |
Any of the above actions may be entered at the c3270> prompt; these commands are also available for use in keymaps (see KEYMAPS). Command names are case-insensitive. Parameters can be specified with parentheses and commas, e.g.:
PF(1)or with spaces, e.g.:
PF 1Parameters can be quoted with double-quote characters, to allow spaces, commas, and parentheses to be used.
c3270 also supports the following interactive commands:
Multiple keymaps may be specified be separating their names with commas. Definitions in later keymaps supercede those in earlier keymaps.
In addition, separate keymaps may be defined that apply only in 3270 mode or only in NVT mode. For example, the resource definition c3270.keymap.xxx.nvt will augment the definition of c3270.keymap.xxx, when c3270 is in NVT mode. Similarly, the resource definition c3270.keymap.xxx.3270 will augment the definition of c3270.keymap.xxx, when c3270 is in 3270 mode.
Keymaps specify actions to perform when a particular sequence of keys is pressed. Each line in a keymap has the following syntax:
[Meta][Ctrl]<Key>key...: Action[(param[,...])] ...
For example:
Meta<Key>c: Clear()
<Key>PPAGE: PF(7)
Ctrl<Key>A <Key>F1: PF(13)
The optional Meta or Ctrl qualifiers specify that the Meta and Ctrl keys are pressed along with the specified key, respectively. The key is either a valid X11 keysym (these are the ISO 8859-1 symbol names, such as equal for `=' and a for `a') or a valid symbolic ncurses key name, such as UP. The Action is an action from the ACTIONS list, above. More than one action may be specified. (Note that symbolic ncurses key names can be used only if the c3270.cursesKeymap resource is set to True, which enables ncurses keymap mode.)
Keymap entries are case-sensitive and modifier-specific. This means that a keymap for the b key will match only a lowercase b. Actions for uppercase B, or for Meta-b or Control-B, must be specified separately.
The base keymap is:
Key | Action |
Ctrl<Key>] | Escape |
Ctrl<Key>a Ctrl<Key>a | Key(0x01) |
Ctrl<Key>a Ctrl<Key>] | Key(0x1d) |
Ctrl<Key>a <Key>Tab | BackTab |
Ctrl<Key>a <Key>c | Clear |
Ctrl<Key>a <Key>e | Escape |
Ctrl<Key>a <Key>r | Reset |
Ctrl<Key>a <Key>l | Redraw |
Ctrl<Key>a <Key>m | Compose |
Ctrl<Key>a <Key>^ | Key(notsign) |
<Key>UP | Up |
<Key>DOWN | Down |
<Key>LEFT | Left |
<Key>RIGHT | Right |
<Key>F(n) | PF(n) |
Ctrl<Key>a <Key>F(n) | PF(n+12) |
Ctrl<Key>a <Key>1 | PA(1) |
Ctrl<Key>a <Key>2 | PA(2) |
Ctrl<Key>a <Key>3 | PA(3) |
The base 3270-mode keymap adds:
Key | Action |
Ctrl<Key>c | Clear |
Ctrl<Key>r | Reset |
Ctrl<Key>l | Redraw |
<Key>Tab | Tab |
<Key>DC | Delete |
<Key>BACKSPACE | BackSpace |
<Key>BackSpace | BackSpace |
<Key>Return | Enter |
<Key>Linefeed | Newline |
The resource c3270.metaEscape and the termcap km attribute control how c3270 will interpret these sequences. When c3270.metaEscape is set to true, or when c3270.metaEscape is set to auto and the termcap km attribute is set, the keyboard is assumed to have a separate Meta key. The Escape key can be used as an ordinary data key and has no special meaning.
When c3270.metaEscape is set to true, or when c3270.metaEscape is set to auto and the termcap km attribute is not set, the keyboard is assumed to use the Escape character as a prefix to indicate that the following character is supposed to have the high-order bit set. When c3270 sees an Escape character from the keyboard, it sets a short timeout. If another character arrives before the timeout expires, then c3270 will combine the two characters, setting the high-order bit of the second. In an event trace file, the combined character is listed as derived. In a keymap, only the combined character or the Meta prefix may be used. The Escape key can still be used by itself, but only if there is a short pause before pressing another key.
The default value for c3270.metaEscape is auto.
Because of the complexity and number of options for file transfer, the parameters to the Transfer action take the unique form of option=value, and can appear in any order. The options are:
Option | Required? | Default | Other Values |
Direction | No | send | receive |
HostFile | Yes | ||
LocalFile | Yes | ||
Host | No | tso | vm |
Mode | No | ascii | binary |
Cr | No | remove | add, keep |
Exist | No | keep | replace, append |
Recfm | No | fixed, variable, undefined | |
Lrecl | No | ||
Blksize | No | ||
Allocation | No | tracks, cylinders, avblock | |
PrimarySpace | No | ||
SecondarySpace | No | ||
BufferSize | No | 4096 |
The option details are as follows.
\b | Left |
\f | Clear* |
\n | Enter* |
\pan | PA(n)* |
\pfnn | PF(nn)* |
\r | Newline |
\t | Tab |
\T | BackTab |
An example keymap entry would be:
Meta<Key>p: String("probs clearrdr\n")
Note: The strings are in ASCII and converted to EBCDIC, so beware of inserting control codes.
There is also an alternate form of the String action, HexString, which is used to enter non-printing data. The argument to HexString is a string of hexadecimal digits, two per character. A leading 0x or 0X is optional. In 3270 mode, the hexadecimal data represent EBCDIC characters, which are entered into the current field. In NVT mode, the hexadecimal data represent ASCII characters, which are sent directly to the host.
The mappings between these pairs of ordinary keys and the symbols they represent is controlled by the "c3270.composeMap" resource; it gives the name of the map to use. The maps themselves are named "c3270.composeMap.name". The default is "latin1", which gives mappings for most of the symbols in the ISO 8859-1 Latin-1 character set that are not in the 7-bit ASCII character set.
Note: The default keymap defines Meta<Key>m as the "Compose" key. You may set up your own "Compose" key with a keymap that maps some other keysym onto the Compose action.
The action Printer Start starts a printer session, associated with the current LU. (This works only if the host supports TN3270E.)
The action Printer Start lu starts a printer session, associated with a specific lu.
The action Printer Stop stops a printer session.
The resource c3270.printer.command specifies the command used to print each job; it defaults to lpr. The resource c3270.printer.assocCommandLine specifies the command used to start an associated printer session. It defaults to:
pr3287 -assoc %L% -command "%C%" %H%
The resource c3270.printer.luCommandLine specifies the command used to start a specific-LU printer session. It defaults to:
pr3287 -command "%C%" %L%@%H%
When the printer session command is run, the following substitutions are made:
Token | Substitition |
%C% | Command (value of c3270.printer.command) |
%H% | Host IP address |
%L% | Current or specified LU |
See pr3287(1) for further details.
Because the curses library does not support mode switching, the escape sequences and resulting screen dimensions must be specified explicitly to c3270. These are specified with the -altscreen and -defscreen command-line options, or the altScreen and defScreen resources. -altscreen or altScreen defines the alternate (132-column) mode; -defscreen or defScreen defines the default (80-column) mode.
The syntax for the options and resources is rowsxcols=init_string, where rows and cols give the screen dimensions, and init_string is the escape sequence to transmit to the terminal to enter that mode. For defscreen, the minimum dimensions are 24 rows and 80 columns. For altscreen, the minimum dimensions are 27 rows and 132 columns. Within init_string, the usual escape sequences are supported (\E for escape, \r, \b, etc.). For example, the init string for a 132-column xterm is:
\E[?40h\E[?3h
Note: When defscreen and altscreen are specified, the model number is always set to 5.
Resource | Default | Option | Purpose |
allBold | Auto | -allbold | Display all characters bold |
altScreen | -altscreen | 132-col screen definition | |
blankFill | False | -set blankFill | Blank Fill mode |
charset | bracket | -charset | EBCDIC character set |
charset.foo | Definition of character set foo | ||
composeMap | latin1 | Name of composed-character map | |
cursesKeymap | True | Set curses keymap option | |
defScreen | -defscreen | 80-col screen definition | |
dsTrace | False | -trace | Data stream tracing |
eof | ^D | NVT-mode EOF character | |
erase | ^H | NVT-mode erase character | |
extended | True | Use 3270 extended data stream | |
eventTrace | False | -trace | Event tracing |
ftCommand | ind$file | Host file transfer command | |
hostsFile | -hostsfile | Host alias/macro file | |
icrnl | False | Map CR to NL on NVT-mode input | |
inlcr | False | Map NL to CR in NVT-mode input | |
intr | ^C | NVT-mode interrupt character | |
keymap | -keymap | Keyboard map name | |
keymap.foo | Definition of keymap foo | ||
kill | ^U | NVT-mode kill character | |
lineWrap | False | -set lineWrap | NVT line wrap mode |
lnext | ^V | NVT-mode lnext character | |
m3279 | (note 1) | -mono | 3279 (color) emulation |
metaEscape | Auto | Interpret ESC-x as Meta-x | |
monoCase | False | -set monoCase | Mono-case mode |
numericLock | False | Lock keyboard for numeric field error | |
oerrLock | True | Lock keyboard for input error | |
oversize | -oversize | Oversize screen dimensions | |
port | telnet | -port | Non-default TCP port |
printer.* | (note 4) | Printer session config | |
quit | ^\ | NVT-mode quit character | |
rprnt | ^R | NVT-mode reprint character | |
secure | False | Disable "dangerous" options | |
termName | (note 2) | -tn | TELNET terminal type string |
traceDir | /tmp | Directory for trace files | |
traceFile | (note 3) | -tracefile | File for trace output |
typeahead | True | Allow typeahead | |
werase | ^W | NVT-mode word-erase character |
Note 1: m3279 defaults to True if the terminal supports color, False otherwise. It can be forced to False with the -mono option.Note 2: The default terminal type string is constructed from the model number, color emulation, and extended data stream modes. E.g., a model 2 with color emulation and the extended data stream option would be sent as IBM-3279-2-E. Note also that when TN3270E mode is used, the terminal type is always sent as some type of 3278.
Note 3: The default trace file is x3trc.pid in the directory specified by the traceDir resource.
Note 4: See PRINTER SUPPORT for details.
In .c3270pro, lines are continued with a backslash character.
-xrm options override definitions found in .c3270pro. If more than one -xrm option is given for the same resource, the last one on the command line is used.
Modifications Copyright © 1993, 1994, 1995, 1996, 1997, 1999, 2000, 2001, 2002, 2004 by Paul Mattes.
Original X11 Port Copyright © 1990 by Jeff Sparkes.
Permission to use, copy, modify, and distribute this software and its documentation for any purpose and without fee is hereby granted, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation.Copyright © 1989 by Georgia Tech Research Corporation, Atlanta, GA 30332.
All Rights Reserved. GTRC hereby grants public use of this software. Derivative works based on this software must incorporate this copyright notice.