2020-09-29 11:16:59 +02:00
# Terminal
**Inherits:** [Control] < [CanvasItem] < [Node] < [Object]
Terminal emulator.
**IMPORTANT:**
< img align = "right" src = "./docs/important_properties.png" / >
2020-10-05 11:25:48 +02:00
- If you are not seeing anything in the terminal check that a theme has been set. If there is no theme, everything will be drawn in black by default. A default theme can be found in the [themes directory ](../../themes ).
2020-09-29 11:16:59 +02:00
- If the terminal isn't responding to keyboard or mouse input check that `focus_mode` is set to `All` , otherwise `_gui_input()` won't be called so no input will be processed.
## Description
![Flow Diagram ](./docs/flow_diagram.svg )
### (1) User Input
2020-10-05 11:25:48 +02:00
The user enters some data into the terminal, typically by typing something on the keyboard or clicking (and possibly dragging) somewhere on the screen.
This corresponds to the `_gui_input()` method which is implemented in [terminal.cpp ](./terminal.cpp ).
2020-09-29 11:16:59 +02:00
### (2) Terminal Output
The user input from (1) is processed by the terminal and converted.
2020-10-05 11:25:48 +02:00
For example, if the user were to press the downwards arrow key (↓), the terminal would interpret this
and the `data_sent()` signal would be emitted with the value `"\u001b[A"` .
For a full list of escape sequences see ["XTerm Control Sequences" ](https://invisible-island.net/xterm/ctlseqs/ctlseqs.html ).
2020-09-29 11:16:59 +02:00
### (3) Terminal Input
In the other direction, characters can be sent to the terminal. This corresponds to the `write()` method.
### (4) Draw
The input from (3) is then intepreted by the terminal and drawn to the screen.
2020-10-05 11:25:48 +02:00
For example if the string "\u001b[38;2;0;255;0;mA" was written to the terminal, then it would draw a green colored capital letter 'A' on the screen.
2020-09-29 11:16:59 +02:00
## Properties
| Type | Name | Default |
|-------|------|---------|
| [int] | rows | 24 |
| [int] | cols | 80 |
## Methods
2020-10-05 11:25:48 +02:00
| Returns | Signature |
|---------|-------------------------------------------------|
| void | write ** (** [String]\|[PoolByteArray] data ** )** |
2020-09-29 11:16:59 +02:00
## Theme Properties
| Type | Name | Default |
|---------|-------------------------------|------------------------------|
| [Color] | Terminal/colors/Background | Color(0.0, 0.0, 0.0, 1.0) |
| [Color] | Terminal/colors/Black | Color(0.0, 0.0, 0.0, 1.0) |
| [Color] | Terminal/colors/Blue | Color(0.0, 0.0, 0.5, 1.0) |
| [Color] | Terminal/colors/Cyan | Color(0.0, 0.5, 0.5, 1.0) |
| [Color] | Terminal/colors/Dark Grey | Color(0.5, 0.5, 0.5, 1.0) |
| [Color] | Terminal/colors/Foreground | Color(1.0, 1.0, 1.0, 1.0) |
| [Color] | Terminal/colors/Green | Color(0.0, 0.5, 0.0, 1.0) |
| [Color] | Terminal/colors/Light Blue | Color(0.0, 0.0, 1.0, 1.0) |
| [Color] | Terminal/colors/Light Cyan | Color(0.0, 1.0, 1.0, 1.0) |
| [Color] | Terminal/colors/Light Green | Color(0.0, 1.0, 0.0, 1.0) |
| [Color] | Terminal/colors/Light Grey | Color(0.75, 0.75, 0.75, 1.0) |
| [Color] | Terminal/colors/Light Magenta | Color(1.0, 0.0, 1.0, 1.0) |
| [Color] | Terminal/colors/Light Red | Color(1.0, 0.0, 0.0, 1.0) |
| [Color] | Terminal/colors/Light Yellow | Color(1.0, 1.0, 0.0, 1.0) |
| [Color] | Terminal/colors/Magenta | Color(0.5, 0.0, 0.5, 1.0) |
| [Color] | Terminal/colors/Red | Color(0.5, 0.0, 0.0, 1.0) |
| [Color] | Terminal/colors/White | Color(1.0, 1.0, 1.0, 1.0) |
| [Color] | Terminal/colors/Yellow | Color(0.5, 0.5, 0.0, 1.0) |
| [Font] | Terminal/fonts/Bold | |
| [Font] | Terminal/fonts/Bold Italic | |
| [Font] | Terminal/fonts/Italic | |
| [Font] | Terminal/fonts/Regular | |
## Signals
2020-10-05 11:25:48 +02:00
- **data_sent** ** (** [PoolByteArray] data ** )**
2020-09-29 11:16:59 +02:00
Emitted when some data comes out of the terminal.
This typically occurs when the user interacts with the terminal by typing on the keyboard or clicking somewhere.
2020-10-05 11:25:48 +02:00
Input can be interpreted differently depending on modifier keys and the terminal's settings/state.
In a typical setup, this data would be forwarded to the pseudoterminal.
---
- **key_pressed** ** (** [String] data, [InputEventKey] event ** )**
Emitted when a key is pressed. `data` is the data that would be emitted by the terminal via the `data_sent()` signal and may vary based on the terminal's state. `event` is the event captured by Godot in the `_gui_input(event)` method.
2020-09-29 11:16:59 +02:00
---
2020-10-05 11:25:48 +02:00
- **size_changed** ** (** [Vector2] new_size ** )**
2020-09-29 11:16:59 +02:00
2020-10-05 11:25:48 +02:00
Emitted when the terminal's size changes, typically in response to its `rect_size` changing.
`new_size.x` will be the number of columns and `new_size.y` will be the number of rows.
This information should be forwarded to a pseudoterminal if it is connected so that it can update its size accordingly.
2020-09-29 11:16:59 +02:00
## Property Descriptions
- [int] **rows**
2020-10-05 11:25:48 +02:00
| | |
|-----------|------|
| *Default* | 24 |
| *Setter* | None |
| *Getter* | None |
2020-09-29 11:16:59 +02:00
The number of rows in the terminal's rect.
2020-10-05 11:25:48 +02:00
When using a monospace font, this is typically the number of characters that can fit from the top to the bottom.
It will automatically update as the Control's rect_size changes, and therefore shouldn't be used to set the size of the terminal directly.
2020-09-29 11:16:59 +02:00
---
- [int] **cols**
2020-10-05 11:25:48 +02:00
| | |
|-----------|------|
| *Default* | 80 |
| *Setter* | None |
| *Getter* | None |
The number of columns in the terminal's rect.
When using a monospace font, this is typically the number of characters that can fit from one side to another.
It will automatically update as the Control's rect_size changes, and therefore shouldn't be used to set the size of the terminal directly.
2020-09-29 11:16:59 +02:00
## Method Descriptions
2020-10-05 11:25:48 +02:00
- void **write** ** (** [String]|[PoolByteArray] data ** )**
2020-09-29 11:16:59 +02:00
2020-10-05 11:25:48 +02:00
Writes data to the terminal emulator. Accepts either a [String] or [PoolByteArray].
Typically it would be connected to the output of a pseudoterminal.
2020-09-29 11:16:59 +02:00
Example:
```gdscript
$Terminal.write("Hello World")
$Terminal.write("Hello World".to_utf8())
$Terminal.write(PoolByteArray([0x1b, 0x9e])
```
2020-10-05 11:25:48 +02:00
[CanvasItem]: https://docs.godotengine.org/en/stable/classes/class_canvasitem.html
[Color]: https://docs.godotengine.org/en/stable/classes/class_color.html
[Control]: https://docs.godotengine.org/en/stable/classes/class_control.html
[Node]: https://docs.godotengine.org/en/stable/classes/class_node.html
[Font]: https://docs.godotengine.org/en/stable/classes/class_font.html
[InputEventKey]: https://docs.godotengine.org/en/stable/classes/class_inputeventkey.html
[int]: https://docs.godotengine.org/en/stable/classes/class_int.html
[Object]: https://docs.godotengine.org/en/stable/classes/class_object.html
[PoolByteArray]: https://docs.godotengine.org/en/stable/classes/class_poolbytearray.html
[String]: https://docs.godotengine.org/en/stable/classes/class_string.html
[Vector2]: https://docs.godotengine.org/en/stable/classes/class_vector2.html