############################################################################## # Copyright (c) 1998 Free Software Foundation, Inc. # # # # Permission is hereby granted, free of charge, to any person obtaining a # # copy of this software and associated documentation files (the "Software"), # # to deal in the Software without restriction, including without limitation # # the rights to use, copy, modify, merge, publish, distribute, distribute # # with modifications, sublicense, and/or sell copies of the Software, and to # # permit persons to whom the Software is furnished to do so, subject to the # # following conditions: # # # # The above copyright notice and this permission notice shall be included in # # all copies or substantial portions of the Software. # # # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL # # THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER # # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING # # FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER # # DEALINGS IN THE SOFTWARE. # # # # Except as contained in this notice, the name(s) of the above copyright # # holders shall not be used in advertising or otherwise to promote the sale, # # use or other dealings in this Software without prior written # # authorization. # ############################################################################## # # Author: Zeyd M. Ben-Halim 1992,1995 # and: Eric S. Raymond # # $OpenBSD: Caps,v 1.4 2000/10/08 22:46:53 millert Exp $ # $From: Caps,v 1.28 2000/10/01 02:07:36 tom Exp $ # # This is the master termcap/terminfo capability table. # # This table is used to generate initializers for tables that drive tic, # infocmp, and the library compilation code used to support the termcap # compatibility hack. It is also used to generate the tabular portion of the # terminfo(5) man page; lines beginning with `#%' are passed through to become # the terminfo table. # # This file has three major sections; a standard-capabilities table, two # extension-capability tables, and a section of aliases declarations. # The first two have the same format, as follows: # # FILE FORMAT # # Column 1: terminfo variable name # Column 2: terminfo capability name # Column 3: capability type (boolean, numeric, or string) # Column 4: termcap capability name # Column 5: Lead with `Y' if capability should be emitted in termcap # translations, `-' otherwise # Column 6: capability description # # The codes following [Y-] in column 5 describe the versions of termcap which # use the given capability. This information is not used by the curses library # proper; rather, it's there to help the terminfo maintainer avoid emitting # termcap entry translations that are more than 1023 bytes long (and tank a # lot of old termcap-using programs). The codes read as follows: # B = mentioned in the BSD man page for 4.4BSD curses # C = used by the 4.4BSD curses library # G = mentioned in the documentation for GNU termcap # E = used by GNU Emacs # K = remove this terminfo capability when translating to standard format # The important codes are C and E. A cap with C or E should be preserved in # translation if possible. The problem is that preserving all such caps may # lead to some termcap translations being too long. The termcap maintainer # has a bit of a juggling act to do...potential problem cases are marked with # a * or **. # # The aliases section has the following format: # # Column 1: either `capalias' or `infoalias' # Column 2: name to be aliased # Column 3: what name it should translate to. The name IGNORE means it # should be discarded with a warning message. # Column 4: name of the extension set (used for compiler warning messages) # Column 5: capability description (usually an associated terminfo variable) # # HANDLING TERMCAP AND TERMINFO EXTENSIONS # # There are basically five different ways to handle termcap and terminfo # extensions: # # 1. Don't list the capname here, or list it but comment it out (the latter # is preferable; someone might want to handle it in the future). If you do # this, the capability will be treated as unknown and raise a warning from # the compiler. # # 2. Alias it. This is appropriate if the capability has the same meaning # as an already-supported one. The compiler will handle aliasing, emitting # an appropriate informational message whenever an alias fires. # # 3. List it in the standard table. You almost certainly do *not* want # to do this -- the capabilities in that one, and their order, have been # carefully chosen to be SVr4-binary-compatible when they're written out # as a terminfo object, and breaking this would be bad. It's up the ncurses # library what to do with the terminfo data after it's read in. # # 4. List it in the aliases table with an IGNORE target field. If you # do this, the capability will be ignored on input (though the user will # get a warning message about it). # # 5. List it in the extensions table. If you do this, the compiler will # silently accept the capability, but the curses library proper will never # see it (because it won't be written out as part of the terminfo object # format). It's up to you what you have the compiler do with it. # # There are two opposite reasons to choose option 5. One is when you want # to eat the capability silently and discard it when doing translations # to terminfo with tic -I. Some very old obsolete BSD caps like :kn: are # in this class. Nothing will ever use them again. # # More usually, you want the compiler to try to deduce something from the # capability value that it can use to translate it into your output format. # You'll need to write custom code, probably in postprocess_termcap() or # postprocess_terminfo(), to handle the translation. # # CONTROLLING ENTRY LENGTH # # Notes on specific elisions made to fit translations within 1023 bytes: # # Machines with IBM PC-like keyboards want to be able to define the following # keys: key_npage, key_ppage, key_home, key_ll (which is used for in termcap- # only environments for End or Home-Down), key_dc, and key_ic. This is also # the set of keys the `joe' editor will be upset if it can't see. So don't # trim those out of the set to be translated to termcap, or various users of # the termcap file will become irate. # # It might look tempting to leave those long init strings out of translations. # We can't do it (yet); 4.4BSD tput and tset use them. # # We retain the sgr capability in translation in spite of the fact that neither # 4.4BSD nor GNU Emacs uses it, because (a) some entry naming distinctions are # hard to understand without it, and (b) the entries in which it is long tend # to be older types that don't use up a lot of string space on function keys. # The tic(1) translation code will complain and elide it if it makes a critical # difference (there is special code in tic to recognize this situation). # # Yes, BSD tset(1) uses hpa. We elide hpa/vpa anyway because the motion # optimizer in BSD curses didn't use them. This omission seems to be the # single most effective one, it shortened the resolved length of all thirteen # problem entries in the 9.9.0 version of the terminfo master below critical. # # It would be nice to keep f11 and f12 for Emacs use, but a couple of termcap # translations go back over critical if we do this. As 4.4BSD curses fades # into history and GNU termcap's application base shrinks towards being GNU # Emacs only, we'll probably elide out some BSD-only capabilities in order # to buy space for non-essentials Emacs is still using. Capabilities high # on that hit list: rc, sc, uc. # ############################################################################# # # STANDARD CAPABILITIES # #%The following is a complete table of the capabilities included in a #%terminfo description block and available to terminfo-using code. In each #%line of the table, #% #%The \fBvariable\fR is the name by which the programmer (at the terminfo level) #%accesses the capability. #% #%The \fBcapname\fR is the short name used in the text of the database, #%and is used by a person updating the database. #%Whenever possible, capnames are chosen to be the same as or similar to #%the ANSI X3.64-1979 standard (now superseded by ECMA-48, which uses #%identical or very similar names). Semantics are also intended to match #%those of the specification. #% #%The termcap code is the old #%.B termcap #%capability name (some capabilities are new, and have names which termcap #%did not originate). #%.P #%Capability names have no hard length limit, but an informal limit of 5 #%characters has been adopted to keep them short and to allow the tabs in #%the source file #%.B Caps #%to line up nicely. #% #%Finally, the description field attempts to convey the semantics of the #%capability. You may find some codes in the description field: #%.TP #%(P) #%indicates that padding may be specified #%.TP #%#[1-9] #%in the description field indicates that the string is passed through tparm with #%parms as given (#\fIi\fP). #%.TP #%(P*) #%indicates that padding may vary in proportion to the number of #%lines affected #%.TP #%(#\d\fIi\fP\u) #%indicates the \fIi\fP\uth\d parameter. #% #%.PP #% These are the boolean capabilities: #% #%.na #%.TS H #%center expand; #%c l l c #%c l l c #%lw25 lw6 lw2 lw20. #%\fBVariable Cap- TCap Description\fR #%\fBBooleans name Code\fR auto_left_margin bw bool bw YB-G- cub1 wraps from column 0 to last column auto_right_margin am bool am YBCGE terminal has automatic margins no_esc_ctlc xsb bool xb YBCG- beehive (f1=escape, f2=ctrl C) ceol_standout_glitch xhp bool xs YBCGE standout not erased by overwriting (hp) eat_newline_glitch xenl bool xn YBCGE newline ignored after 80 cols (concept) erase_overstrike eo bool eo YBCG- can erase overstrikes with a blank generic_type gn bool gn YB-G- generic line type hard_copy hc bool hc YBCG- hardcopy terminal has_meta_key km bool km YB-GE Has a meta key (i.e., sets 8th-bit) has_status_line hs bool hs YB-G- has extra status line insert_null_glitch in bool in YBCGE insert mode distinguishes nulls memory_above da bool da YBCG- display may be retained above the screen memory_below db bool db YB-GE display may be retained below the screen move_insert_mode mir bool mi YBCGE safe to move while in insert mode move_standout_mode msgr bool ms YBCGE safe to move while in standout mode over_strike os bool os YBCG- terminal can overstrike status_line_esc_ok eslok bool es YB-G- escape can be used on the status line dest_tabs_magic_smso xt bool xt YBCGE tabs destructive, magic so char (t1061) tilde_glitch hz bool hz YB-GE can't print ~'s (hazeltine) transparent_underline ul bool ul YBCGE underline character overstrikes xon_xoff xon bool xo YB--- terminal uses xon/xoff handshaking needs_xon_xoff nxon bool nx ----- padding won't work, xon/xoff required prtr_silent mc5i bool 5i ----- printer won't echo on screen hard_cursor chts bool HC ----- cursor is hard to see non_rev_rmcup nrrmc bool NR ----- smcup does not reverse rmcup no_pad_char npc bool NP ----- pad character does not exist non_dest_scroll_region ndscr bool ND ----- scrolling region is non-destructive can_change ccc bool cc ----- terminal can re-define existing colors back_color_erase bce bool ut ----- screen erased with background color hue_lightness_saturation hls bool hl ----- terminal uses only HLS color notation (Tektronix) col_addr_glitch xhpa bool YA ----- only positive motion for hpa/mhpa caps cr_cancels_micro_mode crxm bool YB ----- using cr turns off micro mode has_print_wheel daisy bool YC ----- printer needs operator to change character set row_addr_glitch xvpa bool YD ----- only positive motion for vpa/mvpa caps semi_auto_right_margin sam bool YE ----- printing in last column causes cr cpi_changes_res cpix bool YF ----- changing character pitch changes resolution lpi_changes_res lpix bool YG ----- changing line pitch changes resolution #%.TE #%.ad #% #%These are the numeric capabilities: #% #%.na #%.TS H #%center expand; #%c l l c #%c l l c #%lw25 lw6 lw2 lw20. #%\fBVariable Cap- TCap Description\fR #%\fBNumeric name Code\fR columns cols num co YBCGE number of columns in a line init_tabs it num it YB-G- tabs initially every # spaces lines lines num li YBCGE number of lines on screen or page lines_of_memory lm num lm YB-G- lines of memory if > line. 0 means varies magic_cookie_glitch xmc num sg YBCGE number of blank characters left by smso or rmso padding_baud_rate pb num pb YB-GE lowest baud rate where padding needed virtual_terminal vt num vt YB--- virtual terminal number (CB/unix) width_status_line wsl num ws YB-G- number of columns in status line num_labels nlab num Nl ----- number of labels on screen label_height lh num lh ----- rows in each label label_width lw num lw ----- columns in each label max_attributes ma num ma YBC-- maximum combined attributes terminal can handle maximum_windows wnum num MW ----- maximum number of defineable windows # These came in with SVr4's color support max_colors colors num Co ----- maximum number of colors on screen max_pairs pairs num pa ----- maximum number of color-pairs on the screen no_color_video ncv num NC ----- video attributes that can't be used with colors #%.TE #%.ad #% #%The following numeric capabilities are present in the SVr4.0 term structure, #%but are not yet documented in the man page. They came in with SVr4's #%printer support. #% #%.na #%.TS H #%center expand; #%c l l c #%c l l c #%lw25 lw6 lw2 lw20. #%\fBVariable Cap- TCap Description\fR #%\fBNumeric name Code\fR buffer_capacity bufsz num Ya ----- numbers of bytes buffered before printing dot_vert_spacing spinv num Yb ----- spacing of pins vertically in pins per inch dot_horz_spacing spinh num Yc ----- spacing of dots horizontally in dots per inch max_micro_address maddr num Yd ----- maximum value in micro_..._address max_micro_jump mjump num Ye ----- maximum value in parm_..._micro micro_col_size mcs num Yf ----- character step size when in micro mode micro_line_size mls num Yg ----- line step size when in micro mode number_of_pins npins num Yh ----- numbers of pins in print-head output_res_char orc num Yi ----- horizontal resolution in units per line output_res_line orl num Yj ----- vertical resolution in units per line output_res_horz_inch orhi num Yk ----- horizontal resolution in units per inch output_res_vert_inch orvi num Yl ----- vertical resolution in units per inch print_rate cps num Ym ----- print rate in characters per second wide_char_size widcs num Yn ----- character step size when in double wide mode buttons btns num BT ----- number of buttons on mouse bit_image_entwining bitwin num Yo ----- number of passes for each bit-image row bit_image_type bitype num Yp ----- type of bit-image device #%.TE #%.ad #% #%These are the string capabilities: #% #%.na #%.TS H #%center expand; #%c l l c #%c l l c #%lw25 lw6 lw2 lw20. #%\fBVariable Cap- TCap Description\fR #%\fBString name Code\fR back_tab cbt str bt YBCGE back tab (P) bell bel str bl YB-GE audible signal (bell) (P) carriage_return cr str cr YBCGE carriage return (P*) (P*) change_scroll_region csr str cs YBCGE change region to line #1 to line #2 (P) clear_all_tabs tbc str ct YB-G- clear all tab stops (P) clear_screen clear str cl YBCGE clear screen and home cursor (P*) clr_eol el str ce YBCGE clear to end of line (P) clr_eos ed str cd YBCGE clear to end of screen (P*) column_address hpa str ch -B-GE** horizontal position #1, absolute (P) command_character cmdch str CC YB-G- terminal settable cmd character in prototype !? cursor_address cup str cm YBCGE move to row #1 columns #2 cursor_down cud1 str do YBCGE down one line cursor_home home str ho YBCGE home cursor (if no cup) cursor_invisible civis str vi YB-G- make cursor invisible cursor_left cub1 str le YBCGE move left one space cursor_mem_address mrcup str CM YB-G- memory relative cursor addressing, move to row #1 columns #2 cursor_normal cnorm str ve YBCGE make cursor appear normal (undo civis/cvvis) cursor_right cuf1 str nd YBCGE non-destructive space (move right one space) cursor_to_ll ll str ll YBCGE last line, first column (if no cup) cursor_up cuu1 str up YBCGE up one line cursor_visible cvvis str vs YBCGE make cursor very visible delete_character dch1 str dc YBCGE delete character (P*) delete_line dl1 str dl YBCGE delete line (P*) dis_status_line dsl str ds YB-G- disable status line down_half_line hd str hd YB-G- half a line down enter_alt_charset_mode smacs str as YB-G- start alternate character set (P) enter_blink_mode blink str mb YB-G- turn on blinking enter_bold_mode bold str md YB-G- turn on bold (extra bright) mode enter_ca_mode smcup str ti YBCGE string to start programs using cup enter_delete_mode smdc str dm YBCGE enter delete mode enter_dim_mode dim str mh YB-G- turn on half-bright mode enter_insert_mode smir str im YBCGE enter insert mode enter_secure_mode invis str mk -B-G-* turn on blank mode (characters invisible) enter_protected_mode prot str mp -B-G-* turn on protected mode enter_reverse_mode rev str mr YB-G- turn on reverse video mode enter_standout_mode smso str so YBCGE begin standout mode enter_underline_mode smul str us YBCGE begin underline mode erase_chars ech str ec YB-G- erase #1 characters (P) exit_alt_charset_mode rmacs str ae YB-G- end alternate character set (P) exit_attribute_mode sgr0 str me YB-GE turn off all attributes exit_ca_mode rmcup str te YBCGE strings to end programs using cup exit_delete_mode rmdc str ed YBCGE end delete mode exit_insert_mode rmir str ei YBCGE exit insert mode exit_standout_mode rmso str se YBCGE exit standout mode exit_underline_mode rmul str ue YBCGE exit underline mode flash_screen flash str vb YBCGE visible bell (may not move cursor) form_feed ff str ff YB-G- hardcopy terminal page eject (P*) from_status_line fsl str fs YB-G- return from status line init_1string is1 str i1 YB-G- initialization string init_2string is2 str is YB-G- initialization string init_3string is3 str i3 YB-G- initialization string init_file if str if YB-G- name of initialization file insert_character ich1 str ic YBCGE insert character (P) insert_line il1 str al YBCGE insert line (P*) insert_padding ip str ip YBCGE insert padding after inserted character key_backspace kbs str kb YB-G- backspace key key_catab ktbc str ka -B-G-* clear-all-tabs key key_clear kclr str kC -B-G-* clear-screen or erase key key_ctab kctab str kt -B-G-* clear-tab key key_dc kdch1 str kD YB-G- delete-character key key_dl kdl1 str kL -B-G-* delete-line key key_down kcud1 str kd YBCGE down-arrow key key_eic krmir str kM -B-G-* sent by rmir or smir in insert mode key_eol kel str kE -B-G-* clear-to-end-of-line key key_eos ked str kS -B-G-* clear-to-end-of-screen key key_f0 kf0 str k0 YBCGE F0 function key key_f1 kf1 str k1 YBCGE F1 function key key_f10 kf10 str k; ----E F10 function key key_f2 kf2 str k2 YBCGE F2 function key key_f3 kf3 str k3 YBCGE F3 function key key_f4 kf4 str k4 YBCGE F4 function key key_f5 kf5 str k5 YBCGE F5 function key key_f6 kf6 str k6 YBCGE F6 function key key_f7 kf7 str k7 YBCGE F7 function key key_f8 kf8 str k8 YBCGE F8 function key key_f9 kf9 str k9 YBCGE F9 function key key_home khome str kh YBCGE home key key_ic kich1 str kI YB-GE insert-character key key_il kil1 str kA -B-G-* insert-line key key_left kcub1 str kl YBCGE left-arrow key key_ll kll str kH YB-G- lower-left key (home down) key_npage knp str kN YB-GE next-page key key_ppage kpp str kP YB-GE previous-page key key_right kcuf1 str kr YBCGE right-arrow key key_sf kind str kF -B-G-* scroll-forward key key_sr kri str kR -B-G-* scroll-backward key key_stab khts str kT -B-G-* set-tab key key_up kcuu1 str ku YBCGE up-arrow key keypad_local rmkx str ke YBCGE leave 'keyboard_transmit' mode keypad_xmit smkx str ks YBCGE enter 'keyboard_transmit' mode lab_f0 lf0 str l0 -B-G-* label on function key f0 if not f0 lab_f1 lf1 str l1 -B-G-* label on function key f1 if not f1 lab_f10 lf10 str la ----- label on function key f10 if not f10 lab_f2 lf2 str l2 -B-G-* label on function key f2 if not f2 lab_f3 lf3 str l3 -B-G-* label on function key f3 if not f3 lab_f4 lf4 str l4 -B-G-* label on function key f4 if not f4 lab_f5 lf5 str l5 -B-G-* label on function key f5 if not f5 lab_f6 lf6 str l6 -B-G-* label on function key f6 if not f6 lab_f7 lf7 str l7 -B-G-* label on function key f7 if not f7 lab_f8 lf8 str l8 -B-G-* label on function key f8 if not f8 lab_f9 lf9 str l9 -B-G-* label on function key f9 if not f9 meta_off rmm str mo YB-G-* turn off meta mode meta_on smm str mm YB-G-* turn on meta mode (8th-bit on) newline nel str nw YB-G-* newline (behave like cr followed by lf) pad_char pad str pc YBCGE padding char (instead of null) parm_dch dch str DC YB-GE delete #1 characters (P*) parm_delete_line dl str DL YBCGE delete #1 lines (P*) parm_down_cursor cud str DO YBCGE down #1 lines (P*) parm_ich ich str IC YB-GE insert #1 characters (P*) parm_index indn str SF YBCG- scroll forward #1 lines (P) parm_insert_line il str AL YBCGE insert #1 lines (P*) parm_left_cursor cub str LE YBCGE move #1 characters to the left (P) parm_right_cursor cuf str RI YBCGE move #1 characters to the right (P*) parm_rindex rin str SR YBCG- scroll back #1 lines (P) parm_up_cursor cuu str UP YBCGE up #1 lines (P*) pkey_key pfkey str pk -B--- program function key #1 to type string #2 pkey_local pfloc str pl -B--- program function key #1 to execute string #2 pkey_xmit pfx str px -B--- program function key #1 to transmit string #2 print_screen mc0 str ps -B-G-* print contents of screen prtr_off mc4 str pf -B-G-* turn off printer prtr_on mc5 str po -B-G-* turn on printer repeat_char rep str rp YB-GE repeat char #1 #2 times (P*) reset_1string rs1 str r1 -B--- reset string reset_2string rs2 str r2 -B--- reset string reset_3string rs3 str r3 -B--- reset string reset_file rf str rf -B--- name of reset file restore_cursor rc str rc YBCG- restore cursor to position of last save_cursor row_address vpa str cv -B-GE** vertical position #1 absolute (P) save_cursor sc str sc YBCG- save current cursor position (P) scroll_forward ind str sf YBCGE scroll text up (P) scroll_reverse ri str sr YBCGE scroll text down (P) set_attributes sgr str sa YB-G- define video attributes #1-#9 (PG9) set_tab hts str st YB-G- set a tab in every row, current columns set_window wind str wi -B-GE current window is lines #1-#2 cols #3-#4 tab ht str ta YBCGE tab to next 8-space hardware tab stop to_status_line tsl str ts YB-G- move to status line, column #1 underline_char uc str uc YBCG- underline char and move past it up_half_line hu str hu YB-G- half a line up init_prog iprog str iP -B--- path name of program for initialization key_a1 ka1 str K1 YB-GE upper left of keypad key_a3 ka3 str K3 YB-GE upper right of keypad key_b2 kb2 str K2 YB-GE center of keypad key_c1 kc1 str K4 YB-GE lower left of keypad key_c3 kc3 str K5 YB-GE lower right of keypad prtr_non mc5p str pO -B-G-* turn on printer for #1 bytes # # SVr1 capabilities stop here. IBM's version of terminfo is the same as # SVr4 up to this point, but has a different set afterwards. # char_padding rmp str rP ----- like ip but when in insert mode acs_chars acsc str ac ----- graphics charset pairs, based on vt100 plab_norm pln str pn ----- program label #1 to show string #2 key_btab kcbt str kB ----- back-tab key enter_xon_mode smxon str SX ----- turn on xon/xoff handshaking exit_xon_mode rmxon str RX ----- turn off xon/xoff handshaking enter_am_mode smam str SA ----- turn on automatic margins exit_am_mode rmam str RA ----- turn off automatic margins xon_character xonc str XN ----- XON character xoff_character xoffc str XF ----- XOFF character ena_acs enacs str eA ----- enable alternate char set label_on smln str LO ----- turn on soft labels label_off rmln str LF ----- turn off soft labels key_beg kbeg str @1 ----- begin key key_cancel kcan str @2 ----- cancel key key_close kclo str @3 ----- close key key_command kcmd str @4 ----- command key key_copy kcpy str @5 ----- copy key key_create kcrt str @6 ----- create key key_end kend str @7 ----- end key key_enter kent str @8 ----- enter/send key key_exit kext str @9 ----- exit key key_find kfnd str @0 ----- find key key_help khlp str %1 ----- help key key_mark kmrk str %2 ----- mark key key_message kmsg str %3 ----- message key key_move kmov str %4 ----- move key key_next knxt str %5 ----- next key key_open kopn str %6 ----- open key key_options kopt str %7 ----- options key key_previous kprv str %8 ----- previous key key_print kprt str %9 ----- print key key_redo krdo str %0 ----- redo key key_reference kref str &1 ----- reference key key_refresh krfr str &2 ----- refresh key key_replace krpl str &3 ----- replace key key_restart krst str &4 ----- restart key key_resume kres str &5 ----- resume key key_save ksav str &6 ----- save key key_suspend kspd str &7 ----- suspend key key_undo kund str &8 ----- undo key key_sbeg kBEG str &9 ----- shifted begin key key_scancel kCAN str &0 ----- shifted cancel key key_scommand kCMD str *1 ----- shifted command key key_scopy kCPY str *2 ----- shifted copy key key_screate kCRT str *3 ----- shifted create key key_sdc kDC str *4 ----- shifted delete-character key key_sdl kDL str *5 ----- shifted delete-line key key_select kslt str *6 ----- select key key_send kEND str *7 ----- shifted end key key_seol kEOL str *8 ----- shifted clear-to-end-of-line key key_sexit kEXT str *9 ----- shifted exit key key_sfind kFND str *0 ----- shifted find key key_shelp kHLP str #1 ----- shifted help key key_shome kHOM str #2 ----- shifted home key key_sic kIC str #3 ----- shifted insert-character key key_sleft kLFT str #4 ----- shifted left-arrow key key_smessage kMSG str %a ----- shifted message key key_smove kMOV str %b ----- shifted move key key_snext kNXT str %c ----- shifted next key key_soptions kOPT str %d ----- shifted options key key_sprevious kPRV str %e ----- shifted previous key key_sprint kPRT str %f ----- shifted print key key_sredo kRDO str %g ----- shifted redo key key_sreplace kRPL str %h ----- shifted replace key key_sright kRIT str %i ----- shifted right-arrow key key_srsume kRES str %j ----- shifted resume key key_ssave kSAV str !1 ----- shifted save key key_ssuspend kSPD str !2 ----- shifted suspend key key_sundo kUND str !3 ----- shifted undo key req_for_input rfi str RF ----- send next input char (for ptys) key_f11 kf11 str F1 ----E F11 function key key_f12 kf12 str F2 ----E F12 function key key_f13 kf13 str F3 ----E F13 function key key_f14 kf14 str F4 ----E F14 function key key_f15 kf15 str F5 ----E F15 function key key_f16 kf16 str F6 ----E F16 function key key_f17 kf17 str F7 ----E F17 function key key_f18 kf18 str F8 ----E F18 function key key_f19 kf19 str F9 ----E F19 function key key_f20 kf20 str FA ----E F20 function key key_f21 kf21 str FB ----E F21 function key key_f22 kf22 str FC ----E F22 function key key_f23 kf23 str FD ----E F23 function key key_f24 kf24 str FE ----E F24 function key key_f25 kf25 str FF ----E F25 function key key_f26 kf26 str FG ----E F26 function key key_f27 kf27 str FH ----E F27 function key key_f28 kf28 str FI ----E F28 function key key_f29 kf29 str FJ ----E F29 function key key_f30 kf30 str FK ----E F30 function key key_f31 kf31 str FL ----E F31 function key key_f32 kf32 str FM ----E F32 function key key_f33 kf33 str FN ----E F33 function key key_f34 kf34 str FO ----E F34 function key key_f35 kf35 str FP ----E F35 function key key_f36 kf36 str FQ ----E F36 function key key_f37 kf37 str FR ----E F37 function key key_f38 kf38 str FS ----E F38 function key key_f39 kf39 str FT ----E F39 function key key_f40 kf40 str FU ----E F40 function key key_f41 kf41 str FV ----E F41 function key key_f42 kf42 str FW ----E F42 function key key_f43 kf43 str FX ----E F43 function key key_f44 kf44 str FY ----E F44 function key key_f45 kf45 str FZ ----E F45 function key key_f46 kf46 str Fa ----E F46 function key key_f47 kf47 str Fb ----E F47 function key key_f48 kf48 str Fc ----E F48 function key key_f49 kf49 str Fd ----E F49 function key key_f50 kf50 str Fe ----E F50 function key key_f51 kf51 str Ff ----E F51 function key key_f52 kf52 str Fg ----E F52 function key key_f53 kf53 str Fh ----E F53 function key key_f54 kf54 str Fi ----E F54 function key key_f55 kf55 str Fj ----E F55 function key key_f56 kf56 str Fk ----E F56 function key key_f57 kf57 str Fl ----E F57 function key key_f58 kf58 str Fm ----E F58 function key key_f59 kf59 str Fn ----E F59 function key key_f60 kf60 str Fo ----E F60 function key key_f61 kf61 str Fp ----E F61 function key key_f62 kf62 str Fq ----E F62 function key key_f63 kf63 str Fr ----E F63 function key clr_bol el1 str cb ----- Clear to beginning of line clear_margins mgc str MC ----- clear right and left soft margins set_left_margin smgl str ML ----- set left soft margin at current column set_right_margin smgr str MR ----- set right soft margin at current column label_format fln str Lf ----- label format set_clock sclk str SC ----- set clock, #1 hrs #2 mins #3 secs display_clock dclk str DK ----- display clock at (#1,#2) remove_clock rmclk str RC ----- remove clock create_window cwin str CW ----- define a window #1 from #2,#3 to #4,#5 goto_window wingo str WG ----- go to window #1 hangup hup str HU ----- hang-up phone dial_phone dial str DI ----- dial number #1 quick_dial qdial str QD ----- dial number #1 without checking tone tone str TO ----- select touch tone dialing pulse pulse str PU ----- select pulse dialing flash_hook hook str fh ----- flash switch hook fixed_pause pause str PA ----- pause for 2-3 seconds wait_tone wait str WA ----- wait for dial-tone user0 u0 str u0 ----- User string #0 user1 u1 str u1 ----- User string #1 user2 u2 str u2 ----- User string #2 user3 u3 str u3 ----- User string #3 user4 u4 str u4 ----- User string #4 user5 u5 str u5 ----- User string #5 user6 u6 str u6 ----- User string #6 user7 u7 str u7 ----- User string #7 user8 u8 str u8 ----- User string #8 user9 u9 str u9 ----- User string #9 # # SVr4 added these capabilities to support color # orig_pair op str op ----- Set default pair to its original value orig_colors oc str oc ----- Set all color pairs to the original ones initialize_color initc str Ic ----- initialize color #1 to (#2,#3,#4) initialize_pair initp str Ip ----- Initialize color pair #1 to fg=(#2,#3,#4), bg=(#5,#6,#7) set_color_pair scp str sp ----- Set current color pair to #1 set_foreground setf str Sf ----- Set foreground color #1 set_background setb str Sb ----- Set background color #1 # # SVr4 added these capabilities to support printers # change_char_pitch cpi str ZA ----- Change number of characters per inch to #1 change_line_pitch lpi str ZB ----- Change number of lines per inch to #1 change_res_horz chr str ZC ----- Change horizontal resolution to #1 change_res_vert cvr str ZD ----- Change vertical resolution to #1 define_char defc str ZE ----- Define a character enter_doublewide_mode swidm str ZF ----- Enter double-wide mode enter_draft_quality sdrfq str ZG ----- Enter draft-quality mode enter_italics_mode sitm str ZH ----- Enter italic mode enter_leftward_mode slm str ZI ----- Start leftward carriage motion enter_micro_mode smicm str ZJ ----- Start micro-motion mode enter_near_letter_quality snlq str ZK ----- Enter NLQ mode enter_normal_quality snrmq str ZL ----- Enter normal-quality mode enter_shadow_mode sshm str ZM ----- Enter shadow-print mode enter_subscript_mode ssubm str ZN ----- Enter subscript mode enter_superscript_mode ssupm str ZO ----- Enter superscript mode enter_upward_mode sum str ZP ----- Start upward carriage motion exit_doublewide_mode rwidm str ZQ ----- End double-wide mode exit_italics_mode ritm str ZR ----- End italic mode exit_leftward_mode rlm str ZS ----- End left-motion mode exit_micro_mode rmicm str ZT ----- End micro-motion mode exit_shadow_mode rshm str ZU ----- End shadow-print mode exit_subscript_mode rsubm str ZV ----- End subscript mode exit_superscript_mode rsupm str ZW ----- End superscript mode exit_upward_mode rum str ZX ----- End reverse character motion micro_column_address mhpa str ZY ----- Like column_address in micro mode micro_down mcud1 str ZZ ----- Like cursor_down in micro mode micro_left mcub1 str Za ----- Like cursor_left in micro mode micro_right mcuf1 str Zb ----- Like cursor_right in micro mode micro_row_address mvpa str Zc ----- Like row_address #1 in micro mode micro_up mcuu1 str Zd ----- Like cursor_up in micro mode order_of_pins porder str Ze ----- Match software bits to print-head pins parm_down_micro mcud str Zf ----- Like parm_down_cursor in micro mode parm_left_micro mcub str Zg ----- Like parm_left_cursor in micro mode parm_right_micro mcuf str Zh ----- Like parm_right_cursor in micro mode parm_up_micro mcuu str Zi ----- Like parm_up_cursor in micro mode select_char_set scs str Zj ----- Select character set, #1 set_bottom_margin smgb str Zk ----- Set bottom margin at current line set_bottom_margin_parm smgbp str Zl ----- Set bottom margin at line #1 or #2 lines from bottom set_left_margin_parm smglp str Zm ----- Set left (right) margin at column #1 (#2) set_right_margin_parm smgrp str Zn ----- Set right margin at column #1 set_top_margin smgt str Zo ----- Set top margin at current line set_top_margin_parm smgtp str Zp ----- Set top (bottom) margin at row #1 (#2) start_bit_image sbim str Zq ----- Start printing bit image graphics start_char_set_def scsd str Zr ----- Start character set definition stop_bit_image rbim str Zs ----- Stop printing bit image graphics stop_char_set_def rcsd str Zt ----- End definition of character set subscript_characters subcs str Zu ----- List of subscriptable characters superscript_characters supcs str Zv ----- List of superscriptable characters these_cause_cr docr str Zw ----- Printing any of these characters causes CR zero_motion zerom str Zx ----- No motion for subsequent character #%.TE #%.ad #% #%The following string capabilities are present in the SVr4.0 term structure, #%but were originally not documented in the man page. #% #%.na #%.TS H #%center expand; #%c l l c #%c l l c #%lw25 lw6 lw2 lw18. #%\fBVariable Cap- TCap Description\fR #%\fBString name Code\fR char_set_names csnm str Zy ----- List of character set names key_mouse kmous str Km ----- Mouse event has occurred mouse_info minfo str Mi ----- Mouse status information req_mouse_pos reqmp str RQ ----- Request mouse position get_mouse getm str Gm ----- Curses should get button events, parameter #1 not documented. set_a_foreground setaf str AF ----- Set foreground color to #1, using ANSI escape set_a_background setab str AB ----- Set background color to #1, using ANSI escape pkey_plab pfxl str xl ----- Program function key #1 to type string #2 and show string #3 device_type devt str dv ----- Indicate language/codeset support code_set_init csin str ci ----- Init sequence for multiple codesets set0_des_seq s0ds str s0 ----- Shift to code set 0 (EUC set 0, ASCII) set1_des_seq s1ds str s1 ----- Shift to code set 1 set2_des_seq s2ds str s2 ----- Shift to code set 2 set3_des_seq s3ds str s3 ----- Shift to code set 3 set_lr_margin smglr str ML ----- Set both left and right margins to #1, #2 set_tb_margin smgtb str MT ----- Sets both top and bottom margins to #1, #2 bit_image_repeat birep str Xy ----- Repeat bit image cell #1 #2 times bit_image_newline binel str Zz ----- Move to next row of the bit image bit_image_carriage_return bicr str Yv ----- Move to beginning of same row color_names colornm str Yw ----- Give name for color #1 define_bit_image_region defbi str Yx ----- Define rectangualar bit image region end_bit_image_region endbi str Yy ----- End a bit-image region set_color_band setcolor str Yz ----- Change to ribbon color #1 set_page_length slines str YZ ----- Set page length to #1 lines # # SVr4 added these capabilities for direct PC-clone support # display_pc_char dispc str S1 ----- Display PC character #1 enter_pc_charset_mode smpch str S2 ----- Enter PC character display mode exit_pc_charset_mode rmpch str S3 ----- Exit PC character display mode enter_scancode_mode smsc str S4 ----- Enter PC scancode mode exit_scancode_mode rmsc str S5 ----- Exit PC scancode mode pc_term_options pctrm str S6 ----- PC terminal options scancode_escape scesc str S7 ----- Escape for scancode emulation alt_scancode_esc scesa str S8 ----- Alternate escape for scancode emulation #%.TE #%.ad #% #%.in .8i #%The XSI Curses standard added these. They are some post-4.1 #%versions of System V curses, e.g., Solaris 2.5 and IRIX 6.x. #%The \fBncurses\fR termcap names for them are invented; according to the #%XSI Curses standard, they have no termcap names. If your compiled terminfo #%entries use these, they may not be binary-compatible with System V terminfo #%entries after SVr4.1; beware! #% #%.na #%.TS H #%center expand; #%c l l c #%c l l c #%lw25 lw6 lw2 lw20. #%\fBVariable Cap- TCap Description\fR #%\fBString name Code\fR enter_horizontal_hl_mode ehhlm str Xh ----- Enter horizontal highlight mode enter_left_hl_mode elhlm str Xl ----- Enter left highlight mode enter_low_hl_mode elohlm str Xo ----- Enter low highlight mode enter_right_hl_mode erhlm str Xr ----- Enter right highlight mode enter_top_hl_mode ethlm str Xt ----- Enter top highlight mode enter_vertical_hl_mode evhlm str Xv ----- Enter vertical highlight mode set_a_attributes sgr1 str sA ----- Define second set of video attributes #1-#6 set_pglen_inch slength str sL ----- YI Set page length to #1 hundredth of an inch #%.TE #%.ad # # The magic token below tells the tic compiler-generator code that all the caps # past it should be ignored (not written out) when dumping terminfo objects. It # also tells the man page table generator not to pass through following lines # This means we can have obsolete capabilities and pseudo-capabilities that are # recognized for termcap or terminfo compilation, but not output. # # %%-STOP-HERE-%% # # Don't move this casually! In fact, don't move it at all unless you're # either doing it to add System V or XPG4 extensions, or have decided you # don't care about SVr4 binary compatibility. # ############################################################################# # # TERMCAP EXTENSION CAPABILITIES # # The capabilities below are either obsolete or extensions on certain systems. # They are not used by SVR4 terminfo. Some are used by captoinfo to translate # termcap sources; the rest are listed for completeness, and in case somebody # cares about them enough to hack in code that will translate them into # terminfo capabilities. # # The first part of the list is from Ross Ridge's `mytinfo' package # (comp.sources.unix, volume 26); the variable names and terminfo names (as # well as the termcap codes) match his list. # # This group of codes is not marked obsolete in 4.4BSD, but have no direct # terminfo equivalents. The rs capability is specially translated to terminfo # r2, and vice versa, if an entry does not already have an r2. Similarly, # i2 is translated to r3 if there is no r3 (because SV terminfo maps is to i2). # The ug capability is thrown away, but assumed to be whatever sg is if the # latter is nonzero and we're dumping in termcap format. # termcap_init2 OTi2 str i2 YB--- secondary initialization string termcap_reset OTrs str rs YB-G- terminal reset string magic_cookie_glitch_ul OTug num ug YBCGE number of blanks left by ul # # Obsolete termcap capabilities. Some are used for termcap translation. The # code uses the 'OT' prefix we put on obsolete capabilities to suppress # printing them in terminfo source dumps of compiled entries. # backspaces_with_bs OTbs bool bs YBCGE uses ^H to move left crt_no_scrolling OTns bool ns YBCG- crt cannot scroll no_correctly_working_cr OTnc bool nc YBCG- no way to go to start of line carriage_return_delay OTdC num dC YB-G- pad needed for CR new_line_delay OTdN num dN YB-G- pad needed for LF linefeed_if_not_lf OTnl str nl YBCGE use to move down backspace_if_not_bs OTbc str bc YBCGE move left, if not ^H # # GNU termcap library extensions. The GNU termcap file distributed with # Emacs no longer uses these, but MT showed up in pre-9.0 versions of the # BSD termcap file. The name clash with terminfo MT is resolved by type # info; MT is converted to km. # gnu_has_meta_key OTMT bool MT ----E has meta key # gnu_tab_width OTtw num tw ----E tab width in spaces # # GNU termcap *does* include the following extended capability, Only the # now-obsolete Ann Arbor terminals used it. # # gnu_change_scroll_region OTcS str cS ---GE alternate set scrolling region # # The following comments describe capnames so ancient that I believe no # software uses them any longer. Some of these have to go because they # clash with terminfo names in ways that cannot be resolved by type # information. # # These mytinfo codes are not used in the 4.4BSD curses code. They are # marked obsolete in the 4.4BSD manual pages. # # There is one conflict with terminfo; ma is in both. This conflict is # resolved by type information. # # The `ko' capability is translated by special code. It should contain a # comma-separated list of capabilities for which there are corresponding keys. # The `kn' code is accepted but ignored. # # The `ma' capability seems to have been designed to map between the rogue(2) # motion keys (including jkhl) and characters emitted by arrow keys on some # primitive pre-ANSI terminals. It's so obsolete it's fossilized... # # Here is a description of memory_lock_above and memory_unlock: # "You can 'freeze' data on the screen by turning on Memory Lock in a line of # text. All lines above the cursor's current line become locked in place on # the screen. Then enter data normally. When the screen fills up, any # further data entered forces the first line of unfrozen line text to scroll # under the frozen data. Lines scrolled off the screen are inserted into # memory immediately preceding the first frozen line." (from the HP 700/96 # User's manual). VT100/ANSI memory lock set is \E[>2h, reset is \E[>2l. # # Applications that use terminfo are supposed to behave as though xr is # always true. # linefeed_is_newline OTNL bool NL YB--- move down with \n # even_parity OTEP bool EP -B--- terminal requires even parity # odd_parity OTOP bool OP -B--- terminal requires odd parity # half_duplex OTHD bool HD -B--- terminal is half-duplex # lower_case_only OTLC bool LC -B--- terminal has only lower case # upper_case_only OTUC bool UC -B--- terminal has only upper case backspace_delay OTdB num dB YB-G- padding required for ^H # form_feed_delay OTdF num dF -B-G- padding required for ^L horizontal_tab_delay OTdT num dT YB-G- padding required for ^I # vertical_tab_delay OTdV num dV -B--- padding required for ^V number_of_function_keys OTkn num kn -B-G- count of function keys other_non_function_keys OTko str ko -B-G- list of self-mapped keycaps arrow_key_map OTma str ma YBC-- map arrow keys rogue(1) motion keys # memory_lock_above OTml str ml -B--- lock visible screen memory above the current line # memory_unlock OTmu str mu -B--- unlock visible screen memory above the current line has_hardware_tabs OTpt bool pt YB--- has 8-char tabs invoked with ^I return_does_clr_eol OTxr bool xr YB--- return clears the line # tek_4025_insert_line OTxx bool xx -BC-- Tektronix 4025 insert-line glitch # # mytinfo described this as a termcap capability, but it's not listed in the # 4.4BSD man pages, and not found in the 4.4BSD termcap file. The ncurses # package, like System V, behaves as though it is always true. # # rind_only_at_top OTxq bool xq ----- reverse index only works from top line # # University of Waterloo termcap extensions (as described in mytinfo). # The `xl' termcap file clashes with a terminfo name; this ambiguity cannot # be resolved by a type check. The descriptions are guesses from what was # in the mytinfo tables. # # key_interrupt_char OTki str ki ----- string set by interrupt key (?) # key_kill_char OTkk str kk ----- string set by kill key (?) # key_suspend_char OTkz str kz ----- string set by suspend key (?) # initialization_messy OTxc bool xc ----- initialization leaves garbage on the screen (?) # ind_at_bottom_does_cr OTxl bool xl ----- index does a carriage return # # Nonstandard capabilities unique to Ross Ridge's `mytinfo' package. # SR clashes with a terminfo name; this ambiguity cannot be resolved by a type # check. # # scroll_left OTsl1 str Sl ----- scroll screen leftward # scroll_right OTsr1 str Sr ----- scroll screen rightward # parm_scroll_left OTsl str SL ----- scroll screen leftward #1 characters # parm_scroll_right OTsr str SR ----- scroll screen rightward #1 characters # # The mytinfo capabilities end here. # # XENIX extensions: # # Xenix defined its own set of forms-drawing capabilities: # # cap IBM ASCII description ACS ASCII # --- ----------- -------------------- ------------- ------ # G1 191 \277 M-? single upper right ACS_URCORNER # G2 218 \332 M-Z single upper left ACS_ULCORNER # G3 192 \300 M-@ single lower left ACS_LLCORNER # G4 217 \331 M-Y single lower right ACS_LRCORNER # G5 187 \273 M-; double upper right # G6 201 \311 M-I double upper left # G7 200 \310 M-H double lower left # G8 188 \274 M-< double lower right # GC 197 \305 M-E single intersection ACS_PLUS _ _ # GD 194 \302 M-B single down-tick ACS_TTEE | # GH 196 \304 M-D single horizontal line ACS_HLINE # GL 180 \264 M-4 single left tick ACS_RTEE -| # GR 195 \303 M-C single right tick ACS_LTEE |- # GU 193 \301 M-A single up tick ACS_BTEE _|_ # GV 179 \263 M-3 single vertical line ACS_VLINE # Gc 206 \316 M-N double intersection # Gd 203 \313 M-K double down tick # Gh 205 \315 M-M double horizontal line # Gl 204 \204 M-L double left tick # Gr 185 \271 M-9 double right tick # Gu 202 \312 M-J double up tick # Gv 186 \272 M-: double vertical line # # The compiler will translate the single-line caps and discard the others # (via IGNORE aliases further down). We don't want to do normal pad # translation on these, they're often single-character printable ASCII # strings that happen to be numerics. There's awk code in parametrized.sh # that detects the acs_ prefix and uses it to suppress pad translation. # These terminfo names are invented. # acs_ulcorner OTG2 str G2 ----- single upper left acs_llcorner OTG3 str G3 ----- single lower left acs_urcorner OTG1 str G1 ----- single upper right acs_lrcorner OTG4 str G4 ----- single lower right acs_ltee OTGR str GR ----- tee pointing right acs_rtee OTGL str GL ----- tee pointing left acs_btee OTGU str GU ----- tee pointing up acs_ttee OTGD str GD ----- tee pointing down acs_hline OTGH str GH ----- single horizontal line acs_vline OTGV str GV ----- single vertical line acs_plus OTGC str GC ----- single intersection # ############################################################################# # # TERMINFO EXTENSION CAPABILITIES # # This section is almost all comments. What it's mainly for is to describe # what capabilities need to be squeezed out to get down to the XSI Curses # standard set. They are flagged with K. # # HP extensions # # These extensions follow ptr_non (replacing everything after it) in HP # terminfo files. Except for memory_lock and memory_unlock, they are # functionally identical to SVr4 extensions, but they make the binary format # different. Grrr.... # memory_lock meml str ml ----K memory lock above memory_unlock memu str mu ----K memory unlock #plab_norm pln str pn ----- program label #1 to show string #2 #label_on smln str LO ----- turn on soft labels #label_off rmln str LF ----- turn off soft labels #key_f11 kf11 str F1 ----- F11 function key #key_f12 kf12 str F2 ----- F12 function key #key_f13 kf13 str F3 ----- F13 function key #key_f14 kf14 str F4 ----- F14 function key #key_f15 kf15 str F5 ----- F15 function key #key_f16 kf16 str F6 ----- F16 function key #key_f17 kf17 str F7 ----- F17 function key #key_f18 kf18 str F8 ----- F18 function key #key_f19 kf19 str F9 ----- F19 function key #key_f20 kf20 str FA ----- F20 function key #key_f21 kf21 str FB ----- F21 function key #key_f22 kf22 str FC ----- F22 function key #key_f23 kf23 str FD ----- F23 function key #key_f24 kf24 str FE ----- F24 function key #key_f25 kf25 str FF ----- F25 function key #key_f26 kf26 str FG ----- F26 function key #key_f27 kf27 str FH ----- F27 function key #key_f28 kf28 str FI ----- F28 function key #key_f29 kf29 str FJ ----- F29 function key #key_f30 kf30 str FK ----- F30 function key #key_f31 kf31 str FL ----- F31 function key #key_f32 kf32 str FM ----- F32 function key #key_f33 kf33 str FN ----- F33 function key #key_f34 kf34 str FO ----- F34 function key #key_f35 kf35 str FP ----- F35 function key #key_f36 kf36 str FQ ----- F36 function key #key_f37 kf37 str FR ----- F37 function key #key_f38 kf38 str FS ----- F38 function key #key_f39 kf39 str FT ----- F39 function key #key_f40 kf40 str FU ----- F40 function key #key_f41 kf41 str FV ----- F41 function key #key_f42 kf42 str FW ----- F42 function key #key_f43 kf43 str FX ----- F43 function key #key_f44 kf44 str FY ----- F44 function key #key_f45 kf45 str FZ ----- F45 function key #key_f46 kf46 str Fa ----- F46 function key #key_f47 kf47 str Fb ----- F47 function key #key_f48 kf48 str Fc ----- F48 function key #key_f49 kf49 str Fd ----- F49 function key #key_f50 kf50 str Fe ----- F50 function key #key_f51 kf51 str Ff ----- F51 function key #key_f52 kf52 str Fg ----- F52 function key #key_f53 kf53 str Fh ----- F53 function key #key_f54 kf54 str Fi ----- F54 function key #key_f55 kf55 str Fj ----- F55 function key #key_f56 kf56 str Fk ----- F56 function key #key_f57 kf57 str Fl ----- F57 function key #key_f58 kf58 str Fm ----- F58 function key #key_f59 kf59 str Fn ----- F59 function key #key_f60 kf60 str Fo ----- F60 function key #key_f61 kf61 str Fp ----- F61 function key #key_f62 kf62 str Fq ----- F62 function key #key_f63 kf63 str Fr ----- F63 function key # # IBM extensions # # These extensions follow ptr_non (replacing everything after it) in IBM # terminfo files. # # The places in the box[12] capabilities correspond to acsc characters, here is # the mapping: # # box1[0] = ACS_ULCORNER # box1[1] = ACS_HLINE # box1[2] = ACS_URCORNER # box1[3] = ACS_VLINE # box1[4] = ACS_LRCORNER # box1[5] = ACS_LLCORNER # box1[6] = ACS_TTEE # box1[7] = ACS_RTEE # box1[8] = ACS_BTEE # box1[9] = ACS_LTEE # box1[10] = ACS_PLUS # # The box2 characters are the double-line versions of these forms graphics. # box_chars_1 box1 str bx ----K box characters primary set #box_chars_2 box2 str by ----K box characters secondary set #box_attr_1 batt1 str Bx ----K attributes for box1 #box_attr_2 batt2 str By ----K attributes for box2 #color_bg_0 colb0 str d0 ----K background color 0 #color_bg_1 colb1 str d1 ----K background color 1 #color_bg_2 colb2 str d2 ----K background color 2 #color_bg_3 colb3 str d3 ----K background color 3 #color_bg_4 colb4 str d4 ----K background color 4 #color_bg_5 colb5 str d5 ----K background color 5 #color_bg_6 colb6 str d6 ----K background color 6 #color_bg_7 colb7 str d7 ----K background color 7 #color_fg_0 colf0 str c0 ----K foreground color 0 #color_fg_1 colf1 str c1 ----K foreground color 1 #color_fg_2 colf2 str c2 ----K foreground color 2 #color_fg_3 colf3 str c3 ----K foreground color 3 #color_fg_4 colf4 str c4 ----K foreground color 4 #color_fg_5 colf5 str c5 ----K foreground color 5 #color_fg_6 colf6 str c6 ----K foreground color 6 #color_fg_7 colf7 str c7 ----K foreground color 7 #font_0 font0 str f0 ----- select font 0 #font_1 font1 str f1 ----- select font 1 #font_2 font2 str f2 ----- select font 2 #font_3 font3 str f3 ----- select font 3 #font_4 font4 str f4 ----K select font 4 #font_5 font5 str f5 ----K select font 5 #font_6 font6 str f6 ----K select font 6 #font_7 font7 str f7 ----K select font 7 #key_back_tab kbtab str k0 ----- backtab key #key_do kdo str ki ----K do request key #key_command kcmd str kd ----K command-request key #key_command_pane kcpn str kW ----K command-pane key #key_end kend str kw ----- end key #key_help khlp str kq ----- help key #key_newline knl str nl ----K newline key #key_next_pane knpn str kv ----K next-pane key #key_prev_cmd kppn str kp ----K previous-command key #key_prev_pane kppn str kV ----K previous-pane key #key_quit kquit str kQ ----K quit key #key_select ksel str kU ----- select key #key_scroll_left kscl str kz ----K scroll left #key_scroll_right kscr str kZ ----K scroll right #key_tab ktab str ko ----K tab key #key_smap_in1 kmpf1 str Kv ----K special mapped key 1 input #key_smap_out1 kmpt1 str KV ----K special mapped key 1 output #key_smap_in2 kmpf2 str Kw ----K special mapped key 2 input #key_smap_out2 kmpt2 str KW ----K special mapped key 2 output #key_smap_in3 kmpf3 str Kx ----K special mapped key 3 input #key_smap_out3 kmpt3 str KX ----K special mapped key 3 output #key_smap_in4 kmpf4 str Ky ----K special mapped key 4 input #key_smap_out4 kmpt4 str KY ----K special mapped key 4 output #key_smap_in5 kmpf5 str Kz ----K special mapped key 5 input #key_smap_out5 kmpt5 str KZ ----K special mapped key 5 output #appl_defined_str apstr str za ----K application-defined string # The key_smap_in[6789] and key_smap_out[6789] capabilities aren't described in # the IBM manual pages, so the cap name strings are guesses. The terminfo # names are almost certainly right, the termcap ones almost certainly wrong. #key_smap_in6 kmpf6 str k! ----K special mapped key 6 input #key_smap_out6 kmpt6 str K@ ----K special mapped key 6 output #key_smap_in7 kmpf7 str k# ----K special mapped key 7 input #key_smap_out7 kmpt7 str K$ ----K special mapped key 7 output #key_smap_in8 kmpf8 str k% ----K special mapped key 8 input #key_smap_out8 kmpt8 str K^ ----K special mapped key 8 output #key_smap_in9 kmpf9 str k& ----K special mapped key 9 input #key_smap_out9 kmpt9 str K* ----K special mapped key 9 output # Undocumented capabilities end here #key_sf1 ksf1 str S1 ----K special function key 1 #key_sf2 ksf2 str S2 ----K special function key 2 #key_sf3 ksf3 str S3 ----K special function key 3 #key_sf4 ksf4 str S4 ----K special function key 4 #key_sf5 ksf5 str S5 ----K special function key 5 #key_sf6 ksf6 str S6 ----K special function key 6 #key_sf7 ksf7 str S7 ----K special function key 7 #key_sf8 ksf8 str S8 ----K special function key 8 #key_sf9 ksf9 str S9 ----K special function key 9 #key_sf10 ksf10 str SA ----K special function key 10 #key_f11 kf11 str k< ----- function key 11 #key_f12 kf12 str k> ----- function key 12 # The key_f13 through key_f64 capabilities aren't described in # the IBM manual pages, so the cap name strings are guesses. The terminfo # names are almost certainly right, the termcap ones certainly wrong. #key_f13 kf13 str k+ ----- function key 13 #key_f14 kf14 str k+ ----- function key 14 #key_f15 kf15 str k+ ----- function key 15 #key_f16 kf16 str k+ ----- function key 16 #key_f17 kf17 str k+ ----- function key 17 #key_f18 kf18 str k+ ----- function key 18 #key_f19 kf19 str k+ ----- function key 19 #key_f20 kf20 str k+ ----- function key 20 #key_f21 kf21 str k+ ----- function key 21 #key_f22 kf22 str k+ ----- function key 22 #key_f23 kf23 str k+ ----- function key 23 #key_f24 kf24 str k+ ----- function key 24 #key_f25 kf25 str k+ ----- function key 25 #key_f26 kf26 str k+ ----- function key 26 #key_f27 kf26 str k+ ----- function key 26 #key_f28 kf28 str k+ ----- function key 28 #key_f29 kf29 str k+ ----- function key 29 #key_f30 kf30 str k+ ----- function key 30 #key_f31 kf31 str k+ ----- function key 31 #key_f32 kf31 str k+ ----- function key 32 #key_f33 kf33 str k+ ----- function key 33 #key_f34 kf34 str k+ ----- function key 34 #key_f35 kf35 str k+ ----- function key 35 #key_f36 kf36 str k+ ----- function key 36 #key_f37 kf37 str k+ ----- function key 37 #key_f38 kf38 str k+ ----- function key 38 #key_f39 kf39 str k+ ----- function key 39 #key_f40 kf40 str k+ ----- function key 40 #key_f41 kf41 str k+ ----- function key 41 #key_f42 kf42 str k+ ----- function key 42 #key_f43 kf43 str k+ ----- function key 43 #key_f44 kf44 str k+ ----- function key 44 #key_f45 kf45 str k+ ----- function key 45 #key_f46 kf46 str k+ ----- function key 46 #key_f47 kf47 str k+ ----- function key 47 #key_f48 kf48 str k+ ----- function key 48 #key_f49 kf49 str k+ ----- function key 49 #key_f50 kf50 str k+ ----- function key 50 #key_f51 kf51 str k+ ----- function key 51 #key_f52 kf52 str k+ ----- function key 52 #key_f53 kf53 str k+ ----- function key 53 #key_f54 kf54 str k+ ----- function key 54 #key_f55 kf55 str k+ ----- function key 55 #key_f56 kf56 str k+ ----- function key 56 #key_f57 kf57 str k+ ----- function key 57 #key_f58 kf58 str k+ ----- function key 58 #key_f59 kf59 str k+ ----- function key 59 #key_f60 kf60 str k+ ----- function key 60 #key_f61 kf61 str k+ ----- function key 61 #key_f62 kf62 str k+ ----- function key 62 #key_f63 kf63 str k+ ----- function key 63 # Undocumented capabilities end here. #key_action kact str kJ ----K sent by action key # The IBM docs say these capabilities are for table-drawing, and are # valid only for aixterm descriptions. #enter_topline_mode topl str tp ----K start top-line mode #enter_bottom_mode btml str bm ----K start bottom-line mode #enter_rvert_mode rvert str rv ----K start right-vertical mode #enter_lvert_mode lvert str lv ----K start left-vertical mode # ############################################################################# # # ALIAS DECLARATIONS # # Here we set up aliases for translating extensions into standard terminfo. # #---------------------------------- Termcap aliases ------------------------- # # BSD aliases: # # This is a common error in many termcap files. We'll get notified during # translation when this (or any other alias) fires. # capalias sb sr BSD scroll text down # # AT&T extensions: # # The old AT&T 5410, 5420, 5425, pc6300plus, 610, and s4 entries used a set of # nonstandard capabilities. Its signature is the KM capability, used to name # some sort of keymap file. EE, BO, CI, CV, XS, DS, FL and FE are in this # set. Comments in the original, and a little cross-checking with other AT&T # documentation, seem to establish the following mappings: # capalias BO mr AT&T enter_reverse_mode capalias CI vi AT&T cursor_invisible capalias CV ve AT&T cursor_normal capalias DS mh AT&T enter_dim_mode #capalias EE me AT&T exit_attribute_mode capalias FE LF AT&T label_on capalias FL LO AT&T label_off capalias XS mk AT&T enter_secure_mode # # We comment out EE because the conflicting XENIX EE is more common in # old entries. # # XENIX extensions: # # These are the ones we know how to translate directly: # capalias EE mh XENIX exit_attribute_mode capalias GE ae XENIX exit_alt_charset_mode capalias GS as XENIX enter_alt_charset_mode capalias CF vi XENIX cursor_invis capalias CO ve XENIX cursor_normal capalias EN @7 XENIX key_end capalias HM kh XENIX key_home capalias LD kL XENIX key_dl capalias PD kN XENIX key_npage capalias PN po XENIX prtr_off capalias PS pf XENIX prtr_on capalias PU kP XENIX key_ppage capalias RT @8 XENIX kent capalias UP ku XENIX kcuu1 capalias G6 IGNORE XENIX double-ACS_ULCORNER capalias G7 IGNORE XENIX double-ACS_LLCORNER capalias G5 IGNORE XENIX double-ACS_URCORNER capalias G8 IGNORE XENIX double-ACS_LRCORNER capalias Gr IGNORE XENIX double-ACS_LTEE capalias Gr IGNORE XENIX double-ACS_RTEE capalias Gu IGNORE XENIX double-ACS_BTEE capalias Gd IGNORE XENIX double ACS_TTEE capalias Gh IGNORE XENIX double-ACS_HLINE capalias Gv IGNORE XENIX double-ACS_VLINE capalias Gc IGNORE XENIX double-ACS_PLUS capalias GG IGNORE XENIX acs-glitch # # IBM extensions: # capalias kq %1 IBM key_help # # Iris extensions: # capalias HS mh IRIS enter_dim_mode # # Tektronix extensions: # capalias KA k; Tek key_f10 capalias KB F1 Tek key_f11 capalias KC F2 Tek key_f12 capalias KD F3 Tek key_f13 capalias KE F4 Tek key_f14 capalias KF F5 Tek key_f15 capalias BC Sb Tek set_background capalias FC Sf Tek set_foreground # # There are also the following: # # XENIX XENIX variable name name clash with terminfo? # ----- ------------------- ------------------------- # CL key_char_left # CR key_char_right # CW key_change_window # HP ?? # LF key_linefeed label_off # NU key_next_unlocked_cell # PL ?? # PR ?? # RC key_recalc remove_clock # RF key_toggle_ref req_for_input # WL key_word_left # WR key_word_right # # If you know what any of the question-marked ones mean, please tell us. # #--------------------------------- Terminfo aliases ------------------------ # # IBM extensions: # infoalias font0 s0ds IBM set0_des_seq infoalias font1 s1ds IBM set1_des_seq infoalias font2 s2ds IBM set2_des_seq infoalias font3 s3ds IBM set3_des_seq infoalias kbtab kcbt IBM key_backtab infoalias ksel kslt IBM key_select # # Some others are identical to SVr4/XPG4 capabilities, in particular: # kcmd, kend, khlp, and kf11...kf63. # ############################################################################# # # The following sets edit modes for GNU EMACS # Local Variables: # case-fold-search:nil # truncate-lines:t # End: