iTerm2

Tested Software version 3.6.10 on Darwin. The homepage URL of this terminal is https://iterm2.com/. Full results available at ucs-detect repository path data/iterm2.yaml.

Score Breakdown

Detailed breakdown of how scores are calculated for iTerm2:

#

Score Type

Raw Score

Final Scaled Score

1

WIDE

99.80%

99.7%

2

NARROW

99.47%

99.5%

3

ZWJ

99.31%

99.3%

4

LANG

90.59%

90.6%

5

VS16

97.18%

97.2%

6

VS15

0.00%

(excluded)

7

SRI

100.00%

100.0%

8

SFZ

100.00%

100.0%

9

RI

100.00%

100.0%

10

FEAT

62.50%

66.7%

11

Graphics

100%

100.0%

12

Resources

N/A

N/A

Score Comparison Plot:

The following plot shows how this terminal’s scores compare to all other terminals tested.

../_images/iterm2_scores_scaled.png

Scaled scores comparison across all metrics (normalized 0-100%)

Final Scaled Score Calculation:

  • Raw Final Score: 83.51% (weighted average: WIDE + NARROW + ZWJ + LANG + VS16 + 0.33 * SRI + 0.33 * SFZ + RI + CAP + 0.5 * GFX + 0.5 * RSC) the categorized ‘average’ absolute support level of this terminal.

    Note

    RSC (Resources) is a composite CPU, memory, and runtime score. RSC is weighted at 0.5 (half as powerful as other metrics). FEAT (Features) is the fraction of notable features supported. GFX (Graphics) scores 100% for modern protocols (iTerm2, Kitty), 50% for legacy only (Sixel, ReGIS), 0% for none.

  • Final Scaled Score: 81.2% (normalized across all terminals tested). Final Scaled scores are normalized (0-100%) relative to all terminals tested

WIDE Score Details:

Wide character support calculation:

  • Total successful codepoints: 505

  • Total codepoints tested: 506

  • Formula: 505 / 506

  • Result: 99.80%

NARROW Score Details:

Narrow character support calculation:

  • Total successful codepoints: 186

  • Total codepoints tested: 187

  • Formula: 186 / 187

  • Result: 99.47%

ZWJ Score Details:

Emoji ZWJ (Zero-Width Joiner) support calculation:

  • Total successful sequences: 1435

  • Total sequences tested: 1445

  • Formula: 1435 / 1445

  • Result: 99.31%

VS16 Score Details:

Variation Selector-16 support calculation:

  • Errors: 12 of 426 codepoints tested

  • Success rate: 97.2%

  • Formula: 97.2 / 100

  • Result: 97.18%

VS15 Score Details (excluded from final score):

Variation Selector-15 support calculation:

  • Errors: 158 of 158 codepoints tested

  • Success rate: 0.0%

  • Formula: 0.0 / 100

  • Result: 0.00%

SRI Score Details:

Standalone Regional Indicator support calculation:

  • Total successful codepoints: 26

  • Total codepoints tested: 26

  • Formula: 26 / 26

  • Result: 100.00%

SFZ Score Details:

Standalone Fitzpatrick skin tone modifier support calculation:

  • Total successful codepoints: 5

  • Total codepoints tested: 5

  • Formula: 5 / 5

  • Result: 100.00%

RI Score Details:

Regional Indicator flag sequence support calculation:

  • Total successful sequences: 262

  • Total sequences tested: 262

  • Formula: 262 / 262

  • Result: 100.00%

Features Score Details:

Notable terminal features (10.0 / 16):

Raw score: 62.50%

Graphics Score Details:

Graphics protocol support (100%):

  • Sixel: yes

  • ReGIS: no

  • iTerm2: yes

  • Kitty: yes

Scoring: 100% for modern (iTerm2/Kitty), 50% for legacy only (Sixel/ReGIS), 0% for none

Resource Score Details:

Resource profiling data not available.

LANG Score Details (Geometric Mean):

Geometric mean calculation:

  • Formula: (p₁ × p₂ × … × pₙ)^(1/n) where n = 85 languages

  • About geometric mean

  • Result: 90.59%

Wide character support

Wide character support of iTerm2 is 99.8% (1 errors of 506 codepoints tested).

Sequence of a WIDE character, from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+115F

‘\u115f’

Lo

2

HANGUL CHOSEONG FILLER

