ghostty/website/app/vt/el/page.mdx
Tim Culverhouse 27be196fb4 website(el): clarify cursor position in test script
The test script for `el` shows the cursor being on the right side of
`X`, however in xterm and ghostty the cursor is _on_ the `X`. Delete the
cursor position and add a comment on where the cursor should be.
2023-12-29 15:19:20 -06:00

226 lines
4.2 KiB
Plaintext

import VTSequence from "@/components/VTSequence";
# Erase Line (EL)
<VTSequence sequence={["CSI", "Pn", "K"]} />
Erase line contents with behavior depending on the command `n`.
If `n` is unset, the value of `n` is 0. The only valid values for `n` are
0, 1, or 2. If any other value of `n` is given, do not execute this sequence.
The remainder of the sequence documentation assumes a valid value of `n`.
For all valid values of `n`, this sequence unsets the pending wrap state.
The cursor position will remain unchanged under all circumstances throughout
this sequence.
If [Select Character Selection Attribute (DECSCA)](#TODO) is enabled
or was the most recently enabled protection mode on the currently active screen,
protected attributes are ignored. Otherwise, protected attributes will be
respected. For more details on this specific logic for protected attribute
handling, see [Erase Character (ECH)](/vt/ech).
For all operations, if a multi-cell character would be split, erase the full multi-cell
character. For example, if "橋" is printed and the erase would only erase the
first or second cell of the two-cell character, both cells should be erased.
If `n` is `0`, perform an **erase line right** operation. Erase line right
is equivalent to [Erase Character (ECH)](/vt/ech) with `n` set to the total
remaining columns from the cursor to the end of the line (and including
the cursor).
If `n` is `1`, perform an **erase line left** operation. This replaces
the `n` cells left of and including the cursor with a blank character and
colors the background according to the current SGR state. The leftmost
column that can be blanked is the first column of the screen. The
[left margin](#TODO) has no effect on this operation.
If `n` is `2`, **erase the entire line**. This is the equivalent of
erase left (`n = 1`) and erase right (`n = 0`) both being executed.
## Validation
### EL V-1: Simple Erase Right
```bash
printf "ABCDE"
printf "\033[3G"
printf "\033[0K"
```
```
|ABc_____|
```
### EL V-2: Erase Right Resets Pending Wrap
```bash
cols=$(tput cols)
printf "\033[${cols}G" # move to last column
printf "A" # set pending wrap state
printf "\033[0K"
printf "X"
```
```
|_______X|
```
The cursor should be on the 'X'
### EL V-3: Erase Right SGR State
```bash
printf "ABC"
printf "\033[2G"
printf "\033[41m"
printf "\033[0K"
```
```
|Ac______|
```
The cells from `c` onwards should have a red background all the way to
the right edge of the screen.
### EL V-4: Erase Right Multi-cell Character
```bash
printf "AB橋DE"
printf "\033[4G"
printf "\033[0K"
```
```
|AB_c____|
```
### EL V-5: Erase Right Left/Right Scroll Region Ignored
```bash
printf "\033[1;1H" # move to top-left
printf "\033[0J" # clear screen
printf "ABCDE"
printf "\033[?69h" # enable left/right margins
printf "\033[1;3s" # scroll region left/right
printf "\033[2G"
printf "\033[0K"
```
```
|Ac________|
```
### EL V-6: Erase Right Protected Attributes Ignored with DECSCA
```bash
printf "\033V"
printf "ABCDE"
printf "\033[1\"q"
printf "\033[0\"q"
printf "\033[2G"
printf "\033[0K"
```
```
|Ac________|
```
### EL V-7: Protected Attributes Respected without DECSCA
```bash
printf "\033[1\"q"
printf "ABCDE"
printf "\033V"
printf "\033[2G"
printf "\033[0K"
printf "\033[1K"
printf "\033[2K"
```
```
|ABCDE_____|
```
### EL V-8: Simple Erase Left
```bash
printf "ABCDE"
printf "\033[3G"
printf "\033[1K"
```
```
|__cDE___|
```
### EL V-9: Erase Left SGR State
```bash
printf "ABC"
printf "\033[2G"
printf "\033[41m"
printf "\033[1K"
```
```
|_cC_____|
```
The cells from `c` to the left should have a red background.
### EL V-10: Erase Left Multi-cell Character
```bash
printf "AB橋DE"
printf "\033[3G"
printf "\033[1K"
```
```
|__c_DE__|
```
### EL V-11: Erase Left Protected Attributes Ignored with DECSCA
```bash
printf "\033V"
printf "ABCDE"
printf "\033[1\"q"
printf "\033[0\"q"
printf "\033[2G"
printf "\033[1K"
```
```
|_cCDE_____|
```
### EL V-12: Simple Erase Complete
```bash
printf "ABCDE"
printf "\033[3G"
printf "\033[2K"
```
```
|__c_______|
```
### EL V-13: Erase Complete SGR State
```bash
printf "ABC"
printf "\033[2G"
printf "\033[41m"
printf "\033[2K"
```
```
|_c______|
```
The entire line should have a red background.