API reference¶
pyte.streams¶
This module provides three stream implementations with different features; for starters, here’s a quick example of how streams are typically used:
>>> import pyte
>>> screen = pyte.Screen(80, 24)
>>> stream = pyte.Stream(screen)
>>> stream.feed("[5B") # Move the cursor down 5 rows.
>>> screen.cursor.y
5
copyright: |
|
---|---|
copyright: | (c) 2012-2017 by pyte authors and contributors, see AUTHORS for details. |
license: | LGPL, see LICENSE for more details. |
pyte.Stream¶
-
class
pyte.
Stream
(screen=None, strict=True)[source]¶ A stream is a state machine that parses a stream of bytes and dispatches events based on what it sees.
Parameters: - screen (pyte.screens.Screen) – a screen to dispatch events to.
- strict (bool) – check if a given screen implements all required events.
Note
Stream only accepts text as input, but if for some reason you need to feed it with bytes, consider using
ByteStream
instead.See also
- man console_codes
- For details on console codes listed bellow in
basic
,escape
,csi
,sharp
.
pyte.screens¶
This module provides classes for terminal screens, currently it contains three screens with different features:
Screen
– base screen implementation, which handles all the core escape sequences, recognized byStream
.- If you need a screen to keep track of the changed lines
(which you probably do need) – use
DiffScreen
. - If you also want a screen to collect history and allow
pagination –
pyte.screen.HistoryScreen
is here for ya ;)
Note
It would be nice to split those features into mixin classes, rather than subclasses, but it’s not obvious how to do – feel free to submit a pull request.
copyright: |
|
---|---|
copyright: | (c) 2012-2017 by pyte authors and contributors, see AUTHORS for details. |
license: | LGPL, see LICENSE for more details. |
pyte.screens.Screen¶
-
class
pyte.screens.
Cursor
(x, y, attrs=Char(data=' ', fg='default', bg='default', bold=False, italics=False, underscore=False, strikethrough=False, reverse=False, blink=False))[source]¶ Screen cursor.
Parameters: - x (int) – 0-based horizontal cursor position.
- y (int) – 0-based vertical cursor position.
- attrs (pyte.screens.Char) – cursor attributes (see
select_graphic_rendition()
for details).
-
class
pyte.screens.
Char
[source]¶ A single styled on-screen character.
Parameters: - data (str) – unicode character. Invariant:
len(data) == 1
. - fg (str) – foreground colour. Defaults to
"default"
. - bg (str) – background colour. Defaults to
"default"
. - bold (bool) – flag for rendering the character using bold font.
Defaults to
False
. - italics (bool) – flag for rendering the character using italic font.
Defaults to
False
. - underscore (bool) – flag for rendering the character underlined.
Defaults to
False
. - strikethrough (bool) – flag for rendering the character with a
strike-through line. Defaults to
False
. - reverse (bool) – flag for swapping foreground and background colours
during rendering. Defaults to
False
. - blink (bool) – flag for rendering the character blinked. Defaults to
False
.
- data (str) – unicode character. Invariant:
-
class
pyte.screens.
Screen
(columns, lines)[source]¶ A screen is an in-memory matrix of characters that represents the screen display of the terminal. It can be instantiated on its own and given explicit commands, or it can be attached to a stream and will respond to events.
-
dirty
¶ A set of line numbers, which should be re-drawn. The user is responsible for clearing this set when changes have been applied.
>>> screen = Screen(80, 24) >>> screen.dirty.clear() >>> screen.draw("!") >>> list(screen.dirty) [0]
New in version 0.7.0.
-
margins
¶ Margins determine which screen lines move during scrolling (see
index()
andreverse_index()
). Characters added outside the scrolling region do not make the screen to scroll.The value is
None
if margins are set to screen boundaries, otherwise – a pair 0-based top and bottom line indices.
-
charset
¶ Current charset number; can be either
0
or1
for G0 and G1 respectively, note that G0 is activated by default.
Note
According to
ECMA-48
standard, lines and columns are 1-indexed, so, for instanceESC [ 10;10 f
really means – move cursor to position (9, 9) in the display matrix.Changed in version 0.4.7.
Warning
LNM
is reset by default, to match VT220 specification. Unfortunatelly this makespyte
failvttest
for cursor movement.Changed in version 0.4.8.
Warning
If DECAWM mode is set than a cursor will be wrapped to the beginning of the next line, which is the behaviour described in
man console_codes
.See also
Standard ECMA-48, Section 6.1.1 for a description of the presentational component, implemented by
Screen
.-
default_char
¶ An empty character with default foreground and background colors.
-
display
¶ A
list()
of screen lines as unicode strings.
-
reset
()[source]¶ Reset the terminal to its initial state.
- Scrolling margins are reset to screen boundaries.
- Cursor is moved to home location –
(0, 0)
and its attributes are set to defaults (seedefault_char
). - Screen is cleared – each character is reset to
default_char
. - Tabstops are reset to “every eight columns”.
- All lines are marked as
dirty
.
Note
Neither VT220 nor VT102 manuals mention that terminal modes and tabstops should be reset as well, thanks to xterm – we now know that.
-
resize
(lines=None, columns=None)[source]¶ Resize the screen to the given size.
If the requested screen size has more lines than the existing screen, lines will be added at the bottom. If the requested size has less lines than the existing screen lines will be clipped at the top of the screen. Similarly, if the existing screen has less columns than the requested screen, columns will be added at the right, and if it has more – columns will be clipped at the right.
Parameters: Changed in version 0.7.0: If the requested screen size is identical to the current screen size, the method does nothing.
-
set_margins
(top=None, bottom=None)[source]¶ Select top and bottom margins for the scrolling region.
Parameters:
-
set_mode
(*modes, **kwargs)[source]¶ Set (enable) a given list of modes.
Parameters: modes (list) – modes to set, where each mode is a constant from pyte.modes
.
-
reset_mode
(*modes, **kwargs)[source]¶ Reset (disable) a given list of modes.
Parameters: modes (list) – modes to reset – hopefully, each mode is a constant from pyte.modes
.
-
define_charset
(code, mode)[source]¶ Define
G0
orG1
charset.Parameters: Warning
User-defined charsets are currently not supported.
-
draw
(data)[source]¶ Display decoded characters at the current cursor position and advances the cursor if
DECAWM
is set.Parameters: data (str) – text to display. Changed in version 0.5.0: Character width is taken into account. Specifically, zero-width and unprintable characters do not affect screen state. Full-width characters are rendered into two consecutive character containers.
-
set_title
(param)[source]¶ Set terminal title.
Note
This is an XTerm extension supported by the Linux terminal.
-
set_icon_name
(param)[source]¶ Set icon name.
Note
This is an XTerm extension supported by the Linux terminal.
-
index
()[source]¶ Move the cursor down one line in the same column. If the cursor is at the last line, create a new line at the bottom.
-
reverse_index
()[source]¶ Move the cursor up one line in the same column. If the cursor is at the first line, create a new line at the top.
-
backspace
()[source]¶ Move cursor to the left one or keep it in its position if it’s at the beginning of the line already.
-
restore_cursor
()[source]¶ Set the current cursor position to whatever cursor is on top of the stack.
-
insert_lines
(count=None)[source]¶ Insert the indicated # of lines at line with cursor. Lines displayed at and below the cursor move down. Lines moved past the bottom margin are lost.
Parameters: count – number of lines to insert.
-
delete_lines
(count=None)[source]¶ Delete the indicated # of lines, starting at line with cursor. As lines are deleted, lines displayed below cursor move up. Lines added to bottom of screen have spaces with same character attributes as last line moved up.
Parameters: count (int) – number of lines to delete.
-
insert_characters
(count=None)[source]¶ Insert the indicated # of blank characters at the cursor position. The cursor does not move and remains at the beginning of the inserted blank characters. Data on the line is shifted forward.
Parameters: count (int) – number of characters to insert.
-
delete_characters
(count=None)[source]¶ Delete the indicated # of characters, starting with the character at cursor position. When a character is deleted, all characters to the right of cursor move left. Character attributes move with the characters.
Parameters: count (int) – number of characters to delete.
-
erase_characters
(count=None)[source]¶ Erase the indicated # of characters, starting with the character at cursor position. Character attributes are set cursor attributes. The cursor remains in the same position.
Parameters: count (int) – number of characters to erase. Note
Using cursor attributes for character attributes may seem illogical, but if recall that a terminal emulator emulates a type writer, it starts to make sense. The only way a type writer could erase a character is by typing over it.
-
erase_in_line
(how=0, private=False)[source]¶ Erase a line in a specific way.
Character attributes are set to cursor attributes.
Parameters: - how (int) –
defines the way the line should be erased in:
0
– Erases from cursor to end of line, including cursor position.1
– Erases from beginning of line to cursor, including cursor position.2
– Erases complete line.
- private (bool) – when
True
only characters marked as eraseable are affected not implemented.
- how (int) –
-
erase_in_display
(how=0, *args, **kwargs)[source]¶ Erases display in a specific way.
Character attributes are set to cursor attributes.
Parameters: - how (int) –
defines the way the line should be erased in:
0
– Erases from cursor to end of screen, including cursor position.1
– Erases from beginning of screen to cursor, including cursor position.2
and3
– Erases complete display. All lines are erased and changed to single-width. Cursor does not move.
- private (bool) – when
True
only characters marked as eraseable are affected not implemented.
Changed in version 0.8.1: The method accepts any number of positional arguments as some
clear
implementations include a;
after the first parameter causing the stream to assume a0
second parameter.- how (int) –
-
clear_tab_stop
(how=0)[source]¶ Clear a horizontal tab stop.
Parameters: how (int) – defines a way the tab stop should be cleared:
0
or nothing – Clears a horizontal tab stop at cursor position.3
– Clears all horizontal tab stops.
-
ensure_vbounds
(use_margins=None)[source]¶ Ensure the cursor is within vertical screen bounds.
Parameters: use_margins (bool) – when True
or whenDECOM
is set, cursor is bounded by top and and bottom margins, instead of[0; lines - 1]
.
-
cursor_up
(count=None)[source]¶ Move cursor up the indicated # of lines in same column. Cursor stops at top margin.
Parameters: count (int) – number of lines to skip.
-
cursor_up1
(count=None)[source]¶ Move cursor up the indicated # of lines to column 1. Cursor stops at bottom margin.
Parameters: count (int) – number of lines to skip.
-
cursor_down
(count=None)[source]¶ Move cursor down the indicated # of lines in same column. Cursor stops at bottom margin.
Parameters: count (int) – number of lines to skip.
-
cursor_down1
(count=None)[source]¶ Move cursor down the indicated # of lines to column 1. Cursor stops at bottom margin.
Parameters: count (int) – number of lines to skip.
-
cursor_back
(count=None)[source]¶ Move cursor left the indicated # of columns. Cursor stops at left margin.
Parameters: count (int) – number of columns to skip.
-
cursor_forward
(count=None)[source]¶ Move cursor right the indicated # of columns. Cursor stops at right margin.
Parameters: count (int) – number of columns to skip.
-
cursor_position
(line=None, column=None)[source]¶ Set the cursor to a specific line and column.
Cursor is allowed to move out of the scrolling region only when
DECOM
is reset, otherwise – the position doesn’t change.Parameters:
-
cursor_to_column
(column=None)[source]¶ Move cursor to a specific column in the current line.
Parameters: column (int) – column number to move the cursor to.
-
cursor_to_line
(line=None)[source]¶ Move cursor to a specific line in the current column.
Parameters: line (int) – line number to move the cursor to.
-
bell
(*args)[source]¶ Bell stub – the actual implementation should probably be provided by the end-user.
-
select_graphic_rendition
(*attrs)[source]¶ Set display attributes.
Parameters: attrs (list) – a list of display attributes to set.
-
report_device_attributes
(mode=0, **kwargs)[source]¶ Report terminal identity.
New in version 0.5.0.
Changed in version 0.7.0: If
private
keyword argument is set, the method does nothing. This behaviour is consistent with VT220 manual.
-
report_device_status
(mode)[source]¶ Report terminal status or cursor position.
Parameters: mode (int) – if 5 – terminal status, 6 – cursor position, otherwise a noop. New in version 0.5.0.
-
pyte.screens.DiffScreen¶
-
class
pyte.screens.
DiffScreen
(*args, **kwargs)[source]¶ A screen subclass, which maintains a set of dirty lines in its
dirty
attribute. The end user is responsible for emptying a set, when a diff is applied.Deprecated since version 0.7.0: The functionality contained in this class has been merged into
Screen
and will be removed in 0.8.0. Please update your code accordingly.
pyte.screens.HistoryScreen¶
-
class
pyte.screens.
History
(top, bottom, ratio, size, position)¶
-
class
pyte.screens.
HistoryScreen
(columns, lines, history=100, ratio=0.5)[source]¶ A :class:~`pyte.screens.Screen` subclass, which keeps track of screen history and allows pagination. This is not linux-specific, but still useful; see page 462 of VT520 User’s Manual.
Parameters: - history (int) – total number of history lines to keep; is split between top and bottom queues.
- ratio (int) – defines how much lines to scroll on
next_page()
andprev_page()
calls.
-
history
¶ A pair of history queues for top and bottom margins accordingly; here’s the overall screen structure:
[ 1: .......] [ 2: .......] <- top history [ 3: .......] ------------ [ 4: .......] s [ 5: .......] c [ 6: .......] r [ 7: .......] e [ 8: .......] e [ 9: .......] n ------------ [10: .......] [11: .......] <- bottom history [12: .......]
Note
Don’t forget to update
Stream
class with appropriate escape sequences – you can use any, since pagination protocol is not standardized, for example:Stream.escape["N"] = "next_page" Stream.escape["P"] = "prev_page"
-
before_event
(event)[source]¶ Ensure a screen is at the bottom of the history buffer.
Parameters: event (str) – event name, for example "linefeed"
.
-
after_event
(event)[source]¶ Ensure all lines on a screen have proper width (
columns
).Extra characters are truncated, missing characters are filled with whitespace.
Parameters: event (str) – event name, for example "linefeed"
.
-
reset
()[source]¶ Overloaded to reset screen history state: history position is reset to bottom of both queues; queues themselves are emptied.
pyte.screens.DebugScreen¶
-
class
pyte.screens.
DebugScreen
(to=<_io.TextIOWrapper name='<stderr>' mode='w' encoding='UTF-8'>, only=())[source]¶ A screen which dumps a subset of the received events to a file.
>>> import io >>> with io.StringIO() as buf: ... stream = Stream(DebugScreen(to=buf)) ... stream.feed("\x1b[1;24r\x1b[4l\x1b[24;1H\x1b[0;10m") ... print(buf.getvalue()) ... ... ["set_margins", [1, 24], {}] ["reset_mode", [4], {}] ["cursor_position", [24, 1], {}] ["select_graphic_rendition", [0, 10], {}]
Parameters: - to (file) – a file-like object to write debug information to.
- only (list) – a list of events you want to debug (empty by default, which means – debug all events).
Warning
This is developer API with no backward compatibility guarantees. Use at your own risk!
pyte.modes¶
This module defines terminal mode switches, used by
Screen
. There’re two types of terminal modes:
- non-private which should be set with
ESC [ N h
, whereN
is an integer, representing mode being set; and - private which should be set with
ESC [ ? N h
.
The latter are shifted 5 times to the right, to be easily
distinguishable from the former ones; for example Origin Mode
– DECOM
is 192
not 6
.
>>> DECOM
192
copyright: |
|
---|---|
copyright: | (c) 2012-2017 by pyte authors and contributors, see AUTHORS for details. |
license: | LGPL, see LICENSE for more details. |
-
pyte.modes.
LNM
= 20¶ Line Feed/New Line Mode: When enabled, causes a received
LF
,pyte.control.FF
, orVT
to move the cursor to the first column of the next line.
-
pyte.modes.
IRM
= 4¶ Insert/Replace Mode: When enabled, new display characters move old display characters to the right. Characters moved past the right margin are lost. Otherwise, new display characters replace old display characters at the cursor position.
-
pyte.modes.
DECTCEM
= 800¶ Text Cursor Enable Mode: determines if the text cursor is visible.
-
pyte.modes.
DECSCNM
= 160¶ Screen Mode: toggles screen-wide reverse-video mode.
-
pyte.modes.
DECOM
= 192¶ Origin Mode: allows cursor addressing relative to a user-defined origin. This mode resets when the terminal is powered up or reset. It does not affect the erase in display (ED) function.
-
pyte.modes.
DECAWM
= 224¶ Auto Wrap Mode: selects where received graphic characters appear when the cursor is at the right margin.
-
pyte.modes.
DECCOLM
= 96¶ Column Mode: selects the number of columns per line (80 or 132) on the screen.
pyte.control¶
This module defines simple control sequences, recognized by
Stream
, the set of codes here is for
TERM=linux
which is a superset of VT102.
copyright: |
|
---|---|
copyright: | (c) 2012-2017 by pyte authors and contributors, see AUTHORS for details. |
license: | LGPL, see LICENSE for more details. |
-
pyte.control.
SP
= ' '¶ Space: Not suprisingly –
" "
.
-
pyte.control.
NUL
= '\x00'¶ Null: Does nothing.
-
pyte.control.
BEL
= '\x07'¶ Bell: Beeps.
-
pyte.control.
BS
= '\x08'¶ Backspace: Backspace one column, but not past the begining of the line.
-
pyte.control.
HT
= '\t'¶ Horizontal tab: Move cursor to the next tab stop, or to the end of the line if there is no earlier tab stop.
-
pyte.control.
LF
= '\n'¶ Linefeed: Give a line feed, and, if
pyte.modes.LNM
(new line mode) is set also a carriage return.
-
pyte.control.
CR
= '\r'¶ Carriage return: Move cursor to left margin on current line.
-
pyte.control.
SO
= '\x0e'¶ Shift out: Activate G1 character set.
-
pyte.control.
SI
= '\x0f'¶ Shift in: Activate G0 character set.
-
pyte.control.
CAN
= '\x18'¶ Cancel: Interrupt escape sequence. If received during an escape or control sequence, cancels the sequence and displays substitution character.
-
pyte.control.
ESC
= '\x1b'¶ Escape: Starts an escape sequence.
-
pyte.control.
DEL
= '\x7f'¶ Delete: Is ignored.
-
pyte.control.
CSI_C0
= '\x1b['¶ Control sequence introducer.
-
pyte.control.
ST_C0
= '\x1b\\'¶ String terminator.
-
pyte.control.
OSC_C0
= '\x1b]'¶ Operating system command.
pyte.escape¶
This module defines both CSI and non-CSI escape sequences, recognized
by Stream
and subclasses.
copyright: |
|
---|---|
copyright: | (c) 2012-2017 by pyte authors and contributors, see AUTHORS for details. |
license: | LGPL, see LICENSE for more details. |
-
pyte.escape.
RIS
= 'c'¶ Reset.
-
pyte.escape.
IND
= 'D'¶ Index: Move cursor down one line in same column. If the cursor is at the bottom margin, the screen performs a scroll-up.
-
pyte.escape.
NEL
= 'E'¶ Next line: Same as
pyte.control.LF
.
-
pyte.escape.
HTS
= 'H'¶ Tabulation set: Set a horizontal tab stop at cursor position.
-
pyte.escape.
RI
= 'M'¶ Reverse index: Move cursor up one line in same column. If the cursor is at the top margin, the screen performs a scroll-down.
-
pyte.escape.
DECSC
= '7'¶ Save cursor: Save cursor position, character attribute (graphic rendition), character set, and origin mode selection (see
DECRC
).
-
pyte.escape.
DECRC
= '8'¶ Restore cursor: Restore previously saved cursor position, character attribute (graphic rendition), character set, and origin mode selection. If none were saved, move cursor to home position.
-
pyte.escape.
DECALN
= '8'¶ Alignment display: Fill screen with uppercase E’s for testing screen focus and alignment.
-
pyte.escape.
ICH
= '@'¶ Insert character: Insert the indicated # of blank characters.
-
pyte.escape.
CUU
= 'A'¶ Cursor up: Move cursor up the indicated # of lines in same column. Cursor stops at top margin.
-
pyte.escape.
CUD
= 'B'¶ Cursor down: Move cursor down the indicated # of lines in same column. Cursor stops at bottom margin.
-
pyte.escape.
CUF
= 'C'¶ Cursor forward: Move cursor right the indicated # of columns. Cursor stops at right margin.
-
pyte.escape.
CUB
= 'D'¶ Cursor back: Move cursor left the indicated # of columns. Cursor stops at left margin.
-
pyte.escape.
CNL
= 'E'¶ Cursor next line: Move cursor down the indicated # of lines to column 1.
-
pyte.escape.
CPL
= 'F'¶ Cursor previous line: Move cursor up the indicated # of lines to column 1.
-
pyte.escape.
CHA
= 'G'¶ Cursor horizontal align: Move cursor to the indicated column in current line.
-
pyte.escape.
CUP
= 'H'¶ Cursor position: Move cursor to the indicated line, column (origin at
1, 1
).
-
pyte.escape.
ED
= 'J'¶ Erase data (default: from cursor to end of line).
-
pyte.escape.
EL
= 'K'¶ Erase in line (default: from cursor to end of line).
-
pyte.escape.
IL
= 'L'¶ Insert line: Insert the indicated # of blank lines, starting from the current line. Lines displayed below cursor move down. Lines moved past the bottom margin are lost.
-
pyte.escape.
DL
= 'M'¶ Delete line: Delete the indicated # of lines, starting from the current line. As lines are deleted, lines displayed below cursor move up. Lines added to bottom of screen have spaces with same character attributes as last line move up.
-
pyte.escape.
DCH
= 'P'¶ Delete character: Delete the indicated # of characters on the current line. When character is deleted, all characters to the right of cursor move left.
-
pyte.escape.
ECH
= 'X'¶ Erase character: Erase the indicated # of characters on the current line.
-
pyte.escape.
DA
= 'c'¶ Device Attributes.
-
pyte.escape.
VPA
= 'd'¶ Vertical position adjust: Move cursor to the indicated line, current column.
-
pyte.escape.
TBC
= 'g'¶ Tabulation clear: Clears a horizontal tab stop at cursor position.
-
pyte.escape.
SM
= 'h'¶ Set mode.
-
pyte.escape.
RM
= 'l'¶ Reset mode.
-
pyte.escape.
SGR
= 'm'¶ Select graphics rendition: The terminal can display the following character attributes that change the character display without changing the character (see
pyte.graphics
).
-
pyte.escape.
DSR
= 'n'¶ Device status report.
-
pyte.escape.
DECSTBM
= 'r'¶ Select top and bottom margins: Selects margins, defining the scrolling region; parameters are top and bottom line. If called without any arguments, whole screen is used.
pyte.graphics¶
This module defines graphic-related constants, mostly taken from console_codes(4) and http://pueblo.sourceforge.net/doc/manual/ansi_color_codes.html.
copyright: |
|
---|---|
copyright: | (c) 2012-2017 by pyte authors and contributors, see AUTHORS for details. |
license: | LGPL, see LICENSE for more details. |
-
pyte.graphics.
TEXT
= {1: '+bold', 3: '+italics', 4: '+underscore', 5: '+blink', 7: '+reverse', 9: '+strikethrough', 22: '-bold', 23: '-italics', 24: '-underscore', 25: '-blink', 27: '-reverse', 29: '-strikethrough'}¶ A mapping of ANSI text style codes to style names, “+” means the: attribute is set, “-” – reset; example:
>>> text[1] '+bold' >>> text[9] '+strikethrough'
-
pyte.graphics.
FG_ANSI
= {30: 'black', 31: 'red', 32: 'green', 33: 'brown', 34: 'blue', 35: 'magenta', 36: 'cyan', 37: 'white', 39: 'default'}¶ A mapping of ANSI foreground color codes to color names.
>>> FG_ANSI[30] 'black' >>> FG_ANSI[38] 'default'
-
pyte.graphics.
FG
= {30: 'black', 31: 'red', 32: 'green', 33: 'brown', 34: 'blue', 35: 'magenta', 36: 'cyan', 37: 'white', 39: 'default'}¶ An alias to
FG_ANSI
for compatibility.
-
pyte.graphics.
FG_AIXTERM
= {90: 'black', 91: 'red', 92: 'green', 93: 'brown', 94: 'blue', 95: 'magenta', 96: 'cyan', 97: 'white'}¶ A mapping of non-standard
aixterm
foreground color codes to color names. These are high intensity colors and thus should be complemented by+bold
.
-
pyte.graphics.
BG_ANSI
= {40: 'black', 41: 'red', 42: 'green', 43: 'brown', 44: 'blue', 45: 'magenta', 46: 'cyan', 47: 'white', 49: 'default'}¶ A mapping of ANSI background color codes to color names.
>>> BG_ANSI[40] 'black' >>> BG_ANSI[48] 'default'
-
pyte.graphics.
BG
= {40: 'black', 41: 'red', 42: 'green', 43: 'brown', 44: 'blue', 45: 'magenta', 46: 'cyan', 47: 'white', 49: 'default'}¶ An alias to
BG_ANSI
for compatibility.
-
pyte.graphics.
BG_AIXTERM
= {100: 'black', 101: 'red', 102: 'green', 103: 'brown', 104: 'blue', 105: 'magenta', 106: 'cyan', 107: 'white'}¶ A mapping of non-standard
aixterm
background color codes to color names. These are high intensity colors and thus should be complemented by+bold
.
-
pyte.graphics.
FG_256
= 38¶ SGR code for foreground in 256 or True color mode.
-
pyte.graphics.
BG_256
= 48¶ SGR code for background in 256 or True color mode.
pyte.charsets¶
This module defines G0
and G1
charset mappings the same way
they are defined for linux terminal, see
linux/drivers/tty/consolemap.c
@ http://git.kernel.org
Note
VT100_MAP
and IBMPC_MAP
were taken unchanged
from linux kernel source and therefore are licensed
under GPL.
copyright: |
|
---|---|
copyright: | (c) 2012-2017 by pyte authors and contributors, see AUTHORS for details. |
license: | LGPL, see LICENSE for more details. |
-
pyte.charsets.
LAT1_MAP
= '\x00\x01\x02\x03\x04\x05\x06\x07\x08\t\n\x0b\x0c\r\x0e\x0f\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~\x7f\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa0¡¢£¤¥¦§¨©ª«¬\xad®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ'¶ Latin1.
-
pyte.charsets.
VT100_MAP
= '\x00\x01\x02\x03\x04\x05\x06\x07\x08\t\n\x0b\x0c\r\x0e\x0f\x10\x11\x12\x13\x14\x15\x16\x17\x18\x19\x1a\x1b\x1c\x1d\x1e\x1f !"#$%&\'()*→←↑↓/█123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^\xa0◆▒␉␌␍␊°±░␋┘┐┌└┼⎺⎻─⎼⎽├┤┴┬│≤≥π≠£·\x7f\x80\x81\x82\x83\x84\x85\x86\x87\x88\x89\x8a\x8b\x8c\x8d\x8e\x8f\x90\x91\x92\x93\x94\x95\x96\x97\x98\x99\x9a\x9b\x9c\x9d\x9e\x9f\xa0¡¢£¤¥¦§¨©ª«¬\xad®¯°±²³´µ¶·¸¹º»¼½¾¿ÀÁÂÃÄÅÆÇÈÉÊËÌÍÎÏÐÑÒÓÔÕÖרÙÚÛÜÝÞßàáâãäåæçèéêëìíîïðñòóôõö÷øùúûüýþÿ'¶ VT100 graphic character set.
-
pyte.charsets.
IBMPC_MAP
= '\x00☺☻♥♦♣♠•◘○◙♂♀♪♫☼▶◀↕‼¶§▬↨↑↓→←∟↔▲▼ !"#$%&\'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~⌂ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■\xa0'¶ IBM Codepage 437.
-
pyte.charsets.
VAX42_MAP
= '\x00☺☻♥♦♣♠•◘○◙♂♀♪♫☼▶◀↕‼¶§▬↨↑↓→←∟↔▲▼ л"#$%&\'()*+,-./0123456789:;<=>е@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`сbcdefgеijklmnкpqтsлеvwxyz{|}~⌂ÇüéâäàåçêëèïîìÄÅÉæÆôöòûùÿÖÜ¢£¥₧ƒáíóúñѪº¿⌐¬½¼¡«»░▒▓│┤╡╢╖╕╣║╗╝╜╛┐└┴┬├─┼╞╟╚╔╩╦╠═╬╧╨╤╥╙╘╒╓╫╪┘┌█▄▌▐▀αßΓπΣσµτΦΘΩδ∞φε∩≡±≥≤⌠⌡÷≈°∙·√ⁿ²■\xa0'¶ VAX42 character set.