Total codepoints: 1

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe1\x85\x9f|\\n12|\\n"
    ᅟ|
    12|
    
  • See Line 98 of ucs_wide.txt for this sequence in the example file.

  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 0.

Narrow character support

Narrow character support of iTerm2 is 99.5% (1 errors of 187 codepoints tested).

Sequence of a NARROW character, from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+00AD

‘\xad’

Cf

1

SOFT HYPHEN

Total codepoints: 1

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xc2\xad|\\n1|\\n"
    ­|
    1|
    
  • python wcwidth.wcswidth() measures width 1, while iTerm2 measures width 0.

Emoji ZWJ support

Compatibility of iTerm2 with the Unicode Emoji ZWJ sequence table is 99.3% (10 errors of 1445 sequences tested).

Sequence of an Emoji ZWJ Sequence, from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+26F9

‘\u26f9’

So

1

PERSON WITH BALL

2

U+0001F3FD

‘\U0001f3fd’

Sk

2

EMOJI MODIFIER FITZPATRICK TYPE-4

3

U+200D

‘\u200d’

Cf

0

ZERO WIDTH JOINER

4

U+2642

‘\u2642’

So

1

MALE SIGN

5

U+FE0F

‘\ufe0f’

Mn

0

VARIATION SELECTOR-16

Total codepoints: 5

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe2\x9b\xb9\xf0\x9f\x8f\xbd\xe2\x80\x8d\xe2\x99\x82\xef\xb8\x8f|\\n12|\\n"
    ⛹🏽‍♂️|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Variation Selector-16 support

Emoji VS-16 results for iTerm2 is 12 errors out of 426 total codepoints tested, 97.2% success. Sequence of a NARROW Emoji made WIDE by Variation Selector-16, from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0034

‘4’

Nd

1

DIGIT FOUR

2

U+FE0F

‘\ufe0f’

Mn

0

VARIATION SELECTOR-16

Total codepoints: 2

  • Shell test using printf(1), '|' should align in output:

    $ printf "4\xef\xb8\x8f|\\n12|\\n"
    4️|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 1.

Variation Selector-15 support

Emoji VS-15 results for iTerm2 is 158 errors out of 158 total codepoints tested, 0.0% success. Sequence of a WIDE Emoji made NARROW by Variation Selector-15, from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0001F3AE

‘\U0001f3ae’

So

2

VIDEO GAME

2

U+FE0E

‘\ufe0e’

Mn

0

VARIATION SELECTOR-15

Total codepoints: 2

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xf0\x9f\x8e\xae\xef\xb8\x8e|\\n1|\\n"
    🎮︎|
    1|
    
  • python wcwidth.wcswidth() measures width 1, while iTerm2 measures width 2.

Standalone Regional Indicator support

Standalone Regional Indicator support of iTerm2 is 100.0% (0 errors of 26 codepoints tested).

Standalone Fitzpatrick modifier support

Standalone Fitzpatrick skin tone modifier support of iTerm2 is 100.0% (0 errors of 5 codepoints tested).

Regional Indicator flag sequence support

Regional Indicator flag sequence support of iTerm2 is 100.0% (0 errors of 262 sequences tested).

Graphics Protocol Support

iTerm2 supports the following graphics protocols: Sixel, iTerm2 inline images, Kitty graphics.

