.. _libvterm: libvterm -------- Tested Software version 0.3 on Linux. libvterm tested is the one shipped with vIM when using command, ``:terminal``. The homepage URL of this terminal is https://www.leonerd.org.uk/code/libvterm/. Full results available at ucs-detect_ repository path `data/libvterm.yaml `_. *libvterm* is a terminal multiplexer. These tests were executed in host terminal `:ref:`ghostty `_. The homepage URL of this host terminal is https://ghostty.org/. .. _libvtermscores: Score Breakdown +++++++++++++++ Detailed breakdown of how scores are calculated for *libvterm*: .. table:: :class: sphinx-datatable === ===================================== =========== ==================== # Score Type Raw Score Final Scaled Score === ===================================== =========== ==================== 1 :ref:`WIDE ` 99.98% 100.0% 2 :ref:`NARROW ` 99.60% 99.6% 3 :ref:`ZWJ ` 0.00% 0.0% 4 :ref:`LANG ` 96.22% 96.2% 5 :ref:`VS16 ` 50.00% 50.0% 6 :ref:`VS15 ` 0.00% *(excluded)* 7 :ref:`SRI ` 100.00% 100.0% 8 :ref:`SFZ ` 100.00% 100.0% 9 :ref:`RI ` 0.00% 0.0% 10 :ref:`FEAT ` 43.75% 46.7% 11 :ref:`Graphics ` 0% 0.0% 12 :ref:`Resources ` 27.0% 27.0% === ===================================== =========== ==================== **Score Comparison Plot:** The following plot shows how this terminal's scores compare to all other terminals tested. .. figure:: ../_static/plots/libvterm_scores_scaled.png :align: center :width: 800px Scaled scores comparison across all metrics (normalized 0-100%) **Final Scaled Score Calculation:** - Raw Final Score: 48.59% (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: 24.0% (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: 43585 - Total codepoints tested: 43592 - Formula: 43585 / 43592 - Result: 99.98% **NARROW Score Details:** Narrow character support calculation: - Total successful codepoints: 36110 - Total codepoints tested: 36254 - Formula: 36110 / 36254 - Result: 99.60% **ZWJ Score Details:** Emoji ZWJ (Zero-Width Joiner) support calculation: - Total successful sequences: 0 - Total sequences tested: 1445 - Formula: 0 / 1445 - Result: 0.00% **VS16 Score Details:** Variation Selector-16 support calculation: - Errors: 213 of 426 codepoints tested - Success rate: 50.0% - Formula: 50.0 / 100 - Result: 50.00% **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: 0 - Total sequences tested: 262 - Formula: 0 / 262 - Result: 0.00% .. _libvtermfeaturesdetails: **Features Score Details:** Notable terminal features (7.0 / 16): - :ref:`Set bracketed paste mode (2004) `: **yes** - :ref:`Synchronized Output (2026) `: **no** - :ref:`Send FocusIn/FocusOut events (1004) `: **yes** - :ref:`Enable SGR Mouse Mode (1006) `: **yes** - :ref:`Grapheme Clustering (2027) `: **no** - :ref:`Bracketed Paste MIME (5522) `: **no** - :ref:`Kitty Keyboard `: **yes** - :ref:`XTGETTCAP `: **no** - :ref:`Text Sizing (OSC 66) `: **no** - :ref:`Kitty Clipboard Protocol `: **no** - :ref:`OSC 52 Clipboard `: **no** - :ref:`Kitty Pointer Shapes (OSC 22) `: **no** - :ref:`Kitty Notifications (OSC 99) `: **no** - :ref:`Color Report (OSC 10/11) `: **yes** - :ref:`Terminal Identification (XTVERSION) `: **yes** - :ref:`Truecolor Detection `: **yes** Raw score: 43.75% **Graphics Score Details:** Graphics protocol support (0%): - Sixel: **no** - ReGIS: **no** - iTerm2: **no** - Kitty: **no** Scoring: 100% for modern (iTerm2/Kitty), 50% for legacy only (Sixel/ReGIS), 0% for none **Resource Score Details:** - Duration: 50.3s - Mean CPU: 119.1% - Mean RSS: 279.3 MB - Resources Score: 27/100 - Note: log-scale composite cost = log(CPU+1) + log(RSS+1) + log(time+1) - Scaled result: 27.0% **LANG Score Details (Geometric Mean):** Geometric mean calculation: - Formula: (p₁ × p₂ × ... × pₙ)^(1/n) where n = 118 languages - About `geometric mean `_ - Result: 96.22% .. _libvtermwide: Wide character support ++++++++++++++++++++++ Wide character support of *libvterm* is **100.0%** (7 errors of 43592 codepoints tested). Sequence of a WIDE character, from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ================================================= ============= ========== ========= ====== # Codepoint Python Category wcwidth Name === ================================================= ============= ========== ========= ====== 1 `U+0001FAC8 `_ '\\U0001fac8' Cn 2 na === ================================================= ============= ========== ========= ====== Total codepoints: 1 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xf0\x9f\xab\x88|\\n12|\\n" 🫈| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/wide.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 1. .. _libvtermnarrow: Narrow character support ++++++++++++++++++++++++ Narrow character support of *libvterm* is **99.6%** (144 errors of 36254 codepoints tested). Sequence of a NARROW character, from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ================================================= ============= ========== ========= ================= # Codepoint Python Category wcwidth Name === ================================================= ============= ========== ========= ================= 1 `U+0001F3CD `_ '\\U0001f3cd' So 1 RACING MOTORCYCLE === ================================================= ============= ========== ========= ================= Total codepoints: 1 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xf0\x9f\x8f\x8d|\\n1|\\n" 🏍| 1| - python `wcwidth.wcswidth()`_ measures width 1, while *libvterm* measures width 2. .. _libvtermzwj: Emoji ZWJ support +++++++++++++++++ Compatibility of *libvterm* with the Unicode Emoji ZWJ sequence table is **0.0%** (1445 errors of 1445 sequences tested). Sequence of an Emoji ZWJ Sequence, from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ================================================= ============= ========== ========= ================================= # Codepoint Python Category wcwidth Name === ================================================= ============= ========== ========= ================================= 1 `U+0001F3C3 `_ '\\U0001f3c3' So 2 RUNNER 2 `U+0001F3FF `_ '\\U0001f3ff' Sk 2 EMOJI MODIFIER FITZPATRICK TYPE-6 3 `U+200D `_ '\\u200d' Cf 0 ZERO WIDTH JOINER 4 `U+2640 `_ '\\u2640' So 1 FEMALE SIGN 5 `U+FE0F `_ '\\ufe0f' Mn 0 VARIATION SELECTOR-16 === ================================================= ============= ========== ========= ================================= Total codepoints: 5 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xf0\x9f\x8f\x83\xf0\x9f\x8f\xbf\xe2\x80\x8d\xe2\x99\x80\xef\xb8\x8f|\\n12|\\n" 🏃🏿‍♀️| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/zwj.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 11. .. _libvtermvs16: Variation Selector-16 support +++++++++++++++++++++++++++++ Emoji VS-16 results for *libvterm* is 213 errors out of 426 total codepoints tested, 50.0% success. Sequence of a NARROW Emoji made WIDE by *Variation Selector-16*, from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # Codepoint Python Category wcwidth Name === ========================================= ========= ========== ========= ======================= 1 `U+26D1 `_ '\\u26d1' So 1 HELMET WITH WHITE CROSS === ========================================= ========= ========== ========= ======================= Total codepoints: 1 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xe2\x9b\x91|\\n1|\\n" ⛑| 1| Screenshot: .. image:: ../_static/screenshots/libvterm/vs16.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 1, while *libvterm* measures width 2. .. _libvtermvs15: Variation Selector-15 support +++++++++++++++++++++++++++++ Emoji VS-15 results for *libvterm* 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: .. table:: :class: sphinx-datatable === ================================================= ============= ========== ========= ===================== # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/vs15.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 1, while *libvterm* measures width 2. .. _libvtermsri: Standalone Regional Indicator support +++++++++++++++++++++++++++++++++++++ Standalone Regional Indicator support of *libvterm* is **100.0%** (0 errors of 26 codepoints tested). .. _libvtermsfz: Standalone Fitzpatrick modifier support +++++++++++++++++++++++++++++++++++++++ Standalone Fitzpatrick skin tone modifier support of *libvterm* is **100.0%** (0 errors of 5 codepoints tested). .. _libvtermri: Regional Indicator flag sequence support ++++++++++++++++++++++++++++++++++++++++ Regional Indicator flag sequence support of *libvterm* is **0.0%** (262 errors of 262 sequences tested). Sequence of a Regional Indicator flag sequence, from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ================================================= ============= ========== ========= ================================== # Codepoint Python Category wcwidth Name === ================================================= ============= ========== ========= ================================== 1 `U+0001F1F0 `_ '\\U0001f1f0' So 2 REGIONAL INDICATOR SYMBOL LETTER K 2 `U+0001F1FF `_ '\\U0001f1ff' So 2 REGIONAL INDICATOR SYMBOL LETTER Z === ================================================= ============= ========== ========= ================================== Total codepoints: 2 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xf0\x9f\x87\xb0\xf0\x9f\x87\xbf|\\n12|\\n" 🇰🇿| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/ri.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 4. .. _libvtermgraphics: Graphics Protocol Support +++++++++++++++++++++++++ *libvterm* does not report support for any graphics protocols. **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: 2 - Sixel_ indicator (``4``): not present - ReGIS_ indicator (``3``): not present .. _Sixel: https://en.wikipedia.org/wiki/Sixel .. _ReGIS: https://en.wikipedia.org/wiki/ReGIS .. _`iTerm2 inline images`: https://iterm2.com/documentation-images.html .. _libvtermlang: Language Support ++++++++++++++++ The following 94 languages were tested with 100% success: (Jinan), (Yeonbyeon), Aja, Amarakaeri, Arabic, Standard, Assyrian Neo-Aramaic, Baatonum, Bamun, Belanda Viri, Bora, Catalan (2), Chickasaw, Chinantec, Chiltepec, Chinese, Gan, Chinese, Hakka, Chinese, Jinyu, Chinese, Mandarin (Beijing), Chinese, Mandarin (Guiyang), Chinese, Mandarin (Harbin), Chinese, Mandarin (Nanjing), Chinese, Mandarin (Simplified), Chinese, Mandarin (Tianjin), Chinese, Mandarin (Traditional), Chinese, Min Nan, Chinese, Wu, Chinese, Xiang, Chinese, Yue, Colorado, Dagaare, Southern, Dangme, Dendi, Dinka, Northeastern, Ditammari, Dzongkha, Evenki, Fon, French (Welche), Fur, Ga, Gen, Gilyak, Gumuz, Japanese, Japanese (Osaka), Japanese (Tokyo), Kabyle, Korean, Lamnso', Lao, Lingala (tones), Maldivian, Maori (2), Mazahua Central, Mirandese, Mixtec, Metlatónoc, Mongolian, Halh (Mongolian), Mòoré, Nanai, Navajo, Nuosu, Orok, Otomi, Mezquital, Panjabi, Eastern, Pashto, Northern, Picard, Pular (Adlam), Saint Lucian Creole French, Secoya, Seraiki, Shan, Shipibo-Conibo, Siona, South Azerbaijani, Tagalog (Tagalog), Tai Dam, Tamazight, Central Atlas, Tamil, Tamil (Sri Lanka), Tem, Thai, Thai (2), Tibetan, Central, Ticuna, Uduk, Urdu, Urdu (2), Veps, Vietnamese, Vietnamese (Han nom), Waama, Yaneshaʼ, Yiddish, Eastern, Yoruba, Éwé. The following 24 languages are not fully supported: .. table:: :class: sphinx-datatable ========================================================= ========== ========= ============= lang n_errors n_total pct_success ========================================================= ========== ========= ============= :ref:`Javanese (Javanese) ` 321 530 39.4% :ref:`Malayalam ` 271 845 67.9% :ref:`Bengali ` 117 385 69.6% :ref:`Sanskrit ` 145 493 70.6% :ref:`Marathi ` 88 391 77.5% :ref:`Hindi ` 82 390 79.0% :ref:`Sanskrit (Grantha) ` 61 293 79.2% :ref:`Khmer, Central ` 90 443 79.7% :ref:`Maithili ` 71 357 80.1% :ref:`Nepali ` 70 352 80.1% :ref:`Tamang, Eastern ` 11 70 84.3% :ref:`Gujarati ` 50 343 85.4% :ref:`Magahi ` 43 314 86.3% :ref:`Bhojpuri ` 41 313 86.9% :ref:`Telugu ` 42 384 89.1% :ref:`Farsi, Western ` 4 49 91.8% :ref:`Dari ` 4 54 92.6% :ref:`Kannada ` 15 287 94.8% :ref:`Chakma ` 13 267 95.1% :ref:`Sinhala ` 11 258 95.7% :ref:`Burmese ` 10 268 96.3% :ref:`Mon ` 7 332 97.9% :ref:`Panjabi, Western ` 1 62 98.4% :ref:`Khün ` 4 396 99.0% ========================================================= ========== ========= ============= .. _libvtermlangjavanesejavanese: Javanese (Javanese) ^^^^^^^^^^^^^^^^^^^ Sequence of language *Javanese (Javanese)* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ========================== # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Javanese__Javanese_.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangmalayalam: Malayalam ^^^^^^^^^ Sequence of language *Malayalam* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Malayalam.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangbengali: Bengali ^^^^^^^ Sequence of language *Bengali* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ===================== # Codepoint Python Category wcwidth Name === ========================================= ========= ========== ========= ===================== 1 `U+0995 `_ '\\u0995' Lo 1 BENGALI LETTER KA 2 `U+09BE `_ '\\u09be' Mc 0 BENGALI VOWEL SIGN AA 3 `U+200C `_ '\\u200c' Cf 0 ZERO WIDTH NON-JOINER === ========================================= ========= ========== ========= ===================== Total codepoints: 3 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xe0\xa6\x95\xe0\xa6\xbe\xe2\x80\x8c|\\n12|\\n" কা‌| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Bengali.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 8. .. _libvtermlangsanskrit: Sanskrit ^^^^^^^^ Sequence of language *Sanskrit* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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+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\xa4\xe0\xa4\xbf|\\n12|\\n" क्ति| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Sanskrit.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px .. _libvtermlangmarathi: Marathi ^^^^^^^ Sequence of language *Marathi* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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+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\xa4\xe0\xa4\xbf|\\n12|\\n" क्ति| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Marathi.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px .. _libvtermlanghindi: Hindi ^^^^^ Sequence of language *Hindi* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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+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\xa4\xe0\xa4\xbf|\\n12|\\n" क्ति| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Hindi.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px .. _libvtermlangsanskritgrantha: Sanskrit (Grantha) ^^^^^^^^^^^^^^^^^^ Sequence of language *Sanskrit (Grantha)* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ================================================= ============= ========== ========= ===================== # Codepoint Python Category wcwidth Name === ================================================= ============= ========== ========= ===================== 1 `U+00011315 `_ '\\U00011315' Lo 1 GRANTHA LETTER KA 2 `U+0001133E `_ '\\U0001133e' Mc 0 GRANTHA VOWEL SIGN AA 3 `U+00011302 `_ '\\U00011302' Mc 0 GRANTHA SIGN ANUSVARA === ================================================= ============= ========== ========= ===================== Total codepoints: 3 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xf0\x91\x8c\x95\xf0\x91\x8c\xbe\xf0\x91\x8c\x82|\\n12|\\n" 𑌕𑌾𑌂| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Sanskrit__Grantha_.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangkhmercentral: Khmer, Central ^^^^^^^^^^^^^^ Sequence of language *Khmer, Central* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= =================== # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Khmer__Central.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangmaithili: Maithili ^^^^^^^^ Sequence of language *Maithili* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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+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\xa4\xe0\xa4\xbf|\\n12|\\n" क्ति| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Maithili.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px .. _libvtermlangnepali: Nepali ^^^^^^ Sequence of language *Nepali* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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+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\xa4\xe0\xa4\xbf|\\n12|\\n" क्ति| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Nepali.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px .. _libvtermlangtamangeastern: Tamang, Eastern ^^^^^^^^^^^^^^^ Sequence of language *Tamang, Eastern* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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+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\xa4\xe0\xa4\xbf|\\n12|\\n" क्ति| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Tamang__Eastern.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px .. _libvtermlanggujarati: Gujarati ^^^^^^^^ Sequence of language *Gujarati* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ====================== # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Gujarati.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangmagahi: Magahi ^^^^^^ Sequence of language *Magahi* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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+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\xa4\xe0\xa4\xbf|\\n12|\\n" क्ति| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Magahi.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px .. _libvtermlangbhojpuri: Bhojpuri ^^^^^^^^ Sequence of language *Bhojpuri* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================= # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Bhojpuri.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 4. .. _libvtermlangtelugu: Telugu ^^^^^^ Sequence of language *Telugu* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ==================== # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Telugu.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangfarsiwestern: Farsi, Western ^^^^^^^^^^^^^^ Sequence of language *Farsi, Western* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ===================== # Codepoint Python Category wcwidth Name === ========================================= ========= ========== ========= ===================== 1 `U+062A `_ '\\u062a' Lo 1 ARABIC LETTER TEH 2 `U+200C `_ '\\u200c' Cf 0 ZERO WIDTH NON-JOINER === ========================================= ========= ========== ========= ===================== Total codepoints: 2 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xd8\xaa\xe2\x80\x8c|\\n1|\\n" ت‌| 1| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Farsi__Western.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px .. _libvtermlangdari: Dari ^^^^ Sequence of language *Dari* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ===================== # Codepoint Python Category wcwidth Name === ========================================= ========= ========== ========= ===================== 1 `U+062A `_ '\\u062a' Lo 1 ARABIC LETTER TEH 2 `U+200C `_ '\\u200c' Cf 0 ZERO WIDTH NON-JOINER === ========================================= ========= ========== ========= ===================== Total codepoints: 2 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xd8\xaa\xe2\x80\x8c|\\n1|\\n" ت‌| 1| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Dari.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 1, while *libvterm* measures width 7. .. _libvtermlangkannada: Kannada ^^^^^^^ Sequence of language *Kannada* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ===================== # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Kannada.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangchakma: Chakma ^^^^^^ Sequence of language *Chakma* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ================================================= ============= ========== ========= =================== # Codepoint Python Category wcwidth Name === ================================================= ============= ========== ========= =================== 1 `U+00011107 `_ '\\U00011107' Lo 1 CHAKMA LETTER KAA 2 `U+00011133 `_ '\\U00011133' Mn 0 CHAKMA VIRAMA 3 `U+00011120 `_ '\\U00011120' Lo 1 CHAKMA LETTER YYAA 4 `U+0001112C `_ '\\U0001112c' Mc 0 CHAKMA VOWEL SIGN E === ================================================= ============= ========== ========= =================== Total codepoints: 4 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xf0\x91\x84\x87\xf0\x91\x84\xb3\xf0\x91\x84\xa0\xf0\x91\x84\xac|\\n12|\\n" 𑄇𑄳𑄠𑄬| 12| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Chakma.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangsinhala: Sinhala ^^^^^^^ Sequence of language *Sinhala* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ================================= # Codepoint Python Category wcwidth Name === ========================================= ========= ========== ========= ================================= 1 `U+0D9A `_ '\\u0d9a' Lo 1 SINHALA LETTER ALPAPRAANA KAYANNA 2 `U+0DCA `_ '\\u0dca' Mn 0 SINHALA SIGN AL-LAKUNA 3 `U+200D `_ '\\u200d' Cf 0 ZERO WIDTH JOINER === ========================================= ========= ========== ========= ================================= Total codepoints: 3 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xe0\xb6\x9a\xe0\xb7\x8a\xe2\x80\x8d|\\n1|\\n" ක්‍| 1| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Sinhala.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 1, while *libvterm* measures width 7. .. _libvtermlangburmese: Burmese ^^^^^^^ Sequence of language *Burmese* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ================================ # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Burmese.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangmon: Mon ^^^ Sequence of language *Mon* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ================================ # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Mon.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermlangpanjabiwestern: Panjabi, Western ^^^^^^^^^^^^^^^^ Sequence of language *Panjabi, Western* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ======================== # Codepoint Python Category wcwidth Name === ========================================= ========= ========== ========= ======================== 1 `U+06D2 `_ '\\u06d2' Lo 1 ARABIC LETTER YEH BARREE 2 `U+200C `_ '\\u200c' Cf 0 ZERO WIDTH NON-JOINER === ========================================= ========= ========== ========= ======================== Total codepoints: 2 - Shell test using `printf(1)`_, ``'|'`` should align in output:: $ printf "\xdb\x92\xe2\x80\x8c|\\n1|\\n" ے‌| 1| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Panjabi__Western.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 1, while *libvterm* measures width 7. .. _libvtermlangkhn: Khün ^^^^ Sequence of language *Khün* from midpoint of alignment failure records: .. table:: :class: sphinx-datatable === ========================================= ========= ========== ========= ================================= # 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| Screenshot: .. image:: ../_static/screenshots/libvterm/lang_Khün.png :alt: Terminal screenshot of the rendering discrepancy :width: 800px :height: 237px - python `wcwidth.wcswidth()`_ measures width 2, while *libvterm* measures width 3. .. _libvtermdecmodes: DEC Private Modes Support +++++++++++++++++++++++++ DEC private modes results for *libvterm*: 3 changeable modes of 3 supported out of 8 total modes tested (37.5% support, 37.5% changeable). Complete list of DEC private modes tested: .. table:: :class: sphinx-datatable ====== ===================== =================================== =========== ============ ========= 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 No No No 2027 GRAPHEME_CLUSTERING Grapheme Clustering No No No 2031 COLOR_PALETTE_UPDATES Color palette updates No No No 2048 IN_BAND_WINDOW_RESIZE In-Band Window Resize Notifications No No No 5522 BRACKETED_PASTE_MIME Bracketed Paste MIME No No No ====== ===================== =================================== =========== ============ ========= **Summary**: 3 changeable, 5 not changeable. .. _libvtermkittykbd: Kitty Keyboard Protocol +++++++++++++++++++++++ *libvterm* supports the `Kitty keyboard protocol`_. .. table:: :class: sphinx-datatable === =============================== ===================== ======= # 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. .. _`Kitty keyboard protocol`: https://sw.kovidgoyal.net/kitty/keyboard-protocol/ .. _libvtermxtgettcap: XTGETTCAP (Terminfo Capabilities) +++++++++++++++++++++++++++++++++ *libvterm* does not support the ``XTGETTCAP`` sequence. .. _libvtermtextsizing: Text Sizing Protocol (OSC 66) +++++++++++++++++++++++++++++ *libvterm* does not support the `Text Sizing protocol`_. .. _`Text Sizing protocol`: https://sw.kovidgoyal.net/kitty/text-sizing-protocol/ .. _libvtermtruecolor: Truecolor Support +++++++++++++++++ *libvterm* supports 24-bit truecolor, detectable via: - XTGETTCAP (RGB capability): **no** - DECRQSS (truecolor probe): **yes (probe)** - COLORTERM: **yes (truecolor)** .. _libvtermosc52: OSC 52 Clipboard Support ++++++++++++++++++++++++ *libvterm* does **not** advertise OSC 52 clipboard support via DA1 extension 52 or XTGETTCAP Ms. - DA1 extension 52: **no** - XTGETTCAP Ms: **no** .. _libvtermidentification: Terminal Identification +++++++++++++++++++++++ *libvterm* is identified as **libvterm** version **0.3** (detected via XTVERSION). - XTVERSION (raw): **libvterm(0.3)** - XTVERSION: **yes** - XTGETTCAP TN: **no** - ENQ: **no** - TERM_PROGRAM: **no** - TERM: **yes** (xterm-ghostty) (inherited from host terminal) .. _libvtermreproduce: Reproduction ++++++++++++ To reproduce these results for *libvterm*, install and run ucs-detect_ with the following commands:: uvx ucs-detect --rerun data/libvterm.yaml .. _libvtermtime: .. _libvtermresources: Test Performance ++++++++++++++++ The test suite completed in **50.33 seconds** (50s). - **Mean CPU**: 119.1% - **Mean RSS**: 279.3 MB - **Total time**: 50.3s .. figure:: ../_static/profiles/libvterm_cpu.png :alt: CPU usage over time :width: 600px CPU usage during test execution for *libvterm*. .. figure:: ../_static/profiles/libvterm_rss.png :alt: RSS memory over time :width: 600px RSS memory usage during test execution for *libvterm*. .. figure:: ../_static/profiles/libvterm_time.png :alt: Duration comparison :width: 600px Test duration for *libvterm* compared to all other terminals. .. figure:: ../_static/profiles/libvterm_cpu_vs_time.png :alt: CPU % vs Duration :width: 600px CPU % vs duration trade-off for *libvterm*. .. _`printf(1)`: https://www.man7.org/linux/man-pages/man1/printf.1.html .. _`wcwidth.wcswidth()`: https://wcwidth.readthedocs.io/en/latest/intro.html .. _`ucs-detect`: https://github.com/jquast/ucs-detect .. _`ttyscan`: https://github.com/jquast/ttyscan .. _`DEC Private Modes`: https://blessed.readthedocs.io/en/latest/dec_modes.html .. _`OSC 52`: https://dev.to/djmitche/clipboards-terminals-and-linux-3pk5 .. _`XTGETTCAP`: https://codeberg.org/dnkl/foot#xtgettcap .. _`Truecolor`: https://github.com/termstandard/colors/blob/master/README.md .. _`Kitty graphics`: https://sw.kovidgoyal.net/kitty/graphics-protocol/