Note: This page is no longer being maintained for wc3270 4.0 and later. Please refer to the the x3270 Wiki for up-to-date documentation.
Name
Synopsis
Description
Options
Modes
Code Pages
Menu Bar and Keypad
NVT Mode
Toggles
Status Line
Keymaps
File Transfer
The PrintText Action
Nested Scripts
Printer Session Support
Proxy
Resources
See Also
Copyrights
Version
[prefix:]...[LUname@]hostname[:port][=accept]
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 wc3270 to first create a TLS tunnel to the host, and then create a TN3270 session inside the tunnel. (This function is supported only if wc3270 was built with 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.
Prepending a Y: onto hostname causes wc3270 to skip validation of host TLS certificates. This overrides any other configuration or command-line options.
Prepending an A: onto hostname is equivalent to setting the -nvt option; it forces an NVT-mode session instead of a 3270-mode session.
A specific Logical Unit (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. (Note that the LU name is used for different purposes by different kinds of hosts. For example, CICS uses the LU name as the Terminal ID.)
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.
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 wc3270 and with tn3270(1), the port may also be specified as a second, separate argument.)
An optional accept name (a hostname to accept in the host's TLS certificate) may be specified by appending it to the hostname with an equals sign (`='). The accept name can also be specified with the -accepthostname option.
Note that this option is mutually-exclusive with the -scriptport option .
The first part is the base model, which is either 3278 or 3279. 3278 specifies a monochrome (green on black) 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 is 3279-4.
It can also be specified as auto, which causes wc3270 to fill the entire terminal or console window.
Note that this option is mutually-exclusive with the -httpd option .
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 "wc3270.extended" resource to "false", removes the -E from the terminal name when connecting to such hosts.
The name can also be specified with the "wc3270.termName" resource.
Interactive actions can be entered at the wc3270> prompt, to connect to a host, disconnect from a host, transfer files, display statistics, exit wc3270, etc. The complete list of interactive actions is listed under ACTIONS.
Session mode is where the emulated 3270 screen is displayed; keyboard actions cause the display buffer to be modified or data to be sent to the host.
To switch from display mode to wc3270> prompt mode, press the Escape key. To switch from wc3270> prompt mode to display mode, press Enter (without entering an action) at the wc3270> prompt.
The default code page is bracket, which is useful for common U.S. IBM hosts which use EBCDIC codes AD and BD for the `[' and `]' characters, respectively.
Note that any of the host code pages listed above can be specified by adding cp to the host code page number, e.g., cp037 for host code page 037. Also note that the code pages available for a given version of wc3270 are displayed by the -v command-line option.
Note that DBCS character sets (Chinese, Japanese) display properly only on 32-bit Windows XP. Work is proceeding on other platforms.
The on-screen menu title bar can be turned off via the "wc3270.menuBar" resource.
The pop-up keypad allows the 3270-specific keys (PF keys, PA keys, Clear, Reset, etc.) to be invoked without memorizing their key mappings or switching to the wc3270> prompt. The keypad can be popped up by pressing Alt-K, or can be invoked via a menu option.
If the host later negotiates to stop functioning in 3270 mode, wc3270 will return to NVT emulation.
In NVT mode, wc3270 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 | wc3270.icrnl | true | 
| Translate NL to CR | wc3270.inlcr | false | 
| Erase previous character | wc3270.erase | ^? | 
| Erase entire line | wc3270.kill | ^U | 
| Erase previous word | wc3270.werase | ^W | 
| Redisplay line | wc3270.rprnt | ^R | 
| Ignore special meaning of next character | wc3270.lnext | ^V | 
| Interrupt | wc3270.intr | ^C | 
| Quit | wc3270.quit | ^\ | 
| End of file | wc3270.eof | ^D | 
Separate keymaps can be defined for use only when wc3270 is in 3270 mode or NVT mode. See KEYMAPS for details.
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 | 
| Charset(charset) | change host code page | 
| CircumNot() | input "^" in NVT mode, or "¬" in 3270 mode | 
| *Clear() | clear screen | 
| Cols | report screen size | 
| Compose() | next two keys form a special symbol | 
| *Connect(host) | connect to host | 
| Copy() | copy highlighted area to clipboard | 
| *CursorSelect() | Cursor Select AID | 
| Cut() | copy highlighted area to clipboard and erase | 
| 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()([failonerror|nofailonerror]) | 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 | 
| FieldEnd() | move cursor to end of field | 
| FieldMark()([failonerror|nofailonError]) | 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 | 
| Keypad() | Display pop-up keypad | 
| Key(keysym[,failonerror|nofailonerror]) | insert key keysym | 
| Key(0xxx[,failonError|nofailonerror]) | insert key with character code xx | 
| Left() | move cursor left | 
| Left2() | move cursor left 2 positions | 
| Menu() | Display menu bar | 
| MonoCase() | toggle uppercase-only mode | 
| MoveCursor(row,col) | move cursor to zero-origin (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 | 
| Paste() | insert clipboard contents | 
| PasteString(hex_digits) | insert string using pasting behavior | 
| Printer(start[,lu]|stop) | start or stop printer session | 
| PrintText([gdi|wordpad,][dialog|nodialog,][printer-name]) | print screen text on printer | 
| Quit() | exit wc3270 | 
| Redraw() | redraw window | 
| Reset() | reset locked keyboard | 
| Right() | move cursor right | 
| Right2() | move cursor right 2 positions | 
| Rows() | report screen size | 
| *Script(command[,arg...]) | run a script | 
| Scroll(forward|backward) | scroll screen | 
| *String(string) | insert string (simple macro facility) | 
| *SelectDown | Extend selection down | 
| SelectLeft() | Extend selection left | 
| SelectUp() | Extend selection up | 
| SelectDown() | Extend selection down | 
| 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 | 
Any of the above actions may be entered at the wc3270> prompt; these actions 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.
wc3270 also supports the following interactive actions:
Note that certain parameters to wc3270 actions (such as the names of files and keymaps) are subject to substitutions:
The character ~ at the beginning of a string is replaced with the user's home directory.
Environment variables are substituted using the Unix shell convention of $name or ${name}.
Two special pseudo-environment variables are supported. ${TIMESTAMP} is replaced with a microsecond-resolution timestamp; ${UNIQUE} is replaced with a string guaranteed to make a unique filename (the process ID optionally followed by a dash and a string of digits). ${UNIQUE} is used to form trace file names.
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 NVT mode. For example, the resource definition wc3270.keymap.xxx.nvt or the file xxx.nvt.wc3270km will augment the definition of keymap xxx in NVT mode. Similarly, the resource definition wc3270.keymap.xxx.3270 or the file xxx.3270.wc3270km will augment the definition of keymap xxx in 3270 mode.
Temporary keymaps can also be added or removed while wc3270 is running with the Keymap action. See wc3270-script(1) for details.
Each line (rule) in a keymap specifies actions to perform when a particular key or sequence of keys is pressed. Keymap rules have the following syntax:
[modifier...]<Key>key...: action[(param[,...])] ...
Here is a sample keymap definition from a file:
! Lines beginning with ! are ignored and can
! occur anywhere.
! The line below will be displayed
! by the New Session Wizard.
!description: An example.
! Definition of keymap xxx
! When Alt-c is pressed, clear the screen.
Alt<Key>c: Clear()
! When PageUp is pressed, send PF7 to the host.
<Key>PRIOR: PF(7)
! When Ctrl-a is pressed, then F1, send PF13
! to the host.
Ctrl<Key>a <Key>F1: PF(13)
Here is the same definition as a resource:
! Lines beginning with ! are ignored, but NOT
! within a definition.
! Note that the \ is required at the end of the
! first line, and \n\ is
! required at the end of every other line except
! the last.
! Definition of keymap xxx
wc3270.keymap.xxx: \
Alt<Key>c: Clear() \n\
<Key>PRIOR: PF(7) \n\
Ctrl<Key>A <Key>F1: PF(13)
The optional Shift, Alt or Ctrl modifiers specify that the Shift, Alt and Ctrl keys are pressed along with the specified key, respectively. The LeftCtrl, RightCtrl, LeftAlt, and RightAlt modifiers specifify a particular Ctrl or Alt key. The Enhanced modifier is also available; Enhanced <Key>ENTER is the keypad Enter key. Key is either an ISO 8859-1 symbol name, such as equal for `=' and a for `a', or a symbolic Windows key name, such as UP. More than one key can be specified, indicating that a sequence of keys must be pressed in order for the rule to be matched. The action is an action from the ACTIONS list above. More than one action may be specified; they will be executed in order.
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 Alt-B, must be specified separately.
Available symbolic key names are: ADD, ALT, APPS, BACK (BackSpace), BackSpace (alias for BACK), CLEAR, CTRL, DECIMAL, DELETE, DIVIDE, DOWN, END, Enter (alias for RETURN), ESCAPE, Esc (alias for ESCAPE), EXECUTE, F1, F2, F3, F4, F5, F6, F7, F8, F9, F10, F11, F12, F13, F14, F15, F16, F17, F18, F19, F20, F21, F22, F23, F24, HELP, HOME, INSERT, LEFT, LMENU, LWIN (Left Windows key), MULTIPLY, NEXT (Page Down), NUMLOCK, NUMPAD0, NUMPAD1, NUMPAD2, NUMPAD3, NUMPAD4, NUMPAD5, NUMPAD6, NUMPAD7, NUMPAD8, NUMPAD9, PageUp (alias for PRIOR), PageDown (alias for Next), PAUSE, PRINT, PRIOR (Page Up), RETURN (Enter), RIGHT, RMENU, RWIN (Right Windows key), SCROLL, SELECT, SEPARATOR, SHIFT, SLEEP, SNAPSHOT, SUBTRACT, TAB and UP. In addition, any Windows VKey code can be specified in hexadecimal with the syntax VKEY-0xnn.
The base keymap is:
| Key | Action | 
| Alt<Key>1 | PA(1) | 
| Alt<Key>2 | PA(2) | 
| Alt<Key>3 | PA(3) | 
| Alt Ctrl<Key>] | Key(0x1d) | 
| Ctrl<Key>] | Escape() | 
| Alt<Key>^ | Key(notsign) | 
| Ctrl<Key>c | Copy() | 
| Alt<Key>k | Keymap() | 
| Alt<Key>l | Redraw() | 
| Alt<Key>m | Compose() | 
| Alt<Key>n | Menu() | 
| Ctrl<Key>p | Paste() | 
| Alt<Key>p | PrintText() | 
| Ctrl<Key>x | Cut() | 
| <Key>PRIOR | Scroll(backward) | 
| <Key>NEXT | Scroll(forward) | 
| Shift<Key>Fn | PF(n+12) | 
The base 3270-mode keymap adds:
| Key | Action | 
| Ctrl<Key>a | Attn() | 
| Alt<Key>a | Attn() | 
| Alt<Key>c | Clear() | 
| Ctrl<Key>d | Dup() | 
| Alt<Key>d | Dup() | 
| Ctrl<Key>f | FieldMark() | 
| Alt<Key>f | FieldMark() | 
| Ctrl<Key>h | Erase() | 
| Alt<Key>i | Insert() | 
| Shift Ctrl<Key>i | BackTab() | 
| Ctrl<Key>i | Tab() | 
| Ctrl<Key>j | Newline() | 
| Ctrl<Key>l | Redraw() | 
| Ctrl<Key>m | Enter() | 
| Ctrl<Key>r | Reset() | 
| Alt<Key>r | Reset() | 
| Ctrl<Key>u | DeleteField() | 
| <Key>INSERT | ToggleInsert() | 
| Shift<Key>TAB | BackTab() | 
| <Key>BACK | Erase() | 
| Shift<Key>END | EraseEOF() | 
| <Key>END | FieldEnd() | 
| Ctrl<Key>LEFT | PreviousWord() | 
| Ctrl<Key>RIGHT | NextWord() | 
| Shift<Key>LEFT | SelectLeft() | 
| Shift<Key>RIGHT | SelectRight() | 
| Shift<Key>UP | SelectUp() | 
| Shift<Key>DOWN | SelectDown() | 
| <Key>PRIOR | PF(7) | 
| <Key>NEXT | PF(8) | 
The Transfer() action can be entered at the wc3270> prompt with no parameters, which will cause it to prompt interactively for the file names and options. It can also be invoked with parameters to define the entire transfer.
Because of the complexity and number of options for file transfer, the parameters to the Transfer() action can take the unique form of option=value. They can also be given with their parameters separately. Options can appear in any order. Note that if the value contains spaces (such as a VM/CMS file name), then the entire parameter must be quoted, e.g., "hostfile=xxx foo a". With sequential options, this would be hostfile,"xxx foo a". The options are:
| Option | Required? | Default | Other Values | 
| direction | No | receive | send | 
| hostfile | Yes | ||
| localfile | Yes | ||
| host | No | tso | vm, cics | 
| mode | No | ascii | binary | 
| cr | No | remove | add, keep | 
| remap | No | yes | no | 
| exist | No | keep | replace, append | 
| recfm | No | fixed, variable, undefined | |
| lrecl | No | ||
| blksize | No | ||
| allocation | No | tracks, cylinders, avblock | |
| primaryspace | Sometimes | ||
| secondaryspace | No | ||
| avblock | Sometimes | ||
| buffersize | No | 4096 | 
The option details are as follows.
There are also resources that control the default values for each of the file transfer parameters. These resources have the same names as the Transfer() keywords, but with ft prepended and the option name capitalized. E.g., the default for the mode keyword is the wc3270.ftMode resource.
Multiple arguments can include keywords to control the output of PrintText():
| \b | Left() | 
| \exxxx | EBCDIC character in hex | 
| \f | Clear()* | 
| \n | Enter()* | 
| \pan | PA(n)* | 
| \pfnn | PF(nn)* | 
| \r | Newline() | 
| \t | Tab() | 
| \T | BackTab() | 
| \uxxxx | Unicode character in hex | 
| \xxxxx | Unicode character in hex | 
Note that the numeric values for the \e, \u and \x sequences can be abbreviated to 2 digits. Note also that EBCDIC codes greater than 255 and some Unicode character codes represent DBCS characters, which will work only if wc3270 is built with DBCS support and the host allows DBCS input in the current field.
An example keymap entry would be:
Alt<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 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 wc3270.printer.name specifies the Windows printer used to print each job. It defaults to the value of the $PRINTER environment variable, if set. Otherwise the default system printer is used. This resource also controls the printer used by the PrintText() action.
The resource wc3270.printer.options specifies extra options, such as -trace to pass to wpr3287.
See wpr3287(1) for further details.
The resource wc3270.printerLu controls automatic printer session start-up. If it is set to `.', then whenever a login session is started, a printer session will automatically be started, associated with the login session. If it is set an LU name, then the automatic printer session will be associated with the specified LU.
type:[username:password@]host[:port]The supported values for type are:
The special types socks4a and socks5d can also be used to force the proxy server to do the hostname resolution for the SOCKS protocol. Note that only the http and socks5 proxies support a username and password.
| Resource | Default | Option | Purpose | 
| blankFill | False | -set blankFill | Blank Fill mode | 
| charset | bracket | -charset | EBCDIC character set | 
| consoleColorForHostColorn | (note 6) | Color mapping | |
| dbcsCgcsgid | Override DBCS CGCSGID | ||
| 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 | 
| hostColorForDefault | green | Default color mapping | |
| hostColorForIntensified | red | Default color mapping | |
| hostColorForProtected | blue | Default color mapping | |
| hostColorForProtectedIntensified | neutralWhite | Default color mapping | |
| 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 | |
| kill | ^U | NVT-mode kill character | |
| lineWrap | False | -set lineWrap | NVT line wrap mode | 
| lnext | ^V | NVT-mode lnext character | |
| m3279 | (note 1) | -model | 3279 (color) emulation | 
| marginedPaste | False | -set marginedPaste | Keep left margin when pasting | 
| monoCase | False | -set monoCase | Mono-case mode | 
| noPrompt | False | -noprompt | Disable wc3270>-prompt mode | 
| numericLock | False | Lock keyboard for numeric field error | |
| oerrLock | False | Lock keyboard for input error | |
| overlayPaste | False | -set overlayPaste | Overlay protected fields when pasting | 
| oversize | -oversize | Oversize screen dimensions | |
| port | telnet | -port | Non-default TCP port | 
| printer.* | (note 4) | Printer session config | |
| printerLu | (note 4) | Printer session config | |
| printTextFont | Courier New | PrintText font name | |
| printTextSize | 8 | PrintText font size | |
| quit | ^\ | NVT-mode quit character | |
| reconnect | False | -reconnect | Automatically reconnect to host | 
| rprnt | ^R | NVT-mode reprint character | |
| sbcsCgcsgid | Override SBCS CGCSGID | ||
| secure | False | Disable "dangerous" options | |
| termName | (note 2) | -tn | TELNET terminal type string | 
| title | Console window title | ||
| traceFile | (note 3) | -tracefile | File for trace output | 
| visualBell | False | Disable bell sound | |
| werase | ^W | NVT-mode word-erase character | 
Note 1: m3279 defaults to True. It can be forced to False with the proper -model 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 3278, but this does not affect color capabilities.
Note 3: The default trace file is x3trc.pid.txt on the current user's desktop.
Note 4: See PRINTER SUPPORT for details.
Note 6: The default console color mappings for host colors 0 through 15 are: 0, 9, 12, 13, 10, 11, 14, 15, 0, 1, 12, 5, 2, 3, 7, and 15.
If more than one -xrm option is given for the same resource, the last one on the command line is used.
Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
THIS SOFTWARE IS PROVIDED BY PAUL MATTES, DON RUSSELL, DICK ALTENBERN, JEFF SPARKES AND GTRC "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL PAUL MATTES, DON RUSSELL, DICK ALTENBERN, JEFF SPARKES OR GTRC BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.