TheC0 and C1 control code orcontrol character sets define control codes for use in text by computer systems that useASCII and derivatives of ASCII. The codes represent additional information about the text, such as the position of a cursor, an instruction to start a new line, or a message that the text has been received.
C0 codes are the range 00HEX–1FHEX and the default C0 set was originally defined inISO 646 (ASCII). C1 codes are the range 80HEX–9FHEX and the default C1 set was originally defined inECMA-48 (harmonized later with ISO 6429). TheISO/IEC 2022 system of specifying control and graphic characters allows other C0 and C1 sets to be available for specialized applications, but they are rarely used.
ASCII defines 32 control characters, plus the DEL character. This large number of codes was desirable at the time, as multi-byte controls would require implementation of a state machine in the terminal, which was very difficult with contemporary electronics and mechanical terminals.
Only a few codes have maintained their use: BEL, ESC, and theformat effector[1] (FEn) characters BS, TAB, LF, VT, FF, and CR. Others are unused or have acquired different meanings such as NUL being theC string terminator. Some data transfer protocols such asANPA-1312,Kermit, andXMODEM do make extensive use of SOH, STX, ETX, EOT, ACK, NAK and SYN for purposes approximating their original definitions; and some file formats use the "Information Separators" (ISn) such as theUnix info format[2] andPython'ssplitlines string method.[3]
The names of some codes were changed in ISO 6429:1992 (or ECMA-48:1991) to be neutral with respect to writing direction. The abbreviations used were not changed, as the standard had already specified that those would remain unchanged when the standard is translated to other languages. In this table both new and old names are shown for the renamed controls (the old name is the one matching the abbreviation).
Unicode providesControl Pictures that can replace C0 control characters to make them visible on screen. Howevercaret notation is used more often.
| Decimal | Hexadecimal | Abbreviations | Name | Description | |||||
|---|---|---|---|---|---|---|---|---|---|
| ^@ | 0 | 00 | NUL | ␀ | Null | \0 | Does nothing. The code of blank paper tape, and also used for padding to slow transmission. | ||
| ^A | 1 | 01 | TC1, SOH | ␁ | Start of Heading | First character of the heading of a message.[5] | |||
| ^B | 2 | 02 | TC2, STX | ␂ | Start of Text | Terminates the header and starts the message text. | |||
| ^C | 3 | 03 | TC3, ETX | ␃ | End of Text | Ends the message text, starts a footer (up to the next TC character).[5][6] | |||
| ^D | 4 | 04 | TC4, EOT | ␄ | End of Transmission | Ends the transmission of one or more messages.[5][6] May place terminals on standby.[6] | |||
| ^E | 5 | 05 | TC5, ENQ, WRU[a] | ␅ | Enquiry | Trigger a response at the receiving end, to see if it is still present. | |||
| ^F | 6 | 06 | TC6, ACK | ␆ | Acknowledge | Indication of successful receipt of a message. | |||
| ^G | 7 | 07 | BEL[b] | ␇ | Bell, Alert | \a | Call for attention from an operator. | ||
| ^H | 8 | 08 | FE0, BS | ␈ | Backspace | \b | Move one position leftwards. Next character may overprint or replace the character that was there. | ||
| ^I | 9 | 09 | FE1, HT | ␉ | Character Tabulation, Horizontal Tabulation | \t | Move right to the nexttab stop. | ||
| ^J | 10 | 0A | FE2, LF | ␊ | Line Feed | \n | Move down to the same position on the next line (some devices also moved to the left column). | ||
| ^K | 11 | 0B | FE3, VT | ␋ | Line Tabulation, Vertical Tabulation | \v | Move down to the next vertical tab stop. | ||
| ^L | 12 | 0C | FE4, FF | ␌ | Form Feed | \f | Move down to the top of the next page. | ||
| ^M | 13 | 0D | FE5, CR | ␍ | Carriage Return | \r | Move to column zero while staying on the same line. | ||
| ^N | 14 | 0E | SO, LS1[13][c] | ␎ | Shift Out | Switch to an alternative character set. | |||
| ^O | 15 | 0F | SI, LS0[13][c] | ␏ | Shift In | Return to regular character set after SO. | |||
| ^P | 16 | 10 | TC7, DC0,[d] DLE | ␐ | Data Link Escape | Cause a limited number of contiguously following characters to be interpreted in some different way.[15][16] | |||
| ^Q | 17 | 11 | DC1,XON | ␑ | Device Control One | Turn on (DC1 and DC2) or off (DC3 and DC4) devices. Teletype[7] used these for the paper tape reader and the paper tape punch. The first use became thede facto standard forsoftware flow control.[17] | |||
| ^R | 18 | 12 | DC2, TAPE | ␒ | Device Control Two | ||||
| ^S | 19 | 13 | DC3,XOFF | ␓ | Device Control Three | ||||
| ^T | 20 | 14 | DC4, | ␔ | Device Control Four | ||||
| ^U | 21 | 15 | TC8, NAK | ␕ | Negative Acknowledge | Negative response to a sender, such as a detected error. | |||
| ^V | 22 | 16 | TC9, SYN | ␖ | Synchronous Idle | Sent in synchronous transmission systems when no other character is being transmitted. | |||
| ^W | 23 | 17 | TC10, ETB | ␗ | End of Transmission Block | End of a transmission block of data when data are divided into such blocks for transmission purposes. | |||
| ^X | 24 | 18 | CAN | ␘ | Cancel | Indicates that the data preceding it are in error or are to be disregarded. | |||
| ^Y | 25 | 19 | EM | ␙ | End of medium | Indicates on paper or magnetic tapes that the end of the usable portion of the tape had been reached.[4] | |||
| ^Z | 26 | 1A | SUB | ␚ | Substitute | Replaces a character that was found to beinvalid or in error. Should be ignored. | |||
| ^[ | 27 | 1B | ESC | ␛ | Escape | \e [e] | Alters the meaning of a limited number of following bytes. Nowadays this is almost always used to introduce anANSI escape sequence. | ||
| ^\ | 28 | 1C | IS4, FS | ␜ | File Separator | Can be used asdelimiters to mark fields of data structures. US is the lowest level, while RS, GS, and FS are of increasing level to divide groups made up of items of the level beneath it. SP (space) could be considered an even lower level. | |||
| ^] | 29 | 1D | IS3, GS | ␝ | Group Separator | ||||
| ^^ | 30 | 1E | IS2, RS | ␞ | Record Separator | ||||
| ^_ | 31 | 1F | IS1, US | ␟ | Unit Separator | ||||
| While not technically part of the C0 control character range, the following two characters can be thought of as having some characteristics of control characters. | |||||||||
| 32 | 20 | SP | ␠ | Space | Move right one character position. | ||||
| ^? | 127 | 7F | DEL | ␡ | Delete | Should be ignored. Used to delete characters on punched tape by punching out all the holes. | |||
In 1973,ECMA-35 andISO 2022[18] attempted to define a method so an 8-bit "extended ASCII" code could be converted to a corresponding 7-bit code, andvice versa.[19] In a 7-bit environment, the Shift Out (SO) would change the meaning of the 96 bytes0x20 through0x7F[a][21] (i.e. all but the C0 control codes), to be the characters that an 8-bit environment would print if it used the same code with the high bit set. This meant that the range0x80 through0x9F could not be printed in a 7-bit environment,[19] thus it was decided that no alternative character set could use them, and that these codes should be additional control codes, which become known as theC1 control codes. To allow a 7-bit environment to use these new controls, the sequencesESC @ throughESC _ were to be considered equivalent.[19] The laterISO 8859 standards abandoned support for 7-bit codes, but preserved this range of control characters.
The first C1 control code set to be registered for use with ISO 2022 wasDIN 31626,[22] a specialised set for bibliographic use which was registered in 1979.[23]
The more common general-useISO/IEC 6429 set was registered in 1983,[24] although the ECMA-48 specification upon which it was based had been first published in 1976[25] andJIS X 0211 (formerly JIS C 6323).[26] Symbolic names defined byRFC 1345 and early drafts of ISO 10646, but not in ISO/IEC 6429 (PAD,HOP andSGC) are also used.[9][27]
Except forSS2 andSS3 inEUC-JP text, andNEL in text transcoded fromEBCDIC, the 8-bit forms of these codes were almost never used.CSI,DCS andOSC are used to controltext terminals andterminal emulators, but almost always by using their 7-bit escape code representations. Nowadays if these codes are encountered it is far more likely they are intended to be printing characters from that position ofWindows-1252 orMac OS Roman.
Except forNEL, Unicode does not provide a "control picture" for any of these. There is no well-known variation of Caret notation for them either.
| ESC+ | Decimal | Hex | Abbr | Name | Description[28] | 
|---|---|---|---|---|---|
| @ | 128 | 80 | PAD[10] | Padding Character[b] | Proposed as a "padding" or "high byte" for single-byte characters to make them two bytes long for easier interoperability withmultiple byte characters.Extended Unix Code (EUC) occasionally uses this.[32] | 
| A | 129 | 81 | HOP[10] | High Octet Preset[b] | Proposed to set the high byte of a sequence ofmultiple byte characters so they only need one byte each, as a simple form of data compression. | 
| B | 130 | 82 | BPH | Break Permitted Here[c] | Follows a graphic character where a line break is permitted. Roughly equivalent to asoft hyphen orzero-width space except it does not define what is printed at the line break. | 
| C | 131 | 83 | NBH | No Break Here[c] | Follows the graphic character that is not to be broken. See alsoword joiner. | 
| D | 132 | 84 | IND | Index[d] | Move down one line without moving horizontally, to eliminate ambiguity about the meaning of LF. | 
| E | 133 | 85 | NEL | Next Line | Equivalent to CR+LF, to match theEBCDIC control character. | 
| F | 134 | 86 | SSA | Start of Selected Area | Used byblock-oriented terminals. Inxterm ESC Fmoves to the lower-left corner of the screen, since certain software assumes this behaviour.[35] | 
| G | 135 | 87 | ESA | End of Selected Area | |
| H | 136 | 88 | HTS | 
 | Set a tab stop at the current position. | 