Detection Methods:

  • Sixel and ReGIS: Detected via the Device Attributes (DA1) query CSI c (\x1b[c). Extension code 4 indicates Sixel support, 3 ReGIS.

  • Kitty graphics: Detected by sending a Kitty graphics query and checking for an OK response.

  • iTerm2 inline images: Detected via the iTerm2 capabilities query OSC 1337 ; Capabilities.

Device Attributes Response:

  • Extensions reported: 1, 2, 4, 6, 17, 18, 21, 22, 52

  • Sixel indicator (4): present

  • ReGIS indicator (3): not present

Language Support

The following 65 languages were tested with 100% success:

Aja, Amarakaeri, Arabic, Standard, Assyrian Neo-Aramaic, Baatonum, Bamun, Belanda Viri, Bora, Catalan (2), Chickasaw, Chinantec, Chiltepec, Dagaare, Southern, Dari, Dendi, Dinka, Northeastern, Dzongkha, Evenki, Farsi, Western, Fon, French (Welche), Fur, Ga, Gen, Gilyak, Gumuz, Kabyle, Lamnso’, Lao, Lingala (tones), Maldivian, Maori (2), Mazahua Central, Mòoré, Nanai, Navajo, Orok, Otomi, Mezquital, Panjabi, Eastern, Panjabi, Western, Pashto, Northern, Picard, Pular (Adlam), Secoya, Seraiki, Shan, Shipibo-Conibo, Sinhala, Siona, South Azerbaijani, Tagalog (Tagalog), Tai Dam, Tamazight, Central Atlas, Tamil, Tem, Thai, Thai (2), Tibetan, Central, Ticuna, Uduk, Urdu, Urdu (2), Vietnamese, Yaneshaʼ, Yiddish, Eastern, Yoruba.

The following 20 languages are not fully supported:

lang

n_errors

n_total

pct_success

Sanskrit (Grantha)

197

237

16.9%

Javanese (Javanese)

321

488

34.2%

Tamang, Eastern

6

11

45.5%

Sanskrit

81

155

47.7%

Marathi

46

103

55.3%

Malayalam

145

382

62.0%

Hindi

56

164

65.9%

Nepali

23

71

67.6%

Magahi

7

22

68.2%

Bengali

97

335

71.0%

Maithili

19

66

71.2%

Khmer, Central

90

390

76.9%

Gujarati

50

290

82.8%

Bhojpuri

41

252

83.7%

Chakma

34

225

84.9%

Telugu

42

335

87.5%

Kannada

14

236

94.1%

Burmese

10

223

95.5%

Mon

7

208

96.6%

Khün

4

354

98.9%

Sanskrit (Grantha)

Sequence of language Sanskrit (Grantha) from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+00011305

‘\U00011305’

Lo

1

GRANTHA LETTER A

2

U+00011302

‘\U00011302’

Mc

0

GRANTHA SIGN ANUSVARA

Total codepoints: 2

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xf0\x91\x8c\x85\xf0\x91\x8c\x82|\\n12|\\n"
    𑌅𑌂|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 1.

Javanese (Javanese)

Sequence of language Javanese (Javanese) from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+A98F

‘\ua98f’

Lo

1

JAVANESE LETTER KA

2

U+A9BA

‘\ua9ba’

Mc

0

JAVANESE VOWEL SIGN TALING

3

U+A9B4

‘\ua9b4’

Mc

0

JAVANESE VOWEL SIGN TARUNG

Total codepoints: 3

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xea\xa6\x8f\xea\xa6\xba\xea\xa6\xb4|\\n12|\\n"
    ꦏꦺꦴ|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Tamang, Eastern

Sequence of language Tamang, Eastern from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

2

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

3

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

4

U+094B

‘\u094b’

Mc

0

DEVANAGARI VOWEL SIGN O

Total codepoints: 4

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa4\x95\xe0\xa5\x8d\xe0\xa4\x95\xe0\xa5\x8b|\\n12|\\n"
    क्को|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Sanskrit

Sequence of language Sanskrit from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

2

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

3

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

4

U+093E

‘\u093e’

Mc

0

DEVANAGARI VOWEL SIGN AA

Total codepoints: 4

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa4\x95\xe0\xa5\x8d\xe0\xa4\x95\xe0\xa4\xbe|\\n12|\\n"
    क्का|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Marathi

Sequence of language Marathi from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

2

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

3

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

4

U+093E

‘\u093e’

Mc

0

DEVANAGARI VOWEL SIGN AA

5

U+0902

‘\u0902’

Mn

0

DEVANAGARI SIGN ANUSVARA

Total codepoints: 5

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa4\x95\xe0\xa5\x8d\xe0\xa4\x95\xe0\xa4\xbe\xe0\xa4\x82|\\n12|\\n"
    क्कां|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Malayalam

Sequence of language Malayalam from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0D15

‘\u0d15’

Lo

1

MALAYALAM LETTER KA

2

U+0D4D

‘\u0d4d’

Mn

0

MALAYALAM SIGN VIRAMA

3

U+0D15

‘\u0d15’

Lo

1

MALAYALAM LETTER KA

4

U+0D3E

‘\u0d3e’

Mc

0

MALAYALAM VOWEL SIGN AA

Total codepoints: 4

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xb4\x95\xe0\xb5\x8d\xe0\xb4\x95\xe0\xb4\xbe|\\n12|\\n"
    ക്കാ|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Hindi

Sequence of language Hindi from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

2

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

3

U+0928

‘\u0928’

Lo

1

DEVANAGARI LETTER NA

4

U+093F

‘\u093f’

Mc

0

DEVANAGARI VOWEL SIGN I

Total codepoints: 4

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa4\x95\xe0\xa5\x8d\xe0\xa4\xa8\xe0\xa4\xbf|\\n12|\\n"
    क्नि|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Nepali

Sequence of language Nepali from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

2

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

3

U+0924

‘\u0924’

Lo

1

DEVANAGARI LETTER TA

4

U+093E

‘\u093e’

Mc

0

DEVANAGARI VOWEL SIGN AA

Total codepoints: 4

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa4\x95\xe0\xa5\x8d\xe0\xa4\xa4\xe0\xa4\xbe|\\n12|\\n"
    क्ता|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Magahi

Sequence of language Magahi from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

2

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

3

U+0937

‘\u0937’

Lo

1

DEVANAGARI LETTER SSA

4

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

5

U+0923

‘\u0923’

Lo

1

DEVANAGARI LETTER NNA

Total codepoints: 5

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa4\x95\xe0\xa5\x8d\xe0\xa4\xb7\xe0\xa5\x8d\xe0\xa4\xa3|\\n12|\\n"
    क्ष्ण|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Bengali

Sequence of language Bengali from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0995

‘\u0995’

Lo

1

BENGALI LETTER KA

2

U+09BF

‘\u09bf’

Mc

0

BENGALI VOWEL SIGN I

3

U+0982

‘\u0982’

Mc

0

BENGALI SIGN ANUSVARA

Total codepoints: 3

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa6\x95\xe0\xa6\xbf\xe0\xa6\x82|\\n12|\\n"
    কিং|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Maithili

Sequence of language Maithili from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

2

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

3

U+0937

‘\u0937’

Lo

1

DEVANAGARI LETTER SSA

4

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

5

U+092F

‘\u092f’

Lo

1

DEVANAGARI LETTER YA

Total codepoints: 5

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa4\x95\xe0\xa5\x8d\xe0\xa4\xb7\xe0\xa5\x8d\xe0\xa4\xaf|\\n12|\\n"
    क्ष्य|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Khmer, Central

Sequence of language Khmer, Central from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+1780

‘\u1780’

Lo

1

KHMER LETTER KA

2

U+17D2

‘\u17d2’

Mn

0

KHMER SIGN COENG

3

U+178A

‘\u178a’

Lo

1

KHMER LETTER DA

4

U+17C5

‘\u17c5’

Mc

0

KHMER VOWEL SIGN AU

Total codepoints: 4

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe1\x9e\x80\xe1\x9f\x92\xe1\x9e\x8a\xe1\x9f\x85|\\n12|\\n"
    ក្ដៅ|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Gujarati

Sequence of language Gujarati from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0A95

‘\u0a95’

Lo

1

GUJARATI LETTER KA

2

U+0ACD

‘\u0acd’

Mn

0

GUJARATI SIGN VIRAMA

3

U+0A95

‘\u0a95’

Lo

1

GUJARATI LETTER KA

4

U+0ABE

‘\u0abe’

Mc

0

GUJARATI VOWEL SIGN AA

Total codepoints: 4

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xaa\x95\xe0\xab\x8d\xe0\xaa\x95\xe0\xaa\xbe|\\n12|\\n"
    ક્કા|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Bhojpuri

Sequence of language Bhojpuri from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0915

‘\u0915’

Lo

1

DEVANAGARI LETTER KA

2

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

3

U+0918

‘\u0918’

Lo

1

DEVANAGARI LETTER GHA

4

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

5

U+0918

‘\u0918’

Lo

1

DEVANAGARI LETTER GHA

6

U+093F

‘\u093f’

Mc

0

DEVANAGARI VOWEL SIGN I

7

U+094D

‘\u094d’

Mn

0

DEVANAGARI SIGN VIRAMA

Total codepoints: 7

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xa4\x95\xe0\xa5\x8d\xe0\xa4\x98\xe0\xa5\x8d\xe0\xa4\x98\xe0\xa4\xbf\xe0\xa5\x8d|\\n12|\\n"
    क्घ्घि्|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 4.

Chakma

Sequence of language Chakma from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+00011103

‘\U00011103’

Lo

1

CHAKMA LETTER AA

2

U+0001112C

‘\U0001112c’

Mc

0

CHAKMA VOWEL SIGN E

Total codepoints: 2

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xf0\x91\x84\x83\xf0\x91\x84\xac|\\n12|\\n"
    𑄃𑄬|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 1.

Telugu

Sequence of language Telugu from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0C15

‘\u0c15’

Lo

1

TELUGU LETTER KA

2

U+0C41

‘\u0c41’

Mc

0

TELUGU VOWEL SIGN U

3

U+0C02

‘\u0c02’

Mc

0

TELUGU SIGN ANUSVARA

Total codepoints: 3

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xb0\x95\xe0\xb1\x81\xe0\xb0\x82|\\n12|\\n"
    కుం|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Kannada

Sequence of language Kannada from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+0C95

‘\u0c95’

Lo

1

KANNADA LETTER KA

2

U+0CBE

‘\u0cbe’

Mc

0

KANNADA VOWEL SIGN AA

3

U+0C82

‘\u0c82’

Mc

0

KANNADA SIGN ANUSVARA

Total codepoints: 3

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe0\xb2\x95\xe0\xb2\xbe\xe0\xb2\x82|\\n12|\\n"
    ಕಾಂ|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Burmese

Sequence of language Burmese from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+1000

‘\u1000’

Lo

1

MYANMAR LETTER KA

2

U+103B

‘\u103b’

Mc

0

MYANMAR CONSONANT SIGN MEDIAL YA

3

U+1031

‘\u1031’

Mc

0

MYANMAR VOWEL SIGN E

Total codepoints: 3

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe1\x80\x80\xe1\x80\xbb\xe1\x80\xb1|\\n12|\\n"
    ကျေ|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Mon

Sequence of language Mon from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+1007

‘\u1007’

Lo

1

MYANMAR LETTER JA

2

U+103C

‘\u103c’

Mc

0

MYANMAR CONSONANT SIGN MEDIAL RA

3

U+1031

‘\u1031’

Mc

0

MYANMAR VOWEL SIGN E

Total codepoints: 3

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe1\x80\x87\xe1\x80\xbc\xe1\x80\xb1|\\n12|\\n"
    ဇြေ|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

Khün

Sequence of language Khün from midpoint of alignment failure records:

#

Codepoint

Python

Category

wcwidth

Name

1

U+1A23

‘\u1a23’

Lo

1

TAI THAM LETTER LOW KA

2

U+1A55

‘\u1a55’

Mc

0

TAI THAM CONSONANT SIGN MEDIAL RA

3

U+1A6E

‘\u1a6e’

Mc

0

TAI THAM VOWEL SIGN E

4

U+1A60

‘\u1a60’

Mn

0

TAI THAM SIGN SAKOT

Total codepoints: 4

  • Shell test using printf(1), '|' should align in output:

    $ printf "\xe1\xa8\xa3\xe1\xa9\x95\xe1\xa9\xae\xe1\xa9\xa0|\\n12|\\n"
    ᨣᩕᩮ᩠|
    12|
    
  • python wcwidth.wcswidth() measures width 2, while iTerm2 measures width 3.

DEC Private Modes Support

DEC private modes results for iTerm2: 6 changeable modes of 6 supported out of 8 total modes tested (75.0% support, 75.0% changeable).

Complete list of DEC private modes tested:

Mode

Name

Description

Supported

Changeable

Enabled

1004

FOCUS_IN_OUT_EVENTS

Send FocusIn/FocusOut events

Yes

Yes

No

1006

MOUSE_EXTENDED_SGR

Enable SGR Mouse Mode

Yes

Yes

No

2004

BRACKETED_PASTE

Set bracketed paste mode

Yes

Yes

No

2026

SYNCHRONIZED_OUTPUT

Synchronized Output

Yes

Yes

No

2027

GRAPHEME_CLUSTERING

Grapheme Clustering

No

No

No

2031

COLOR_PALETTE_UPDATES

Color palette updates

Yes

Yes

No

2048

IN_BAND_WINDOW_RESIZE

In-Band Window Resize Notifications

Yes

Yes

No

5522

BRACKETED_PASTE_MIME

Bracketed Paste MIME

No

No

No

Summary: 6 changeable, 2 not changeable.

Kitty Keyboard Protocol

iTerm2 supports the Kitty keyboard protocol.

#

Flag

Key

State

1

Disambiguate escape codes

disambiguate

No

2

Report event types

report_events

No

3

Report alternate keys

report_alternates

No

4

Report all keys as escape codes

report_all_keys

No

5

Report associated text

report_text

No

Detection is performed by sending CSI ? u to query the current progressive enhancement flags. A terminal that supports this protocol responds with the active flags value.

XTGETTCAP (Terminfo Capabilities)

iTerm2 supports the XTGETTCAP sequence and reports 197 terminfo capabilities (Full).

#

Capability

Description

Value

1

AX

Supports default colors

1

2

Cr

Set cursor color

\E]112\a

