class TerminalController:
A class that can be used to portably generate formatted output to a terminal.
TerminalController defines a set of instance variables whose values are initialized to the control sequence necessary to perform a given action. These can be simply included in normal output to the terminal:
>>> term = TerminalController() >>> print('This is '+term.GREEN+'green'+term.NORMAL) This is green
Alternatively, the render()
method can used, which replaces ${action} with the string required to perform action:
>>> term = TerminalController() >>> print(term.render('This is ${GREEN}green${NORMAL}')) This is green
If the terminal doesn't support a given action, then the value of the corresponding instance variable will be set to ''. As a result, the above code will still work on terminals that do not support color, except that their output will not be colored. Also, this means that you can test whether the terminal supports a given action by simply testing the truth value of the corresponding instance variable:
>>> term = TerminalController() >>> if term.CLEAR_SCREEN: ... print 'This terminal supports clearning the screen.' ...
Finally, if the width and height of the terminal are known, then they will be stored in the COLS and LINES attributes.
Author | |
Edward Loper |
Method | __init__ |
Create a TerminalController and initialize its attributes with appropriate values for the current terminal. term_stream is the stream that will be used for terminal output; if this stream is not a tty, then the terminal is assumed to be a dumb terminal (i... |
Method | render |
Replace each $-substitutions in the given template string with the corresponding terminal control string (if it's defined) or '' (if it's not). |
Constant | BG |
Undocumented |
Constant | BG |
Undocumented |
Constant | BG |
Undocumented |
Constant | BG |
Undocumented |
Constant | BG |
Undocumented |
Constant | BG |
Undocumented |
Constant | BG |
Undocumented |
Constant | BG |
Undocumented |
Constant | BLACK |
Undocumented |
Constant | BLINK |
Undocumented |
Constant | BLUE |
Undocumented |
Constant | BOL |
Undocumented |
Constant | BOLD |
Undocumented |
Constant | CLEAR |
Undocumented |
Constant | CLEAR |
Undocumented |
Constant | CLEAR |
Undocumented |
Constant | CLEAR |
Undocumented |
Constant | COLS |
Undocumented |
Constant | CYAN |
Undocumented |
Constant | DIM |
Undocumented |
Constant | DOWN |
Undocumented |
Constant | GREEN |
Undocumented |
Constant | HIDE |
Undocumented |
Constant | LEFT |
Undocumented |
Constant | LINES |
Undocumented |
Constant | MAGENTA |
Undocumented |
Constant | NORMAL |
Undocumented |
Constant | RED |
Undocumented |
Constant | REVERSE |
Undocumented |
Constant | RIGHT |
Undocumented |
Constant | SHOW |
Undocumented |
Constant | UP |
Undocumented |
Constant | WHITE |
Undocumented |
Constant | YELLOW |
Undocumented |
Static Method | _tigetstr |
Rewrites string capabilities to remove "delays" which are not required for modern terminals |
Static Method | _tparm |
Undocumented |
Method | _render |
Helper function for render |
Constant | _ANSICOLORS |
Undocumented |
Constant | _COLORS |
Undocumented |
Constant | _STRING |
Undocumented |
Create a TerminalController and initialize its attributes with appropriate values for the current terminal. term_stream is the stream that will be used for terminal output; if this stream is not a tty, then the terminal is assumed to be a dumb terminal (i.e., have no capabilities).
Replace each $-substitutions in the given template string with the corresponding terminal control string (if it's defined) or '' (if it's not).
Undocumented
Value |
|