| I | 137 | 89 | HTJ | 
 | Right-justify the text since the last tab against the next tab stop. | 
| J | 138 | 8A | VTS | 
 | Set a vertical tab stop. | 
| K | 139 | 8B | PLD | 
 | To produce subscripts and superscripts inISO/IEC 6429. Subscripts use PLDtext PLUwhile superscripts usePLUtext PLD. | 
| L | 140 | 8C | PLU | 
 | |
| M | 141 | 8D | RI | 
 | Move up one line. | 
| N | 142 | 8E | SS2 | Single-Shift 2 | Next character is from the G2 or G3 sets, respectively. | 
| O | 143 | 8F | SS3 | Single-Shift 3 | |
| P | 144 | 90 | DCS | Device Control String | Followed by a string of printable characters (0x20 through 0x7E) and format effectors (0x08 through 0x0D), terminated by ST (0x9C).Xterm defined a number of these.[36] | 
| Q | 145 | 91 | PU1 | Private Use 1 | Reserved for private function agreed on between the sender and the recipient of the data. | 
| R | 146 | 92 | PU2 | Private Use 2 | |
| S | 147 | 93 | STS | Set Transmit State | |
| T | 148 | 94 | CCH | Cancel character | Destructive backspace, to eliminate ambiguity about meaning ofBS. | 
| U | 149 | 95 | MW | Message Waiting | |
| V | 150 | 96 | SPA | Start of Protected Area | Used byblock-oriented terminals. | 
| W | 151 | 97 | EPA | End of Protected Area | |
| X | 152 | 98 | SOS | Start of String[c] | Followed by a control string terminated byST (0x9C) which (unlikeDCS,OSC,PM orAPC) may contain any character except SOS or ST. | 
| Y | 153 | 99 | SGC,[10] SGCI[37] | Single Graphic Character Introducer[b] | Intended to allow an arbitraryUnicode character to be printed; it would be followed by that character, most likely encoded inUTF-1.[37] | 
| Z | 154 | 9A | SCI | Single Character Introducer[c] | To be followed by a single printable character (0x20 through 0x7E) or format effector (0x08 through 0x0D), and to print it as ASCII no matter what graphic or control sets were in use. | 
| [ | 155 | 9B | CSI | Control Sequence Introducer | Used to introduce control sequences that take parameters. Used forANSI escape sequences. | 
| \ | 156 | 9C | ST | String Terminator | Terminates a string started byDCS,SOS,OSC,PM orAPC. | 
| ] | 157 | 9D | OSC | Operating System Command | Followed by a string of printable characters (0x20 through 0x7E) and format effectors (0x08 through 0x0D), terminated by ST (0x9C), intended for use to allow in-band signaling of protocol information, but rarely used for that purpose. Someterminal emulators, includingxterm, use OSC sequences for setting the window title and changing the colour palette. They may also support terminating an OSC sequence withBEL instead of ST.[38]Kermit used APC to transmit commands.[39] | 
| ^ | 158 | 9E | PM | Privacy Message | |
| _ | 159 | 9F | APC | Application Program Command | 
TheISO/IEC 2022 (ECMA-35) extension mechanism allowed escape sequences to change the C0 and C1 sets. The standard C0 control character set shown above is chosen with the sequenceESC ! @ and the above C1 set chosen with the sequenceESC " C.[24]
Several official and unofficial alternatives have been defined, but this is pretty much obsolete. Most were forced to retain a good deal of compatibility with the ASCII controls for interoperability. The standard makes ESC,[40][41] SP and DEL[a] "fixed" coded characters, which are available in their ASCII locations in all encodings that conform to the standard.[43] It also specifies that if a C0 set included transmission control (TCn) codes, they must be encoded at their ASCII locations[40] and could not be put in a C1 set,[44] and any new transmission controls must be in a C1 set.[40]
Unicode reserves the 65 code points described above for compatibility with the C0 and C1 control codes, giving them thegeneral categoryCc (control). These are:
Unicode only specifies semantics for the C0 format controls HT, LF, VT, FF, and CR (note BS is missing); the C0 information separators FS, GS, RS, US (and SP); and the C1 control NEL.[58] The rest of the codes are transparent to Unicode and their meanings are left to higher-level protocols, withISO/IEC 6429 suggested as a default.[58]
Unicode includes many additional format effector characters besides these, such asmarks, embeds, isolates and pops for explicit bidirectional formatting, and thezero-width joiner andnon-joiner for controlling ligature use. However these are given the general categoryCf (format) rather thanCc.
{{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{cite book}}:  CS1 maint: numeric names: authors list (link){{cite book}}:  CS1 maint: numeric names: authors list (link){{cite book}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{cite web}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link){{citation}}:  CS1 maint: numeric names: authors list (link)The 64 control characters […], the ASCII DELETE character (U+007F)[…] are mapped respecting EBCDIC conventions, as defined in IBM Character Data Representation Architecture, CDRA, with one exception -- the pairing of EBCDIC Line Feed and New Line control characters are swapped from their CDRA default pairings to ISO/IEC 6429 Line Feed (U+000A) and Next Line (U+0085) control characters