1 :mod:`curses` --- Terminal handling for character-cell displays 2 =============================================================== 3 4 .. module:: curses 5 :synopsis: An interface to the curses library, providing portable 6 terminal handling. 7 :platform: Unix 8 9 .. sectionauthor:: Moshe Zadka <moshez (a] zadka.site.co.il> 10 .. sectionauthor:: Eric Raymond <esr (a] thyrsus.com> 11 12 -------------- 13 14 The :mod:`curses` module provides an interface to the curses library, the 15 de-facto standard for portable advanced terminal handling. 16 17 While curses is most widely used in the Unix environment, versions are available 18 for Windows, DOS, and possibly other systems as well. This extension module is 19 designed to match the API of ncurses, an open-source curses library hosted on 20 Linux and the BSD variants of Unix. 21 22 .. note:: 23 24 Whenever the documentation mentions a *character* it can be specified 25 as an integer, a one-character Unicode string or a one-byte byte string. 26 27 Whenever the documentation mentions a *character string* it can be specified 28 as a Unicode string or a byte string. 29 30 .. note:: 31 32 Since version 5.4, the ncurses library decides how to interpret non-ASCII data 33 using the ``nl_langinfo`` function. That means that you have to call 34 :func:`locale.setlocale` in the application and encode Unicode strings 35 using one of the system's available encodings. This example uses the 36 system's default encoding:: 37 38 import locale 39 locale.setlocale(locale.LC_ALL, '') 40 code = locale.getpreferredencoding() 41 42 Then use *code* as the encoding for :meth:`str.encode` calls. 43 44 .. seealso:: 45 46 Module :mod:`curses.ascii` 47 Utilities for working with ASCII characters, regardless of your locale settings. 48 49 Module :mod:`curses.panel` 50 A panel stack extension that adds depth to curses windows. 51 52 Module :mod:`curses.textpad` 53 Editable text widget for curses supporting :program:`Emacs`\ -like bindings. 54 55 :ref:`curses-howto` 56 Tutorial material on using curses with Python, by Andrew Kuchling and Eric 57 Raymond. 58 59 The :source:`Tools/demo/` directory in the Python source distribution contains 60 some example programs using the curses bindings provided by this module. 61 62 63 .. _curses-functions: 64 65 Functions 66 --------- 67 68 The module :mod:`curses` defines the following exception: 69 70 71 .. exception:: error 72 73 Exception raised when a curses library function returns an error. 74 75 .. note:: 76 77 Whenever *x* or *y* arguments to a function or a method are optional, they 78 default to the current cursor location. Whenever *attr* is optional, it defaults 79 to :const:`A_NORMAL`. 80 81 The module :mod:`curses` defines the following functions: 82 83 84 .. function:: baudrate() 85 86 Return the output speed of the terminal in bits per second. On software 87 terminal emulators it will have a fixed high value. Included for historical 88 reasons; in former times, it was used to write output loops for time delays and 89 occasionally to change interfaces depending on the line speed. 90 91 92 .. function:: beep() 93 94 Emit a short attention sound. 95 96 97 .. function:: can_change_color() 98 99 Return ``True`` or ``False``, depending on whether the programmer can change the colors 100 displayed by the terminal. 101 102 103 .. function:: cbreak() 104 105 Enter cbreak mode. In cbreak mode (sometimes called "rare" mode) normal tty 106 line buffering is turned off and characters are available to be read one by one. 107 However, unlike raw mode, special characters (interrupt, quit, suspend, and flow 108 control) retain their effects on the tty driver and calling program. Calling 109 first :func:`raw` then :func:`cbreak` leaves the terminal in cbreak mode. 110 111 112 .. function:: color_content(color_number) 113 114 Return the intensity of the red, green, and blue (RGB) components in the color 115 *color_number*, which must be between ``0`` and :const:`COLORS`. Return a 3-tuple, 116 containing the R,G,B values for the given color, which will be between 117 ``0`` (no component) and ``1000`` (maximum amount of component). 118 119 120 .. function:: color_pair(color_number) 121 122 Return the attribute value for displaying text in the specified color. This 123 attribute value can be combined with :const:`A_STANDOUT`, :const:`A_REVERSE`, 124 and the other :const:`A_\*` attributes. :func:`pair_number` is the counterpart 125 to this function. 126 127 128 .. function:: curs_set(visibility) 129 130 Set the cursor state. *visibility* can be set to ``0``, ``1``, or ``2``, for invisible, 131 normal, or very visible. If the terminal supports the visibility requested, return the 132 previous cursor state; otherwise raise an exception. On many 133 terminals, the "visible" mode is an underline cursor and the "very visible" mode 134 is a block cursor. 135 136 137 .. function:: def_prog_mode() 138 139 Save the current terminal mode as the "program" mode, the mode when the running 140 program is using curses. (Its counterpart is the "shell" mode, for when the 141 program is not in curses.) Subsequent calls to :func:`reset_prog_mode` will 142 restore this mode. 143 144 145 .. function:: def_shell_mode() 146 147 Save the current terminal mode as the "shell" mode, the mode when the running 148 program is not using curses. (Its counterpart is the "program" mode, when the 149 program is using curses capabilities.) Subsequent calls to 150 :func:`reset_shell_mode` will restore this mode. 151 152 153 .. function:: delay_output(ms) 154 155 Insert an *ms* millisecond pause in output. 156 157 158 .. function:: doupdate() 159 160 Update the physical screen. The curses library keeps two data structures, one 161 representing the current physical screen contents and a virtual screen 162 representing the desired next state. The :func:`doupdate` ground updates the 163 physical screen to match the virtual screen. 164 165 The virtual screen may be updated by a :meth:`~window.noutrefresh` call after write 166 operations such as :meth:`~window.addstr` have been performed on a window. The normal 167 :meth:`~window.refresh` call is simply :meth:`!noutrefresh` followed by :func:`!doupdate`; 168 if you have to update multiple windows, you can speed performance and perhaps 169 reduce screen flicker by issuing :meth:`!noutrefresh` calls on all windows, 170 followed by a single :func:`!doupdate`. 171 172 173 .. function:: echo() 174 175 Enter echo mode. In echo mode, each character input is echoed to the screen as 176 it is entered. 177 178 179 .. function:: endwin() 180 181 De-initialize the library, and return terminal to normal status. 182 183 184 .. function:: erasechar() 185 186 Return the user's current erase character as a one-byte bytes object. Under Unix operating systems this 187 is a property of the controlling tty of the curses program, and is not set by 188 the curses library itself. 189 190 191 .. function:: filter() 192 193 The :func:`.filter` routine, if used, must be called before :func:`initscr` is 194 called. The effect is that, during those calls, :envvar:`LINES` is set to ``1``; the 195 capabilities ``clear``, ``cup``, ``cud``, ``cud1``, ``cuu1``, ``cuu``, ``vpa`` are disabled; and the ``home`` 196 string is set to the value of ``cr``. The effect is that the cursor is confined to 197 the current line, and so are screen updates. This may be used for enabling 198 character-at-a-time line editing without touching the rest of the screen. 199 200 201 .. function:: flash() 202 203 Flash the screen. That is, change it to reverse-video and then change it back 204 in a short interval. Some people prefer such as 'visible bell' to the audible 205 attention signal produced by :func:`beep`. 206 207 208 .. function:: flushinp() 209 210 Flush all input buffers. This throws away any typeahead that has been typed 211 by the user and has not yet been processed by the program. 212 213 214 .. function:: getmouse() 215 216 After :meth:`~window.getch` returns :const:`KEY_MOUSE` to signal a mouse event, this 217 method should be call to retrieve the queued mouse event, represented as a 218 5-tuple ``(id, x, y, z, bstate)``. *id* is an ID value used to distinguish 219 multiple devices, and *x*, *y*, *z* are the event's coordinates. (*z* is 220 currently unused.) *bstate* is an integer value whose bits will be set to 221 indicate the type of event, and will be the bitwise OR of one or more of the 222 following constants, where *n* is the button number from 1 to 4: 223 :const:`BUTTONn_PRESSED`, :const:`BUTTONn_RELEASED`, :const:`BUTTONn_CLICKED`, 224 :const:`BUTTONn_DOUBLE_CLICKED`, :const:`BUTTONn_TRIPLE_CLICKED`, 225 :const:`BUTTON_SHIFT`, :const:`BUTTON_CTRL`, :const:`BUTTON_ALT`. 226 227 228 .. function:: getsyx() 229 230 Return the current coordinates of the virtual screen cursor as a tuple 231 ``(y, x)``. If :meth:`leaveok <window.leaveok>` is currently ``True``, then return ``(-1, -1)``. 232 233 234 .. function:: getwin(file) 235 236 Read window related data stored in the file by an earlier :func:`putwin` call. 237 The routine then creates and initializes a new window using that data, returning 238 the new window object. 239 240 241 .. function:: has_colors() 242 243 Return ``True`` if the terminal can display colors; otherwise, return ``False``. 244 245 246 .. function:: has_ic() 247 248 Return ``True`` if the terminal has insert- and delete-character capabilities. 249 This function is included for historical reasons only, as all modern software 250 terminal emulators have such capabilities. 251 252 253 .. function:: has_il() 254 255 Return ``True`` if the terminal has insert- and delete-line capabilities, or can 256 simulate them using scrolling regions. This function is included for 257 historical reasons only, as all modern software terminal emulators have such 258 capabilities. 259 260 261 .. function:: has_key(ch) 262 263 Take a key value *ch*, and return ``True`` if the current terminal type recognizes 264 a key with that value. 265 266 267 .. function:: halfdelay(tenths) 268 269 Used for half-delay mode, which is similar to cbreak mode in that characters 270 typed by the user are immediately available to the program. However, after 271 blocking for *tenths* tenths of seconds, raise an exception if nothing has 272 been typed. The value of *tenths* must be a number between ``1`` and ``255``. Use 273 :func:`nocbreak` to leave half-delay mode. 274 275 276 .. function:: init_color(color_number, r, g, b) 277 278 Change the definition of a color, taking the number of the color to be changed 279 followed by three RGB values (for the amounts of red, green, and blue 280 components). The value of *color_number* must be between ``0`` and 281 :const:`COLORS`. Each of *r*, *g*, *b*, must be a value between ``0`` and 282 ``1000``. When :func:`init_color` is used, all occurrences of that color on the 283 screen immediately change to the new definition. This function is a no-op on 284 most terminals; it is active only if :func:`can_change_color` returns ``True``. 285 286 287 .. function:: init_pair(pair_number, fg, bg) 288 289 Change the definition of a color-pair. It takes three arguments: the number of 290 the color-pair to be changed, the foreground color number, and the background 291 color number. The value of *pair_number* must be between ``1`` and 292 ``COLOR_PAIRS - 1`` (the ``0`` color pair is wired to white on black and cannot 293 be changed). The value of *fg* and *bg* arguments must be between ``0`` and 294 :const:`COLORS`. If the color-pair was previously initialized, the screen is 295 refreshed and all occurrences of that color-pair are changed to the new 296 definition. 297 298 299 .. function:: initscr() 300 301 Initialize the library. Return a :ref:`window <curses-window-objects>` object 302 which represents the whole screen. 303 304 .. note:: 305 306 If there is an error opening the terminal, the underlying curses library may 307 cause the interpreter to exit. 308 309 310 .. function:: is_term_resized(nlines, ncols) 311 312 Return ``True`` if :func:`resize_term` would modify the window structure, 313 ``False`` otherwise. 314 315 316 .. function:: isendwin() 317 318 Return ``True`` if :func:`endwin` has been called (that is, the curses library has 319 been deinitialized). 320 321 322 .. function:: keyname(k) 323 324 Return the name of the key numbered *k* as a bytes object. The name of a key generating printable 325 ASCII character is the key's character. The name of a control-key combination 326 is a two-byte bytes object consisting of a caret (``b'^'``) followed by the corresponding 327 printable ASCII character. The name of an alt-key combination (128--255) is a 328 bytes object consisting of the prefix ``b'M-'`` followed by the name of the corresponding 329 ASCII character. 330 331 332 .. function:: killchar() 333 334 Return the user's current line kill character as a one-byte bytes object. Under Unix operating systems 335 this is a property of the controlling tty of the curses program, and is not set 336 by the curses library itself. 337 338 339 .. function:: longname() 340 341 Return a bytes object containing the terminfo long name field describing the current 342 terminal. The maximum length of a verbose description is 128 characters. It is 343 defined only after the call to :func:`initscr`. 344 345 346 .. function:: meta(flag) 347 348 If *flag* is ``True``, allow 8-bit characters to be input. If 349 *flag* is ``False``, allow only 7-bit chars. 350 351 352 .. function:: mouseinterval(interval) 353 354 Set the maximum time in milliseconds that can elapse between press and release 355 events in order for them to be recognized as a click, and return the previous 356 interval value. The default value is 200 msec, or one fifth of a second. 357 358 359 .. function:: mousemask(mousemask) 360 361 Set the mouse events to be reported, and return a tuple ``(availmask, 362 oldmask)``. *availmask* indicates which of the specified mouse events can be 363 reported; on complete failure it returns ``0``. *oldmask* is the previous value of 364 the given window's mouse event mask. If this function is never called, no mouse 365 events are ever reported. 366 367 368 .. function:: napms(ms) 369 370 Sleep for *ms* milliseconds. 371 372 373 .. function:: newpad(nlines, ncols) 374 375 Create and return a pointer to a new pad data structure with the given number 376 of lines and columns. Return a pad as a window object. 377 378 A pad is like a window, except that it is not restricted by the screen size, and 379 is not necessarily associated with a particular part of the screen. Pads can be 380 used when a large window is needed, and only a part of the window will be on the 381 screen at one time. Automatic refreshes of pads (such as from scrolling or 382 echoing of input) do not occur. The :meth:`~window.refresh` and :meth:`~window.noutrefresh` 383 methods of a pad require 6 arguments to specify the part of the pad to be 384 displayed and the location on the screen to be used for the display. The 385 arguments are *pminrow*, *pmincol*, *sminrow*, *smincol*, *smaxrow*, *smaxcol*; the *p* 386 arguments refer to the upper left corner of the pad region to be displayed and 387 the *s* arguments define a clipping box on the screen within which the pad region 388 is to be displayed. 389 390 391 .. function:: newwin(nlines, ncols) 392 newwin(nlines, ncols, begin_y, begin_x) 393 394 Return a new :ref:`window <curses-window-objects>`, whose left-upper corner 395 is at ``(begin_y, begin_x)``, and whose height/width is *nlines*/*ncols*. 396 397 By default, the window will extend from the specified position to the lower 398 right corner of the screen. 399 400 401 .. function:: nl() 402 403 Enter newline mode. This mode translates the return key into newline on input, 404 and translates newline into return and line-feed on output. Newline mode is 405 initially on. 406 407 408 .. function:: nocbreak() 409 410 Leave cbreak mode. Return to normal "cooked" mode with line buffering. 411 412 413 .. function:: noecho() 414 415 Leave echo mode. Echoing of input characters is turned off. 416 417 418 .. function:: nonl() 419 420 Leave newline mode. Disable translation of return into newline on input, and 421 disable low-level translation of newline into newline/return on output (but this 422 does not change the behavior of ``addch('\n')``, which always does the 423 equivalent of return and line feed on the virtual screen). With translation 424 off, curses can sometimes speed up vertical motion a little; also, it will be 425 able to detect the return key on input. 426 427 428 .. function:: noqiflush() 429 430 When the :func:`!noqiflush` routine is used, normal flush of input and output queues 431 associated with the ``INTR``, ``QUIT`` and ``SUSP`` characters will not be done. You may 432 want to call :func:`!noqiflush` in a signal handler if you want output to 433 continue as though the interrupt had not occurred, after the handler exits. 434 435 436 .. function:: noraw() 437 438 Leave raw mode. Return to normal "cooked" mode with line buffering. 439 440 441 .. function:: pair_content(pair_number) 442 443 Return a tuple ``(fg, bg)`` containing the colors for the requested color pair. 444 The value of *pair_number* must be between ``1`` and ``COLOR_PAIRS - 1``. 445 446 447 .. function:: pair_number(attr) 448 449 Return the number of the color-pair set by the attribute value *attr*. 450 :func:`color_pair` is the counterpart to this function. 451 452 453 .. function:: putp(str) 454 455 Equivalent to ``tputs(str, 1, putchar)``; emit the value of a specified 456 terminfo capability for the current terminal. Note that the output of :func:`putp` 457 always goes to standard output. 458 459 460 .. function:: qiflush([flag]) 461 462 If *flag* is ``False``, the effect is the same as calling :func:`noqiflush`. If 463 *flag* is ``True``, or no argument is provided, the queues will be flushed when 464 these control characters are read. 465 466 467 .. function:: raw() 468 469 Enter raw mode. In raw mode, normal line buffering and processing of 470 interrupt, quit, suspend, and flow control keys are turned off; characters are 471 presented to curses input functions one by one. 472 473 474 .. function:: reset_prog_mode() 475 476 Restore the terminal to "program" mode, as previously saved by 477 :func:`def_prog_mode`. 478 479 480 .. function:: reset_shell_mode() 481 482 Restore the terminal to "shell" mode, as previously saved by 483 :func:`def_shell_mode`. 484 485 486 .. function:: resetty() 487 488 Restore the state of the terminal modes to what it was at the last call to 489 :func:`savetty`. 490 491 492 .. function:: resize_term(nlines, ncols) 493 494 Backend function used by :func:`resizeterm`, performing most of the work; 495 when resizing the windows, :func:`resize_term` blank-fills the areas that are 496 extended. The calling application should fill in these areas with 497 appropriate data. The :func:`!resize_term` function attempts to resize all 498 windows. However, due to the calling convention of pads, it is not possible 499 to resize these without additional interaction with the application. 500 501 502 .. function:: resizeterm(nlines, ncols) 503 504 Resize the standard and current windows to the specified dimensions, and 505 adjusts other bookkeeping data used by the curses library that record the 506 window dimensions (in particular the SIGWINCH handler). 507 508 509 .. function:: savetty() 510 511 Save the current state of the terminal modes in a buffer, usable by 512 :func:`resetty`. 513 514 515 .. function:: setsyx(y, x) 516 517 Set the virtual screen cursor to *y*, *x*. If *y* and *x* are both ``-1``, then 518 :meth:`leaveok <window.leaveok>` is set ``True``. 519 520 521 .. function:: setupterm(term=None, fd=-1) 522 523 Initialize the terminal. *term* is a string giving 524 the terminal name, or ``None``; if omitted or ``None``, the value of the 525 :envvar:`TERM` environment variable will be used. *fd* is the 526 file descriptor to which any initialization sequences will be sent; if not 527 supplied or ``-1``, the file descriptor for ``sys.stdout`` will be used. 528 529 530 .. function:: start_color() 531 532 Must be called if the programmer wants to use colors, and before any other color 533 manipulation routine is called. It is good practice to call this routine right 534 after :func:`initscr`. 535 536 :func:`start_color` initializes eight basic colors (black, red, green, yellow, 537 blue, magenta, cyan, and white), and two global variables in the :mod:`curses` 538 module, :const:`COLORS` and :const:`COLOR_PAIRS`, containing the maximum number 539 of colors and color-pairs the terminal can support. It also restores the colors 540 on the terminal to the values they had when the terminal was just turned on. 541 542 543 .. function:: termattrs() 544 545 Return a logical OR of all video attributes supported by the terminal. This 546 information is useful when a curses program needs complete control over the 547 appearance of the screen. 548 549 550 .. function:: termname() 551 552 Return the value of the environment variable :envvar:`TERM`, as a bytes object, 553 truncated to 14 characters. 554 555 556 .. function:: tigetflag(capname) 557 558 Return the value of the Boolean capability corresponding to the terminfo 559 capability name *capname* as an integer. Return the value ``-1`` if *capname* is not a 560 Boolean capability, or ``0`` if it is canceled or absent from the terminal 561 description. 562 563 564 .. function:: tigetnum(capname) 565 566 Return the value of the numeric capability corresponding to the terminfo 567 capability name *capname* as an integer. Return the value ``-2`` if *capname* is not a 568 numeric capability, or ``-1`` if it is canceled or absent from the terminal 569 description. 570 571 572 .. function:: tigetstr(capname) 573 574 Return the value of the string capability corresponding to the terminfo 575 capability name *capname* as a bytes object. Return ``None`` if *capname* 576 is not a terminfo "string capability", or is canceled or absent from the 577 terminal description. 578 579 580 .. function:: tparm(str[, ...]) 581 582 Instantiate the bytes object *str* with the supplied parameters, where *str* should 583 be a parameterized string obtained from the terminfo database. E.g. 584 ``tparm(tigetstr("cup"), 5, 3)`` could result in ``b'\033[6;4H'``, the exact 585 result depending on terminal type. 586 587 588 .. function:: typeahead(fd) 589 590 Specify that the file descriptor *fd* be used for typeahead checking. If *fd* 591 is ``-1``, then no typeahead checking is done. 592 593 The curses library does "line-breakout optimization" by looking for typeahead 594 periodically while updating the screen. If input is found, and it is coming 595 from a tty, the current update is postponed until refresh or doupdate is called 596 again, allowing faster response to commands typed in advance. This function 597 allows specifying a different file descriptor for typeahead checking. 598 599 600 .. function:: unctrl(ch) 601 602 Return a bytes object which is a printable representation of the character *ch*. 603 Control characters are represented as a caret followed by the character, for 604 example as ``b'^C'``. Printing characters are left as they are. 605 606 607 .. function:: ungetch(ch) 608 609 Push *ch* so the next :meth:`~window.getch` will return it. 610 611 .. note:: 612 613 Only one *ch* can be pushed before :meth:`!getch` is called. 614 615 616 .. function:: update_lines_cols() 617 618 Update :envvar:`LINES` and :envvar:`COLS`. Useful for detecting manual screen resize. 619 620 .. versionadded:: 3.5 621 622 623 .. function:: unget_wch(ch) 624 625 Push *ch* so the next :meth:`~window.get_wch` will return it. 626 627 .. note:: 628 629 Only one *ch* can be pushed before :meth:`!get_wch` is called. 630 631 .. versionadded:: 3.3 632 633 634 .. function:: ungetmouse(id, x, y, z, bstate) 635 636 Push a :const:`KEY_MOUSE` event onto the input queue, associating the given 637 state data with it. 638 639 640 .. function:: use_env(flag) 641 642 If used, this function should be called before :func:`initscr` or newterm are 643 called. When *flag* is ``False``, the values of lines and columns specified in the 644 terminfo database will be used, even if environment variables :envvar:`LINES` 645 and :envvar:`COLUMNS` (used by default) are set, or if curses is running in a 646 window (in which case default behavior would be to use the window size if 647 :envvar:`LINES` and :envvar:`COLUMNS` are not set). 648 649 650 .. function:: use_default_colors() 651 652 Allow use of default values for colors on terminals supporting this feature. Use 653 this to support transparency in your application. The default color is assigned 654 to the color number ``-1``. After calling this function, ``init_pair(x, 655 curses.COLOR_RED, -1)`` initializes, for instance, color pair *x* to a red 656 foreground color on the default background. 657 658 659 .. function:: wrapper(func, ...) 660 661 Initialize curses and call another callable object, *func*, which should be the 662 rest of your curses-using application. If the application raises an exception, 663 this function will restore the terminal to a sane state before re-raising the 664 exception and generating a traceback. The callable object *func* is then passed 665 the main window 'stdscr' as its first argument, followed by any other arguments 666 passed to :func:`!wrapper`. Before calling *func*, :func:`!wrapper` turns on 667 cbreak mode, turns off echo, enables the terminal keypad, and initializes colors 668 if the terminal has color support. On exit (whether normally or by exception) 669 it restores cooked mode, turns on echo, and disables the terminal keypad. 670 671 672 .. _curses-window-objects: 673 674 Window Objects 675 -------------- 676 677 Window objects, as returned by :func:`initscr` and :func:`newwin` above, have 678 the following methods and attributes: 679 680 681 .. method:: window.addch(ch[, attr]) 682 window.addch(y, x, ch[, attr]) 683 684 Paint character *ch* at ``(y, x)`` with attributes *attr*, overwriting any 685 character previously painter at that location. By default, the character 686 position and attributes are the current settings for the window object. 687 688 .. note:: 689 690 Writing outside the window, subwindow, or pad raises a :exc:`curses.error`. 691 Attempting to write to the lower right corner of a window, subwindow, 692 or pad will cause an exception to be raised after the character is printed. 693 694 695 .. method:: window.addnstr(str, n[, attr]) 696 window.addnstr(y, x, str, n[, attr]) 697 698 Paint at most *n* characters of the character string *str* at 699 ``(y, x)`` with attributes 700 *attr*, overwriting anything previously on the display. 701 702 703 .. method:: window.addstr(str[, attr]) 704 window.addstr(y, x, str[, attr]) 705 706 Paint the character string *str* at ``(y, x)`` with attributes 707 *attr*, overwriting anything previously on the display. 708 709 .. note:: 710 711 Writing outside the window, subwindow, or pad raises :exc:`curses.error`. 712 Attempting to write to the lower right corner of a window, subwindow, 713 or pad will cause an exception to be raised after the string is printed. 714 715 716 .. method:: window.attroff(attr) 717 718 Remove attribute *attr* from the "background" set applied to all writes to the 719 current window. 720 721 722 .. method:: window.attron(attr) 723 724 Add attribute *attr* from the "background" set applied to all writes to the 725 current window. 726 727 728 .. method:: window.attrset(attr) 729 730 Set the "background" set of attributes to *attr*. This set is initially 731 ``0`` (no attributes). 732 733 734 .. method:: window.bkgd(ch[, attr]) 735 736 Set the background property of the window to the character *ch*, with 737 attributes *attr*. The change is then applied to every character position in 738 that window: 739 740 * The attribute of every character in the window is changed to the new 741 background attribute. 742 743 * Wherever the former background character appears, it is changed to the new 744 background character. 745 746 747 .. method:: window.bkgdset(ch[, attr]) 748 749 Set the window's background. A window's background consists of a character and 750 any combination of attributes. The attribute part of the background is combined 751 (OR'ed) with all non-blank characters that are written into the window. Both 752 the character and attribute parts of the background are combined with the blank 753 characters. The background becomes a property of the character and moves with 754 the character through any scrolling and insert/delete line/character operations. 755 756 757 .. method:: window.border([ls[, rs[, ts[, bs[, tl[, tr[, bl[, br]]]]]]]]) 758 759 Draw a border around the edges of the window. Each parameter specifies the 760 character to use for a specific part of the border; see the table below for more 761 details. 762 763 .. note:: 764 765 A ``0`` value for any parameter will cause the default character to be used for 766 that parameter. Keyword parameters can *not* be used. The defaults are listed 767 in this table: 768 769 +-----------+---------------------+-----------------------+ 770 | Parameter | Description | Default value | 771 +===========+=====================+=======================+ 772 | *ls* | Left side | :const:`ACS_VLINE` | 773 +-----------+---------------------+-----------------------+ 774 | *rs* | Right side | :const:`ACS_VLINE` | 775 +-----------+---------------------+-----------------------+ 776 | *ts* | Top | :const:`ACS_HLINE` | 777 +-----------+---------------------+-----------------------+ 778 | *bs* | Bottom | :const:`ACS_HLINE` | 779 +-----------+---------------------+-----------------------+ 780 | *tl* | Upper-left corner | :const:`ACS_ULCORNER` | 781 +-----------+---------------------+-----------------------+ 782 | *tr* | Upper-right corner | :const:`ACS_URCORNER` | 783 +-----------+---------------------+-----------------------+ 784 | *bl* | Bottom-left corner | :const:`ACS_LLCORNER` | 785 +-----------+---------------------+-----------------------+ 786 | *br* | Bottom-right corner | :const:`ACS_LRCORNER` | 787 +-----------+---------------------+-----------------------+ 788 789 790 .. method:: window.box([vertch, horch]) 791 792 Similar to :meth:`border`, but both *ls* and *rs* are *vertch* and both *ts* and 793 *bs* are *horch*. The default corner characters are always used by this function. 794 795 796 .. method:: window.chgat(attr) 797 window.chgat(num, attr) 798 window.chgat(y, x, attr) 799 window.chgat(y, x, num, attr) 800 801 Set the attributes of *num* characters at the current cursor position, or at 802 position ``(y, x)`` if supplied. If *num* is not given or is ``-1``, 803 the attribute will be set on all the characters to the end of the line. This 804 function moves cursor to position ``(y, x)`` if supplied. The changed line 805 will be touched using the :meth:`touchline` method so that the contents will 806 be redisplayed by the next window refresh. 807 808 809 .. method:: window.clear() 810 811 Like :meth:`erase`, but also cause the whole window to be repainted upon next 812 call to :meth:`refresh`. 813 814 815 .. method:: window.clearok(flag) 816 817 If *flag* is ``True``, the next call to :meth:`refresh` will clear the window 818 completely. 819 820 821 .. method:: window.clrtobot() 822 823 Erase from cursor to the end of the window: all lines below the cursor are 824 deleted, and then the equivalent of :meth:`clrtoeol` is performed. 825 826 827 .. method:: window.clrtoeol() 828 829 Erase from cursor to the end of the line. 830 831 832 .. method:: window.cursyncup() 833 834 Update the current cursor position of all the ancestors of the window to 835 reflect the current cursor position of the window. 836 837 838 .. method:: window.delch([y, x]) 839 840 Delete any character at ``(y, x)``. 841 842 843 .. method:: window.deleteln() 844 845 Delete the line under the cursor. All following lines are moved up by one line. 846 847 848 .. method:: window.derwin(begin_y, begin_x) 849 window.derwin(nlines, ncols, begin_y, begin_x) 850 851 An abbreviation for "derive window", :meth:`derwin` is the same as calling 852 :meth:`subwin`, except that *begin_y* and *begin_x* are relative to the origin 853 of the window, rather than relative to the entire screen. Return a window 854 object for the derived window. 855 856 857 .. method:: window.echochar(ch[, attr]) 858 859 Add character *ch* with attribute *attr*, and immediately call :meth:`refresh` 860 on the window. 861 862 863 .. method:: window.enclose(y, x) 864 865 Test whether the given pair of screen-relative character-cell coordinates are 866 enclosed by the given window, returning ``True`` or ``False``. It is useful for 867 determining what subset of the screen windows enclose the location of a mouse 868 event. 869 870 871 .. attribute:: window.encoding 872 873 Encoding used to encode method arguments (Unicode strings and characters). 874 The encoding attribute is inherited from the parent window when a subwindow 875 is created, for example with :meth:`window.subwin`. By default, the locale 876 encoding is used (see :func:`locale.getpreferredencoding`). 877 878 .. versionadded:: 3.3 879 880 881 .. method:: window.erase() 882 883 Clear the window. 884 885 886 .. method:: window.getbegyx() 887 888 Return a tuple ``(y, x)`` of co-ordinates of upper-left corner. 889 890 891 .. method:: window.getbkgd() 892 893 Return the given window's current background character/attribute pair. 894 895 896 .. method:: window.getch([y, x]) 897 898 Get a character. Note that the integer returned does *not* have to be in ASCII 899 range: function keys, keypad keys and so on are represented by numbers higher 900 than 255. In no-delay mode, return ``-1`` if there is no input, otherwise 901 wait until a key is pressed. 902 903 904 .. method:: window.get_wch([y, x]) 905 906 Get a wide character. Return a character for most keys, or an integer for 907 function keys, keypad keys, and other special keys. 908 In no-delay mode, raise an exception if there is no input. 909 910 .. versionadded:: 3.3 911 912 913 .. method:: window.getkey([y, x]) 914 915 Get a character, returning a string instead of an integer, as :meth:`getch` 916 does. Function keys, keypad keys and other special keys return a multibyte 917 string containing the key name. In no-delay mode, raise an exception if 918 there is no input. 919 920 921 .. method:: window.getmaxyx() 922 923 Return a tuple ``(y, x)`` of the height and width of the window. 924 925 926 .. method:: window.getparyx() 927 928 Return the beginning coordinates of this window relative to its parent window 929 as a tuple ``(y, x)``. Return ``(-1, -1)`` if this window has no 930 parent. 931 932 933 .. method:: window.getstr() 934 window.getstr(n) 935 window.getstr(y, x) 936 window.getstr(y, x, n) 937 938 Read a bytes object from the user, with primitive line editing capacity. 939 940 941 .. method:: window.getyx() 942 943 Return a tuple ``(y, x)`` of current cursor position relative to the window's 944 upper-left corner. 945 946 947 .. method:: window.hline(ch, n) 948 window.hline(y, x, ch, n) 949 950 Display a horizontal line starting at ``(y, x)`` with length *n* consisting of 951 the character *ch*. 952 953 954 .. method:: window.idcok(flag) 955 956 If *flag* is ``False``, curses no longer considers using the hardware insert/delete 957 character feature of the terminal; if *flag* is ``True``, use of character insertion 958 and deletion is enabled. When curses is first initialized, use of character 959 insert/delete is enabled by default. 960 961 962 .. method:: window.idlok(flag) 963 964 If *flag* is ``True``, :mod:`curses` will try and use hardware line 965 editing facilities. Otherwise, line insertion/deletion are disabled. 966 967 968 .. method:: window.immedok(flag) 969 970 If *flag* is ``True``, any change in the window image automatically causes the 971 window to be refreshed; you no longer have to call :meth:`refresh` yourself. 972 However, it may degrade performance considerably, due to repeated calls to 973 wrefresh. This option is disabled by default. 974 975 976 .. method:: window.inch([y, x]) 977 978 Return the character at the given position in the window. The bottom 8 bits are 979 the character proper, and upper bits are the attributes. 980 981 982 .. method:: window.insch(ch[, attr]) 983 window.insch(y, x, ch[, attr]) 984 985 Paint character *ch* at ``(y, x)`` with attributes *attr*, moving the line from 986 position *x* right by one character. 987 988 989 .. method:: window.insdelln(nlines) 990 991 Insert *nlines* lines into the specified window above the current line. The 992 *nlines* bottom lines are lost. For negative *nlines*, delete *nlines* lines 993 starting with the one under the cursor, and move the remaining lines up. The 994 bottom *nlines* lines are cleared. The current cursor position remains the 995 same. 996 997 998 .. method:: window.insertln() 999 1000 Insert a blank line under the cursor. All following lines are moved down by one 1001 line. 1002 1003 1004 .. method:: window.insnstr(str, n[, attr]) 1005 window.insnstr(y, x, str, n[, attr]) 1006 1007 Insert a character string (as many characters as will fit on the line) before 1008 the character under the cursor, up to *n* characters. If *n* is zero or 1009 negative, the entire string is inserted. All characters to the right of the 1010 cursor are shifted right, with the rightmost characters on the line being lost. 1011 The cursor position does not change (after moving to *y*, *x*, if specified). 1012 1013 1014 .. method:: window.insstr(str[, attr]) 1015 window.insstr(y, x, str[, attr]) 1016 1017 Insert a character string (as many characters as will fit on the line) before 1018 the character under the cursor. All characters to the right of the cursor are 1019 shifted right, with the rightmost characters on the line being lost. The cursor 1020 position does not change (after moving to *y*, *x*, if specified). 1021 1022 1023 .. method:: window.instr([n]) 1024 window.instr(y, x[, n]) 1025 1026 Return a bytes object of characters, extracted from the window starting at the 1027 current cursor position, or at *y*, *x* if specified. Attributes are stripped 1028 from the characters. If *n* is specified, :meth:`instr` returns a string 1029 at most *n* characters long (exclusive of the trailing NUL). 1030 1031 1032 .. method:: window.is_linetouched(line) 1033 1034 Return ``True`` if the specified line was modified since the last call to 1035 :meth:`refresh`; otherwise return ``False``. Raise a :exc:`curses.error` 1036 exception if *line* is not valid for the given window. 1037 1038 1039 .. method:: window.is_wintouched() 1040 1041 Return ``True`` if the specified window was modified since the last call to 1042 :meth:`refresh`; otherwise return ``False``. 1043 1044 1045 .. method:: window.keypad(flag) 1046 1047 If *flag* is ``True``, escape sequences generated by some keys (keypad, function keys) 1048 will be interpreted by :mod:`curses`. If *flag* is ``False``, escape sequences will be 1049 left as is in the input stream. 1050 1051 1052 .. method:: window.leaveok(flag) 1053 1054 If *flag* is ``True``, cursor is left where it is on update, instead of being at "cursor 1055 position." This reduces cursor movement where possible. If possible the cursor 1056 will be made invisible. 1057 1058 If *flag* is ``False``, cursor will always be at "cursor position" after an update. 1059 1060 1061 .. method:: window.move(new_y, new_x) 1062 1063 Move cursor to ``(new_y, new_x)``. 1064 1065 1066 .. method:: window.mvderwin(y, x) 1067 1068 Move the window inside its parent window. The screen-relative parameters of 1069 the window are not changed. This routine is used to display different parts of 1070 the parent window at the same physical position on the screen. 1071 1072 1073 .. method:: window.mvwin(new_y, new_x) 1074 1075 Move the window so its upper-left corner is at ``(new_y, new_x)``. 1076 1077 1078 .. method:: window.nodelay(flag) 1079 1080 If *flag* is ``True``, :meth:`getch` will be non-blocking. 1081 1082 1083 .. method:: window.notimeout(flag) 1084 1085 If *flag* is ``True``, escape sequences will not be timed out. 1086 1087 If *flag* is ``False``, after a few milliseconds, an escape sequence will not be 1088 interpreted, and will be left in the input stream as is. 1089 1090 1091 .. method:: window.noutrefresh() 1092 1093 Mark for refresh but wait. This function updates the data structure 1094 representing the desired state of the window, but does not force an update of 1095 the physical screen. To accomplish that, call :func:`doupdate`. 1096 1097 1098 .. method:: window.overlay(destwin[, sminrow, smincol, dminrow, dmincol, dmaxrow, dmaxcol]) 1099 1100 Overlay the window on top of *destwin*. The windows need not be the same size, 1101 only the overlapping region is copied. This copy is non-destructive, which means 1102 that the current background character does not overwrite the old contents of 1103 *destwin*. 1104 1105 To get fine-grained control over the copied region, the second form of 1106 :meth:`overlay` can be used. *sminrow* and *smincol* are the upper-left 1107 coordinates of the source window, and the other variables mark a rectangle in 1108 the destination window. 1109 1110 1111 .. method:: window.overwrite(destwin[, sminrow, smincol, dminrow, dmincol, dmaxrow, dmaxcol]) 1112 1113 Overwrite the window on top of *destwin*. The windows need not be the same size, 1114 in which case only the overlapping region is copied. This copy is destructive, 1115 which means that the current background character overwrites the old contents of 1116 *destwin*. 1117 1118 To get fine-grained control over the copied region, the second form of 1119 :meth:`overwrite` can be used. *sminrow* and *smincol* are the upper-left 1120 coordinates of the source window, the other variables mark a rectangle in the 1121 destination window. 1122 1123 1124 .. method:: window.putwin(file) 1125 1126 Write all data associated with the window into the provided file object. This 1127 information can be later retrieved using the :func:`getwin` function. 1128 1129 1130 .. method:: window.redrawln(beg, num) 1131 1132 Indicate that the *num* screen lines, starting at line *beg*, are corrupted and 1133 should be completely redrawn on the next :meth:`refresh` call. 1134 1135 1136 .. method:: window.redrawwin() 1137 1138 Touch the entire window, causing it to be completely redrawn on the next 1139 :meth:`refresh` call. 1140 1141 1142 .. method:: window.refresh([pminrow, pmincol, sminrow, smincol, smaxrow, smaxcol]) 1143 1144 Update the display immediately (sync actual screen with previous 1145 drawing/deleting methods). 1146 1147 The 6 optional arguments can only be specified when the window is a pad created 1148 with :func:`newpad`. The additional parameters are needed to indicate what part 1149 of the pad and screen are involved. *pminrow* and *pmincol* specify the upper 1150 left-hand corner of the rectangle to be displayed in the pad. *sminrow*, 1151 *smincol*, *smaxrow*, and *smaxcol* specify the edges of the rectangle to be 1152 displayed on the screen. The lower right-hand corner of the rectangle to be 1153 displayed in the pad is calculated from the screen coordinates, since the 1154 rectangles must be the same size. Both rectangles must be entirely contained 1155 within their respective structures. Negative values of *pminrow*, *pmincol*, 1156 *sminrow*, or *smincol* are treated as if they were zero. 1157 1158 1159 .. method:: window.resize(nlines, ncols) 1160 1161 Reallocate storage for a curses window to adjust its dimensions to the 1162 specified values. If either dimension is larger than the current values, the 1163 window's data is filled with blanks that have the current background 1164 rendition (as set by :meth:`bkgdset`) merged into them. 1165 1166 1167 .. method:: window.scroll([lines=1]) 1168 1169 Scroll the screen or scrolling region upward by *lines* lines. 1170 1171 1172 .. method:: window.scrollok(flag) 1173 1174 Control what happens when the cursor of a window is moved off the edge of the 1175 window or scrolling region, either as a result of a newline action on the bottom 1176 line, or typing the last character of the last line. If *flag* is ``False``, the 1177 cursor is left on the bottom line. If *flag* is ``True``, the window is scrolled up 1178 one line. Note that in order to get the physical scrolling effect on the 1179 terminal, it is also necessary to call :meth:`idlok`. 1180 1181 1182 .. method:: window.setscrreg(top, bottom) 1183 1184 Set the scrolling region from line *top* to line *bottom*. All scrolling actions 1185 will take place in this region. 1186 1187 1188 .. method:: window.standend() 1189 1190 Turn off the standout attribute. On some terminals this has the side effect of 1191 turning off all attributes. 1192 1193 1194 .. method:: window.standout() 1195 1196 Turn on attribute *A_STANDOUT*. 1197 1198 1199 .. method:: window.subpad(begin_y, begin_x) 1200 window.subpad(nlines, ncols, begin_y, begin_x) 1201 1202 Return a sub-window, whose upper-left corner is at ``(begin_y, begin_x)``, and 1203 whose width/height is *ncols*/*nlines*. 1204 1205 1206 .. method:: window.subwin(begin_y, begin_x) 1207 window.subwin(nlines, ncols, begin_y, begin_x) 1208 1209 Return a sub-window, whose upper-left corner is at ``(begin_y, begin_x)``, and 1210 whose width/height is *ncols*/*nlines*. 1211 1212 By default, the sub-window will extend from the specified position to the lower 1213 right corner of the window. 1214 1215 1216 .. method:: window.syncdown() 1217 1218 Touch each location in the window that has been touched in any of its ancestor 1219 windows. This routine is called by :meth:`refresh`, so it should almost never 1220 be necessary to call it manually. 1221 1222 1223 .. method:: window.syncok(flag) 1224 1225 If *flag* is ``True``, then :meth:`syncup` is called automatically 1226 whenever there is a change in the window. 1227 1228 1229 .. method:: window.syncup() 1230 1231 Touch all locations in ancestors of the window that have been changed in the 1232 window. 1233 1234 1235 .. method:: window.timeout(delay) 1236 1237 Set blocking or non-blocking read behavior for the window. If *delay* is 1238 negative, blocking read is used (which will wait indefinitely for input). If 1239 *delay* is zero, then non-blocking read is used, and :meth:`getch` will 1240 return ``-1`` if no input is waiting. If *delay* is positive, then 1241 :meth:`getch` will block for *delay* milliseconds, and return ``-1`` if there is 1242 still no input at the end of that time. 1243 1244 1245 .. method:: window.touchline(start, count[, changed]) 1246 1247 Pretend *count* lines have been changed, starting with line *start*. If 1248 *changed* is supplied, it specifies whether the affected lines are marked as 1249 having been changed (*changed*\ ``=True``) or unchanged (*changed*\ ``=False``). 1250 1251 1252 .. method:: window.touchwin() 1253 1254 Pretend the whole window has been changed, for purposes of drawing 1255 optimizations. 1256 1257 1258 .. method:: window.untouchwin() 1259 1260 Mark all lines in the window as unchanged since the last call to 1261 :meth:`refresh`. 1262 1263 1264 .. method:: window.vline(ch, n) 1265 window.vline(y, x, ch, n) 1266 1267 Display a vertical line starting at ``(y, x)`` with length *n* consisting of the 1268 character *ch*. 1269 1270 1271 Constants 1272 --------- 1273 1274 The :mod:`curses` module defines the following data members: 1275 1276 1277 .. data:: ERR 1278 1279 Some curses routines that return an integer, such as :func:`getch`, return 1280 :const:`ERR` upon failure. 1281 1282 1283 .. data:: OK 1284 1285 Some curses routines that return an integer, such as :func:`napms`, return 1286 :const:`OK` upon success. 1287 1288 1289 .. data:: version 1290 1291 A bytes object representing the current version of the module. Also available as 1292 :const:`__version__`. 1293 1294 Some constants are available to specify character cell attributes. 1295 The exact constants available are system dependent. 1296 1297 +------------------+-------------------------------+ 1298 | Attribute | Meaning | 1299 +==================+===============================+ 1300 | ``A_ALTCHARSET`` | Alternate character set mode | 1301 +------------------+-------------------------------+ 1302 | ``A_BLINK`` | Blink mode | 1303 +------------------+-------------------------------+ 1304 | ``A_BOLD`` | Bold mode | 1305 +------------------+-------------------------------+ 1306 | ``A_DIM`` | Dim mode | 1307 +------------------+-------------------------------+ 1308 | ``A_INVIS`` | Invisible or blank mode | 1309 +------------------+-------------------------------+ 1310 | ``A_ITALIC`` | Italic mode | 1311 +------------------+-------------------------------+ 1312 | ``A_NORMAL`` | Normal attribute | 1313 +------------------+-------------------------------+ 1314 | ``A_PROTECT`` | Protected mode | 1315 +------------------+-------------------------------+ 1316 | ``A_REVERSE`` | Reverse background and | 1317 | | foreground colors | 1318 +------------------+-------------------------------+ 1319 | ``A_STANDOUT`` | Standout mode | 1320 +------------------+-------------------------------+ 1321 | ``A_UNDERLINE`` | Underline mode | 1322 +------------------+-------------------------------+ 1323 | ``A_HORIZONTAL`` | Horizontal highlight | 1324 +------------------+-------------------------------+ 1325 | ``A_LEFT`` | Left highlight | 1326 +------------------+-------------------------------+ 1327 | ``A_LOW`` | Low highlight | 1328 +------------------+-------------------------------+ 1329 | ``A_RIGHT`` | Right highlight | 1330 +------------------+-------------------------------+ 1331 | ``A_TOP`` | Top highlight | 1332 +------------------+-------------------------------+ 1333 | ``A_VERTICAL`` | Vertical highlight | 1334 +------------------+-------------------------------+ 1335 | ``A_CHARTEXT`` | Bit-mask to extract a | 1336 | | character | 1337 +------------------+-------------------------------+ 1338 1339 .. versionadded:: 3.7 1340 ``A_ITALIC`` was added. 1341 1342 Several constants are available to extract corresponding attributes returned 1343 by some methods. 1344 1345 +------------------+-------------------------------+ 1346 | Bit-mask | Meaning | 1347 +==================+===============================+ 1348 | ``A_ATTRIBUTES`` | Bit-mask to extract | 1349 | | attributes | 1350 +------------------+-------------------------------+ 1351 | ``A_CHARTEXT`` | Bit-mask to extract a | 1352 | | character | 1353 +------------------+-------------------------------+ 1354 | ``A_COLOR`` | Bit-mask to extract | 1355 | | color-pair field information | 1356 +------------------+-------------------------------+ 1357 1358 Keys are referred to by integer constants with names starting with ``KEY_``. 1359 The exact keycaps available are system dependent. 1360 1361 .. XXX this table is far too large! should it be alphabetized? 1362 1363 +-------------------+--------------------------------------------+ 1364 | Key constant | Key | 1365 +===================+============================================+ 1366 | ``KEY_MIN`` | Minimum key value | 1367 +-------------------+--------------------------------------------+ 1368 | ``KEY_BREAK`` | Break key (unreliable) | 1369 +-------------------+--------------------------------------------+ 1370 | ``KEY_DOWN`` | Down-arrow | 1371 +-------------------+--------------------------------------------+ 1372 | ``KEY_UP`` | Up-arrow | 1373 +-------------------+--------------------------------------------+ 1374 | ``KEY_LEFT`` | Left-arrow | 1375 +-------------------+--------------------------------------------+ 1376 | ``KEY_RIGHT`` | Right-arrow | 1377 +-------------------+--------------------------------------------+ 1378 | ``KEY_HOME`` | Home key (upward+left arrow) | 1379 +-------------------+--------------------------------------------+ 1380 | ``KEY_BACKSPACE`` | Backspace (unreliable) | 1381 +-------------------+--------------------------------------------+ 1382 | ``KEY_F0`` | Function keys. Up to 64 function keys are | 1383 | | supported. | 1384 +-------------------+--------------------------------------------+ 1385 | ``KEY_Fn`` | Value of function key *n* | 1386 +-------------------+--------------------------------------------+ 1387 | ``KEY_DL`` | Delete line | 1388 +-------------------+--------------------------------------------+ 1389 | ``KEY_IL`` | Insert line | 1390 +-------------------+--------------------------------------------+ 1391 | ``KEY_DC`` | Delete character | 1392 +-------------------+--------------------------------------------+ 1393 | ``KEY_IC`` | Insert char or enter insert mode | 1394 +-------------------+--------------------------------------------+ 1395 | ``KEY_EIC`` | Exit insert char mode | 1396 +-------------------+--------------------------------------------+ 1397 | ``KEY_CLEAR`` | Clear screen | 1398 +-------------------+--------------------------------------------+ 1399 | ``KEY_EOS`` | Clear to end of screen | 1400 +-------------------+--------------------------------------------+ 1401 | ``KEY_EOL`` | Clear to end of line | 1402 +-------------------+--------------------------------------------+ 1403 | ``KEY_SF`` | Scroll 1 line forward | 1404 +-------------------+--------------------------------------------+ 1405 | ``KEY_SR`` | Scroll 1 line backward (reverse) | 1406 +-------------------+--------------------------------------------+ 1407 | ``KEY_NPAGE`` | Next page | 1408 +-------------------+--------------------------------------------+ 1409 | ``KEY_PPAGE`` | Previous page | 1410 +-------------------+--------------------------------------------+ 1411 | ``KEY_STAB`` | Set tab | 1412 +-------------------+--------------------------------------------+ 1413 | ``KEY_CTAB`` | Clear tab | 1414 +-------------------+--------------------------------------------+ 1415 | ``KEY_CATAB`` | Clear all tabs | 1416 +-------------------+--------------------------------------------+ 1417 | ``KEY_ENTER`` | Enter or send (unreliable) | 1418 +-------------------+--------------------------------------------+ 1419 | ``KEY_SRESET`` | Soft (partial) reset (unreliable) | 1420 +-------------------+--------------------------------------------+ 1421 | ``KEY_RESET`` | Reset or hard reset (unreliable) | 1422 +-------------------+--------------------------------------------+ 1423 | ``KEY_PRINT`` | Print | 1424 +-------------------+--------------------------------------------+ 1425 | ``KEY_LL`` | Home down or bottom (lower left) | 1426 +-------------------+--------------------------------------------+ 1427 | ``KEY_A1`` | Upper left of keypad | 1428 +-------------------+--------------------------------------------+ 1429 | ``KEY_A3`` | Upper right of keypad | 1430 +-------------------+--------------------------------------------+ 1431 | ``KEY_B2`` | Center of keypad | 1432 +-------------------+--------------------------------------------+ 1433 | ``KEY_C1`` | Lower left of keypad | 1434 +-------------------+--------------------------------------------+ 1435 | ``KEY_C3`` | Lower right of keypad | 1436 +-------------------+--------------------------------------------+ 1437 | ``KEY_BTAB`` | Back tab | 1438 +-------------------+--------------------------------------------+ 1439 | ``KEY_BEG`` | Beg (beginning) | 1440 +-------------------+--------------------------------------------+ 1441 | ``KEY_CANCEL`` | Cancel | 1442 +-------------------+--------------------------------------------+ 1443 | ``KEY_CLOSE`` | Close | 1444 +-------------------+--------------------------------------------+ 1445 | ``KEY_COMMAND`` | Cmd (command) | 1446 +-------------------+--------------------------------------------+ 1447 | ``KEY_COPY`` | Copy | 1448 +-------------------+--------------------------------------------+ 1449 | ``KEY_CREATE`` | Create | 1450 +-------------------+--------------------------------------------+ 1451 | ``KEY_END`` | End | 1452 +-------------------+--------------------------------------------+ 1453 | ``KEY_EXIT`` | Exit | 1454 +-------------------+--------------------------------------------+ 1455 | ``KEY_FIND`` | Find | 1456 +-------------------+--------------------------------------------+ 1457 | ``KEY_HELP`` | Help | 1458 +-------------------+--------------------------------------------+ 1459 | ``KEY_MARK`` | Mark | 1460 +-------------------+--------------------------------------------+ 1461 | ``KEY_MESSAGE`` | Message | 1462 +-------------------+--------------------------------------------+ 1463 | ``KEY_MOVE`` | Move | 1464 +-------------------+--------------------------------------------+ 1465 | ``KEY_NEXT`` | Next | 1466 +-------------------+--------------------------------------------+ 1467 | ``KEY_OPEN`` | Open | 1468 +-------------------+--------------------------------------------+ 1469 | ``KEY_OPTIONS`` | Options | 1470 +-------------------+--------------------------------------------+ 1471 | ``KEY_PREVIOUS`` | Prev (previous) | 1472 +-------------------+--------------------------------------------+ 1473 | ``KEY_REDO`` | Redo | 1474 +-------------------+--------------------------------------------+ 1475 | ``KEY_REFERENCE`` | Ref (reference) | 1476 +-------------------+--------------------------------------------+ 1477 | ``KEY_REFRESH`` | Refresh | 1478 +-------------------+--------------------------------------------+ 1479 | ``KEY_REPLACE`` | Replace | 1480 +-------------------+--------------------------------------------+ 1481 | ``KEY_RESTART`` | Restart | 1482 +-------------------+--------------------------------------------+ 1483 | ``KEY_RESUME`` | Resume | 1484 +-------------------+--------------------------------------------+ 1485 | ``KEY_SAVE`` | Save | 1486 +-------------------+--------------------------------------------+ 1487 | ``KEY_SBEG`` | Shifted Beg (beginning) | 1488 +-------------------+--------------------------------------------+ 1489 | ``KEY_SCANCEL`` | Shifted Cancel | 1490 +-------------------+--------------------------------------------+ 1491 | ``KEY_SCOMMAND`` | Shifted Command | 1492 +-------------------+--------------------------------------------+ 1493 | ``KEY_SCOPY`` | Shifted Copy | 1494 +-------------------+--------------------------------------------+ 1495 | ``KEY_SCREATE`` | Shifted Create | 1496 +-------------------+--------------------------------------------+ 1497 | ``KEY_SDC`` | Shifted Delete char | 1498 +-------------------+--------------------------------------------+ 1499 | ``KEY_SDL`` | Shifted Delete line | 1500 +-------------------+--------------------------------------------+ 1501 | ``KEY_SELECT`` | Select | 1502 +-------------------+--------------------------------------------+ 1503 | ``KEY_SEND`` | Shifted End | 1504 +-------------------+--------------------------------------------+ 1505 | ``KEY_SEOL`` | Shifted Clear line | 1506 +-------------------+--------------------------------------------+ 1507 | ``KEY_SEXIT`` | Shifted Exit | 1508 +-------------------+--------------------------------------------+ 1509 | ``KEY_SFIND`` | Shifted Find | 1510 +-------------------+--------------------------------------------+ 1511 | ``KEY_SHELP`` | Shifted Help | 1512 +-------------------+--------------------------------------------+ 1513 | ``KEY_SHOME`` | Shifted Home | 1514 +-------------------+--------------------------------------------+ 1515 | ``KEY_SIC`` | Shifted Input | 1516 +-------------------+--------------------------------------------+ 1517 | ``KEY_SLEFT`` | Shifted Left arrow | 1518 +-------------------+--------------------------------------------+ 1519 | ``KEY_SMESSAGE`` | Shifted Message | 1520 +-------------------+--------------------------------------------+ 1521 | ``KEY_SMOVE`` | Shifted Move | 1522 +-------------------+--------------------------------------------+ 1523 | ``KEY_SNEXT`` | Shifted Next | 1524 +-------------------+--------------------------------------------+ 1525 | ``KEY_SOPTIONS`` | Shifted Options | 1526 +-------------------+--------------------------------------------+ 1527 | ``KEY_SPREVIOUS`` | Shifted Prev | 1528 +-------------------+--------------------------------------------+ 1529 | ``KEY_SPRINT`` | Shifted Print | 1530 +-------------------+--------------------------------------------+ 1531 | ``KEY_SREDO`` | Shifted Redo | 1532 +-------------------+--------------------------------------------+ 1533 | ``KEY_SREPLACE`` | Shifted Replace | 1534 +-------------------+--------------------------------------------+ 1535 | ``KEY_SRIGHT`` | Shifted Right arrow | 1536 +-------------------+--------------------------------------------+ 1537 | ``KEY_SRSUME`` | Shifted Resume | 1538 +-------------------+--------------------------------------------+ 1539 | ``KEY_SSAVE`` | Shifted Save | 1540 +-------------------+--------------------------------------------+ 1541 | ``KEY_SSUSPEND`` | Shifted Suspend | 1542 +-------------------+--------------------------------------------+ 1543 | ``KEY_SUNDO`` | Shifted Undo | 1544 +-------------------+--------------------------------------------+ 1545 | ``KEY_SUSPEND`` | Suspend | 1546 +-------------------+--------------------------------------------+ 1547 | ``KEY_UNDO`` | Undo | 1548 +-------------------+--------------------------------------------+ 1549 | ``KEY_MOUSE`` | Mouse event has occurred | 1550 +-------------------+--------------------------------------------+ 1551 | ``KEY_RESIZE`` | Terminal resize event | 1552 +-------------------+--------------------------------------------+ 1553 | ``KEY_MAX`` | Maximum key value | 1554 +-------------------+--------------------------------------------+ 1555 1556 On VT100s and their software emulations, such as X terminal emulators, there are 1557 normally at least four function keys (:const:`KEY_F1`, :const:`KEY_F2`, 1558 :const:`KEY_F3`, :const:`KEY_F4`) available, and the arrow keys mapped to 1559 :const:`KEY_UP`, :const:`KEY_DOWN`, :const:`KEY_LEFT` and :const:`KEY_RIGHT` in 1560 the obvious way. If your machine has a PC keyboard, it is safe to expect arrow 1561 keys and twelve function keys (older PC keyboards may have only ten function 1562 keys); also, the following keypad mappings are standard: 1563 1564 +------------------+-----------+ 1565 | Keycap | Constant | 1566 +==================+===========+ 1567 | :kbd:`Insert` | KEY_IC | 1568 +------------------+-----------+ 1569 | :kbd:`Delete` | KEY_DC | 1570 +------------------+-----------+ 1571 | :kbd:`Home` | KEY_HOME | 1572 +------------------+-----------+ 1573 | :kbd:`End` | KEY_END | 1574 +------------------+-----------+ 1575 | :kbd:`Page Up` | KEY_PPAGE | 1576 +------------------+-----------+ 1577 | :kbd:`Page Down` | KEY_NPAGE | 1578 +------------------+-----------+ 1579 1580 The following table lists characters from the alternate character set. These are 1581 inherited from the VT100 terminal, and will generally be available on software 1582 emulations such as X terminals. When there is no graphic available, curses 1583 falls back on a crude printable ASCII approximation. 1584 1585 .. note:: 1586 1587 These are available only after :func:`initscr` has been called. 1588 1589 +------------------+------------------------------------------+ 1590 | ACS code | Meaning | 1591 +==================+==========================================+ 1592 | ``ACS_BBSS`` | alternate name for upper right corner | 1593 +------------------+------------------------------------------+ 1594 | ``ACS_BLOCK`` | solid square block | 1595 +------------------+------------------------------------------+ 1596 | ``ACS_BOARD`` | board of squares | 1597 +------------------+------------------------------------------+ 1598 | ``ACS_BSBS`` | alternate name for horizontal line | 1599 +------------------+------------------------------------------+ 1600 | ``ACS_BSSB`` | alternate name for upper left corner | 1601 +------------------+------------------------------------------+ 1602 | ``ACS_BSSS`` | alternate name for top tee | 1603 +------------------+------------------------------------------+ 1604 | ``ACS_BTEE`` | bottom tee | 1605 +------------------+------------------------------------------+ 1606 | ``ACS_BULLET`` | bullet | 1607 +------------------+------------------------------------------+ 1608 | ``ACS_CKBOARD`` | checker board (stipple) | 1609 +------------------+------------------------------------------+ 1610 | ``ACS_DARROW`` | arrow pointing down | 1611 +------------------+------------------------------------------+ 1612 | ``ACS_DEGREE`` | degree symbol | 1613 +------------------+------------------------------------------+ 1614 | ``ACS_DIAMOND`` | diamond | 1615 +------------------+------------------------------------------+ 1616 | ``ACS_GEQUAL`` | greater-than-or-equal-to | 1617 +------------------+------------------------------------------+ 1618 | ``ACS_HLINE`` | horizontal line | 1619 +------------------+------------------------------------------+ 1620 | ``ACS_LANTERN`` | lantern symbol | 1621 +------------------+------------------------------------------+ 1622 | ``ACS_LARROW`` | left arrow | 1623 +------------------+------------------------------------------+ 1624 | ``ACS_LEQUAL`` | less-than-or-equal-to | 1625 +------------------+------------------------------------------+ 1626 | ``ACS_LLCORNER`` | lower left-hand corner | 1627 +------------------+------------------------------------------+ 1628 | ``ACS_LRCORNER`` | lower right-hand corner | 1629 +------------------+------------------------------------------+ 1630 | ``ACS_LTEE`` | left tee | 1631 +------------------+------------------------------------------+ 1632 | ``ACS_NEQUAL`` | not-equal sign | 1633 +------------------+------------------------------------------+ 1634 | ``ACS_PI`` | letter pi | 1635 +------------------+------------------------------------------+ 1636 | ``ACS_PLMINUS`` | plus-or-minus sign | 1637 +------------------+------------------------------------------+ 1638 | ``ACS_PLUS`` | big plus sign | 1639 +------------------+------------------------------------------+ 1640 | ``ACS_RARROW`` | right arrow | 1641 +------------------+------------------------------------------+ 1642 | ``ACS_RTEE`` | right tee | 1643 +------------------+------------------------------------------+ 1644 | ``ACS_S1`` | scan line 1 | 1645 +------------------+------------------------------------------+ 1646 | ``ACS_S3`` | scan line 3 | 1647 +------------------+------------------------------------------+ 1648 | ``ACS_S7`` | scan line 7 | 1649 +------------------+------------------------------------------+ 1650 | ``ACS_S9`` | scan line 9 | 1651 +------------------+------------------------------------------+ 1652 | ``ACS_SBBS`` | alternate name for lower right corner | 1653 +------------------+------------------------------------------+ 1654 | ``ACS_SBSB`` | alternate name for vertical line | 1655 +------------------+------------------------------------------+ 1656 | ``ACS_SBSS`` | alternate name for right tee | 1657 +------------------+------------------------------------------+ 1658 | ``ACS_SSBB`` | alternate name for lower left corner | 1659 +------------------+------------------------------------------+ 1660 | ``ACS_SSBS`` | alternate name for bottom tee | 1661 +------------------+------------------------------------------+ 1662 | ``ACS_SSSB`` | alternate name for left tee | 1663 +------------------+------------------------------------------+ 1664 | ``ACS_SSSS`` | alternate name for crossover or big plus | 1665 +------------------+------------------------------------------+ 1666 | ``ACS_STERLING`` | pound sterling | 1667 +------------------+------------------------------------------+ 1668 | ``ACS_TTEE`` | top tee | 1669 +------------------+------------------------------------------+ 1670 | ``ACS_UARROW`` | up arrow | 1671 +------------------+------------------------------------------+ 1672 | ``ACS_ULCORNER`` | upper left corner | 1673 +------------------+------------------------------------------+ 1674 | ``ACS_URCORNER`` | upper right corner | 1675 +------------------+------------------------------------------+ 1676 | ``ACS_VLINE`` | vertical line | 1677 +------------------+------------------------------------------+ 1678 1679 The following table lists the predefined colors: 1680 1681 +-------------------+----------------------------+ 1682 | Constant | Color | 1683 +===================+============================+ 1684 | ``COLOR_BLACK`` | Black | 1685 +-------------------+----------------------------+ 1686 | ``COLOR_BLUE`` | Blue | 1687 +-------------------+----------------------------+ 1688 | ``COLOR_CYAN`` | Cyan (light greenish blue) | 1689 +-------------------+----------------------------+ 1690 | ``COLOR_GREEN`` | Green | 1691 +-------------------+----------------------------+ 1692 | ``COLOR_MAGENTA`` | Magenta (purplish red) | 1693 +-------------------+----------------------------+ 1694 | ``COLOR_RED`` | Red | 1695 +-------------------+----------------------------+ 1696 | ``COLOR_WHITE`` | White | 1697 +-------------------+----------------------------+ 1698 | ``COLOR_YELLOW`` | Yellow | 1699 +-------------------+----------------------------+ 1700 1701 1702 :mod:`curses.textpad` --- Text input widget for curses programs 1703 =============================================================== 1704 1705 .. module:: curses.textpad 1706 :synopsis: Emacs-like input editing in a curses window. 1707 .. moduleauthor:: Eric Raymond <esr (a] thyrsus.com> 1708 .. sectionauthor:: Eric Raymond <esr (a] thyrsus.com> 1709 1710 1711 The :mod:`curses.textpad` module provides a :class:`Textbox` class that handles 1712 elementary text editing in a curses window, supporting a set of keybindings 1713 resembling those of Emacs (thus, also of Netscape Navigator, BBedit 6.x, 1714 FrameMaker, and many other programs). The module also provides a 1715 rectangle-drawing function useful for framing text boxes or for other purposes. 1716 1717 The module :mod:`curses.textpad` defines the following function: 1718 1719 1720 .. function:: rectangle(win, uly, ulx, lry, lrx) 1721 1722 Draw a rectangle. The first argument must be a window object; the remaining 1723 arguments are coordinates relative to that window. The second and third 1724 arguments are the y and x coordinates of the upper left hand corner of the 1725 rectangle to be drawn; the fourth and fifth arguments are the y and x 1726 coordinates of the lower right hand corner. The rectangle will be drawn using 1727 VT100/IBM PC forms characters on terminals that make this possible (including 1728 xterm and most other software terminal emulators). Otherwise it will be drawn 1729 with ASCII dashes, vertical bars, and plus signs. 1730 1731 1732 .. _curses-textpad-objects: 1733 1734 Textbox objects 1735 --------------- 1736 1737 You can instantiate a :class:`Textbox` object as follows: 1738 1739 1740 .. class:: Textbox(win) 1741 1742 Return a textbox widget object. The *win* argument should be a curses 1743 :ref:`window <curses-window-objects>` object in which the textbox is to 1744 be contained. The edit cursor of the textbox is initially located at the 1745 upper left hand corner of the containing window, with coordinates ``(0, 0)``. 1746 The instance's :attr:`stripspaces` flag is initially on. 1747 1748 :class:`Textbox` objects have the following methods: 1749 1750 1751 .. method:: edit([validator]) 1752 1753 This is the entry point you will normally use. It accepts editing 1754 keystrokes until one of the termination keystrokes is entered. If 1755 *validator* is supplied, it must be a function. It will be called for 1756 each keystroke entered with the keystroke as a parameter; command dispatch 1757 is done on the result. This method returns the window contents as a 1758 string; whether blanks in the window are included is affected by the 1759 :attr:`stripspaces` attribute. 1760 1761 1762 .. method:: do_command(ch) 1763 1764 Process a single command keystroke. Here are the supported special 1765 keystrokes: 1766 1767 +------------------+-------------------------------------------+ 1768 | Keystroke | Action | 1769 +==================+===========================================+ 1770 | :kbd:`Control-A` | Go to left edge of window. | 1771 +------------------+-------------------------------------------+ 1772 | :kbd:`Control-B` | Cursor left, wrapping to previous line if | 1773 | | appropriate. | 1774 +------------------+-------------------------------------------+ 1775 | :kbd:`Control-D` | Delete character under cursor. | 1776 +------------------+-------------------------------------------+ 1777 | :kbd:`Control-E` | Go to right edge (stripspaces off) or end | 1778 | | of line (stripspaces on). | 1779 +------------------+-------------------------------------------+ 1780 | :kbd:`Control-F` | Cursor right, wrapping to next line when | 1781 | | appropriate. | 1782 +------------------+-------------------------------------------+ 1783 | :kbd:`Control-G` | Terminate, returning the window contents. | 1784 +------------------+-------------------------------------------+ 1785 | :kbd:`Control-H` | Delete character backward. | 1786 +------------------+-------------------------------------------+ 1787 | :kbd:`Control-J` | Terminate if the window is 1 line, | 1788 | | otherwise insert newline. | 1789 +------------------+-------------------------------------------+ 1790 | :kbd:`Control-K` | If line is blank, delete it, otherwise | 1791 | | clear to end of line. | 1792 +------------------+-------------------------------------------+ 1793 | :kbd:`Control-L` | Refresh screen. | 1794 +------------------+-------------------------------------------+ 1795 | :kbd:`Control-N` | Cursor down; move down one line. | 1796 +------------------+-------------------------------------------+ 1797 | :kbd:`Control-O` | Insert a blank line at cursor location. | 1798 +------------------+-------------------------------------------+ 1799 | :kbd:`Control-P` | Cursor up; move up one line. | 1800 +------------------+-------------------------------------------+ 1801 1802 Move operations do nothing if the cursor is at an edge where the movement 1803 is not possible. The following synonyms are supported where possible: 1804 1805 +------------------------+------------------+ 1806 | Constant | Keystroke | 1807 +========================+==================+ 1808 | :const:`KEY_LEFT` | :kbd:`Control-B` | 1809 +------------------------+------------------+ 1810 | :const:`KEY_RIGHT` | :kbd:`Control-F` | 1811 +------------------------+------------------+ 1812 | :const:`KEY_UP` | :kbd:`Control-P` | 1813 +------------------------+------------------+ 1814 | :const:`KEY_DOWN` | :kbd:`Control-N` | 1815 +------------------------+------------------+ 1816 | :const:`KEY_BACKSPACE` | :kbd:`Control-h` | 1817 +------------------------+------------------+ 1818 1819 All other keystrokes are treated as a command to insert the given 1820 character and move right (with line wrapping). 1821 1822 1823 .. method:: gather() 1824 1825 Return the window contents as a string; whether blanks in the 1826 window are included is affected by the :attr:`stripspaces` member. 1827 1828 1829 .. attribute:: stripspaces 1830 1831 This attribute is a flag which controls the interpretation of blanks in 1832 the window. When it is on, trailing blanks on each line are ignored; any 1833 cursor motion that would land the cursor on a trailing blank goes to the 1834 end of that line instead, and trailing blanks are stripped when the window 1835 contents are gathered. 1836