3

Cs

Reset cursor color

\E]12;%p1%s\a

4

E3

Erase scrollback

\E[3J

5

Ms

Clipboard set

\E]52;%p1%s;%p2%s\a

6

RGB

Bits per color channel (8 = 24-bit truecolor)

8

7

Se

Reset underline style

\E[2 q

8

Ss

Set underline style

\E[%p1%d q

9

TN

Terminal name

xterm-256color

10

XT

Xterm extensions

1

11

acsc

Alternate character set

``aaffggiijjkkllmmnnooppqqrrssttuuvvwwxxyyzz{{||}}~~

12

am

Auto right margin

1

13

bce

Background color erase

1

14

bel

Bell

\a

15

blink

Enter blink mode

\E[5m

16

bold

Enter bold mode

\E[1m

17

bw

Auto left margin

0

18

ccc

Can redefine colors

1

19

civis

Hide cursor

\E[?25l

20

clear

Clear screen

\E[H\E[2J

21

cnorm

Normal cursor

\E[?12l\E[?25h

22

colors

Max colors on screen

256

23

cols

Columns

80

24

cr

Carriage return

\r

25

csr

Change scroll region

\E[%i%p1%d;%p2%dr

26

cub

Cursor left n

\E[%p1%dD

27

cub1

Cursor left

\b

28

cud

Cursor down n

\E[%p1%dB

29

cud1

Cursor down

\n

30

cuf

Cursor right n

\E[%p1%dC

31

cuf1

Cursor right

\E[C

32

cup

Cursor address

\E[%i%p1%d;%p2%dH

33

cuu

Cursor up n

\E[%p1%dA

34

cuu1

Cursor up

\E[A

35

cvvis

Very visible cursor

\E[?12;25h

36

da

Memory above

0

37

db

Memory below

0

38

dch

Delete n characters

\E[%p1%dP

39

dch1

Delete character

\E[P

40

dim

Enter dim mode

\E[2m

41

dl

Delete n lines

\E[%p1%dM

42

dl1

Delete line

\E[M

43

ech

Erase characters

\E[%p1%dX

44

ed

Clear to end of screen

\E[J

45

el

Clear to end of line

\E[K

46

el1

Clear to start of line

\E[1K

47

eslok

Status line escape OK

0

48

flash

Flash screen

\E[?5h$<100/>\E[?5l

49

home

Cursor home

\E[H

50

hpa

Horizontal position

\E[%i%p1%dG

51

hs

Has status line

0

52

ht

Horizontal tab

\t

53

hts

Set tab stop

\EH

54

ich

Insert n characters

\E[%p1%d@

55

il

Insert n lines

\E[%p1%dL

56

il1

Insert line

\E[L

57

ind

Scroll forward

\n

58

indn

Scroll forward n

\E[%p1%dS

59

initc

Initialize color

\E]4;%p1%d;rgb:%p2%{255}%*%{1000}%/%2.2X/%p3%{255}%*%{100...

60

invis

Invisible cursor

\E[8m

61

is2

Init 2 string

\E[!p\E[?3;4l\E[4l\E>

62

it

Init tabs

8

63

kDC

Shifted delete-char key

\E[3;2~

64

kDC3

Alt delete-char key

\E[3;3~

65

kDC4

Alt-Shift delete-char key

\E[3;4~

66

kDC5

Ctrl delete-char key

\E[3;5~

67

kDC6

Ctrl-Shift delete-char key

\E[3;6~

68

kDC7

Ctrl-Alt delete-char key

\E[3;7~

69

kDN

Shifted down-arrow key

\E[1;2B

70

kDN3

Alt down-arrow key

\E[1;3B

71

kDN4

Alt-Shift down-arrow key

\E[1;4B

72

kDN5

Ctrl down-arrow key

\E[1;5B

73

kDN6

Ctrl-Shift down-arrow key

\E[1;6B

74

kDN7

Ctrl-Alt down-arrow key

\E[1;7B

75

kEND

Shifted end key

\E[1;2F

76

kEND3

Alt end key

\E[1;3F

77

kEND4

Alt-Shift end key

\E[1;4F

78

kEND5

Ctrl end key

\E[1;5F

79

kEND6

Ctrl-Shift end key

\E[1;6F

80

kEND7

Ctrl-Alt end key

\E[1;7F

81

kHOM

Shifted home key

\E[1;2H

82

kHOM3

Alt home key

\E[1;3H

83

kHOM4

Alt-Shift home key

\E[1;4H

84

kHOM5

Ctrl home key

\E[1;5H

85

kHOM6

Ctrl-Shift home key

\E[1;6H

86

kHOM7

Ctrl-Alt home key

\E[1;7H

87

kIC

Shifted insert-char key

\E[2;2~

88

kIC3

Alt insert-char key

\E[2;3~

89

kIC4

Alt-Shift insert-char key

\E[2;4~

90

kIC5

Ctrl insert-char key

\E[2;5~

91

kIC6

Ctrl-Shift insert-char key

\E[2;6~

92

kIC7

Ctrl-Alt insert-char key

\E[2;7~

93

kLFT

Shifted left-arrow key

\E[1;2D

94

kLFT3

Alt left-arrow key

\E[1;3D

95

kLFT4

Alt-Shift left-arrow key

\E[1;4D

96

kLFT5

Ctrl left-arrow key

\E[1;5D

97

kLFT6

Ctrl-Shift left-arrow key

\E[1;6D

98

kLFT7

Ctrl-Alt left-arrow key

\E[1;7D

99

kNXT

Shifted next-page key

\E[6;2~

100

kNXT3

Alt next-page key

\E[6;3~

101

kNXT4

Alt-Shift next-page key

\E[6;4~

102

kNXT5

Ctrl next-page key

\E[6;5~

103

kNXT6

Ctrl-Shift next-page key

\E[6;6~

104

kNXT7

Ctrl-Alt next-page key

\E[6;7~

105

kPRV

Shifted previous-page key

\E[5;2~

106

kPRV3

Alt previous-page key

\E[5;3~

107

kPRV4

Alt-Shift previous-page key

\E[5;4~

108

kPRV5

Ctrl previous-page key

\E[5;5~

109

kPRV6

Ctrl-Shift previous-page key

\E[5;6~

110

kPRV7

Ctrl-Alt previous-page key

\E[5;7~

111

kRIT

Shifted right-arrow key

\E[1;2C

112

kRIT3

Alt right-arrow key

\E[1;3C

113

kRIT4

Alt-Shift right-arrow key

\E[1;4C

114

kRIT5

Ctrl right-arrow key

\E[1;5C

115

kRIT6

Ctrl-Shift right-arrow key

\E[1;6C

116

kRIT7

Ctrl-Alt right-arrow key

\E[1;7C

117

kUP

Shifted up-arrow key

\E[1;2A

118

kUP3

Alt up-arrow key

\E[1;3A

119

kUP4

Alt-Shift up-arrow key

\E[1;4A

120

kUP5

Ctrl up-arrow key

\E[1;5A

121

kUP6

Ctrl-Shift up-arrow key

\E[1;6A

122

kUP7

Ctrl-Alt up-arrow key

\E[1;7A

123

kb2

Keypad center

\EOE

124

kbs

Backspace key

\b

125

kcbt

Back-tab key

\E[Z

126

kcub1

Left arrow key

\EOD

127

kcud1

Down arrow key

\EOB

128

kcuf1

Right arrow key

\EOC

129

kcuu1

Up arrow key

\EOA

130

kdch1

Delete character key

\E[3~

131

kend

End key

\EOF

132

kent

Enter/send key

\EOM

133

kf1

Function key F1

\EOP

134

kf10

Function key F10

\E[21~

135

kf11

Function key F11

\E[23~

136

kf12

Function key F12

\E[24~

137

kf2

Function key F2

\EOQ

138

kf3

Function key F3

\EOR

139

kf4

Function key F4

\EOS

140

kf5

Function key F5

\E[15~

141

kf6

Function key F6

\E[17~

142

kf7

Function key F7

\E[18~

143

kf8

Function key F8

\E[19~

144

kf9

Function key F9

\E[20~

145

khome

Home key

\EOH

146

kich1

Insert character key

\E[2~

147

kind

Scroll-down key

\E[1;2B

148

km

Has meta key

1

149

kmous

Mouse key

\E[M

150

knp

Next page key

\E[6~

151

kpp

Previous page key

\E[5~

152

kri

Scroll-up key

\E[1;2A

153

lines

Lines

24

154

mc5i

Will not echo input

1

155

mir

Move in insert mode

1

156

msgr

Move in standout mode

1

157

npc

No pad character

1

158

op

Original pair

\E[39;49m

159

pairs

Max color pairs

32767

160

rc

Restore cursor

\E8

161

rev

Enter reverse mode

\E[7m

162

ri

Reverse index

\EM

163

rin

Scroll reverse n

\E[%p1%dT

164

ritm

Exit italics mode

\E[23m

165

rmacs

Exit alternate charset mode

\E(B

166

rmam

Disable line wrap

\E[?7l

167

rmcup

Exit alt screen

\E[?1049l

168

rmir

Exit insert mode

\E[4l

169

rmkx

Keypad local mode

\E[?1l\E>

170

rmm

Reset meta mode

\E[?1034l

171

rmso

Exit standout mode

\E[27m

172

rmul

Exit underline mode

\E[24m

173

rs1

Reset string 1

\Ec

174

rs2

Reset string 2

\E[!p\E[?3;4l\E[4l\E>

175

sc

Save cursor

\E7

176

setab

Set background color

\E[%?%p1%{8}%<%t4%p1%d%e%p1%{16}%<%t10%p1%{8}%-%d%e48;5;%...

177

setaf

Set foreground color

\E[%?%p1%{8}%<%t3%p1%d%e%p1%{16}%<%t9%p1%{8}%-%d%e38;5;%p...

178

sgr

Set attributes

%?%p9%t\E(0%e\E(B%;\E[0%?%p6%t;1%;%?%p5%t;2%;%?%p2%t;4%;%...

179

sgr0

Reset attributes

\E(B\E[m

180

sitm

Enter italics mode

\E[3m

181

smacs

Enter alternate charset mode

\E(0

182

smam

Enable line wrap

\E[?7h

183

smcup

Enter alt screen

\E[?1049h

184

smir

Enter insert mode

\E[4h

185

smkx

Keypad transmit mode

\E[?1h\E=

186

smso

Enter standout mode

\E[7m

187

smul

Enter underline mode

\E[4m

188

tbc

Clear all tabs

\E[3g

189

u6

CPR response format

\E[%i%d;%dR

190

u7

CPR request

\E[6n

191

u8

DA response format

\E[?1;2c

192

u9

DA request

\E[c

193

ul

Transparent underline

0

194

vpa

Vertical position

\E[%i%p1%dd

195

xenl

Newline glitch

1

196

xt

Destructive tabs

0

197

xvpa

Extended vertical positioning

0

The XTGETTCAP sequence (DCS + q Pt ST) allows applications to query terminfo capabilities directly from the terminal emulator, rather than relying on the system terminfo database.

Text Sizing Protocol (OSC 66)

iTerm2 does not support the Text Sizing protocol.

Truecolor Support

iTerm2 supports 24-bit truecolor, detectable via:

  • XTGETTCAP (RGB capability): yes (RGB)

  • DECRQSS (truecolor probe): no

  • COLORTERM: yes (truecolor)

OSC 52 Clipboard Support

iTerm2 supports OSC 52 clipboard operations (detected via DA1 extension 52 + XTGETTCAP Ms).

  • DA1 extension 52: yes

  • XTGETTCAP Ms: yes

Terminal Identification

iTerm2 is identified as iTerm2 version 3.6.10 (detected via XTVERSION).

  • XTVERSION (raw): iTerm2 3.6.11

  • XTVERSION: yes

  • XTGETTCAP TN: yes (xterm-256color)

  • ENQ: no

  • TERM_PROGRAM: yes (iTerm.app)

  • TERM: no (xterm-256color)

Reproduction

To reproduce these results for iTerm2, install and run ucs-detect with the following commands:

uvx ucs-detect --rerun data/iterm2.yaml

Test Performance

Performance data for iTerm2 is not available.