Unicode on the Web: Text Rendering in the Chrome Browser

Total Page:16

File Type:pdf, Size:1020Kb

Unicode on the Web: Text Rendering in the Chrome Browser Unicode on the Web: Text Rendering in the Chrome Browser Dominik Röttsches [email protected] Behdad Esfahbod [email protected] Source: SIL Source: http://www.h-57.com/the-force-of-typography/ Challenges ● Millions of Users - what if we break stuff? ● ~17.84 Million page loads per minute - how can we keep those going fast? ● Chrome shipping on 5 platforms: Android, Windows, ChromeOS, Linux, Mac - how can we ensure it works everywhere? ● Speed, Simplicity, Security, Stability ● The Web: Mixed scripts and languages, mixed directionality of text, text and Emoji, demand for fast web fonts Source: https://chrome.googleblog.com/2016/04/chrome-50-releases-and-counting.html Scope ● Recap: What is text shaping? ● Evolution of Chrome’s text stack ● Benefits and notable features of Chrome’s current text stack Text Shaping Text Shaping e ̆ ̧ a ̥ ᵉ ĕ ̧ ḁ ᵉ ȩ ̆ ḁ ᵉ ḝ ḁ ᵉ GlyphBuffer Text Shaping gb = f ( font, size, direction, features, script, language, text, context ) Text Shaping gb = f ( font, size, direction, features, script, language, text, context ) Text Shaping Times Source Sans Lobster gb = f ( font, size, direction, features, script, language, text, context ) Text Shaping 32 16 6 gb = f ( font, size, direction, features, script, language, text, context ) Text Shaping TTB LTR RTL BTT gb = f ( font, size, direction, features, script, language, text, context ) Text Shaping ● Small Caps ● Ligatures ● Swashes, Ornamentals ● Number Forms ● … more gb = f ( font, size, direction, features, script, language, text, context ) Text Shaping ● Latin ● Arabic ● Hiragana ● Cyrillic ● Traditional & Simplified Chinese ● “Common” ● … more gb = f ( font, size, direction, features, script, language, text, context ) Text Shaping Language Script English, German, Finnish… Latin Azerbaijani Cyrillic, Latin, Arabic Chinese Traditional, Simplified gb = f ( font, size, direction, features, script, language, text, context ) Text Shaping LoremHello WorldIpsum length = f ( font, size, direction, features, script, language, text, context ) Text Shaping length = f ( font, size, direction, features, script, language, text, context ) Text Shaping پ ت و length = f ( font, size, direction, features, script, language, text, context ) Text Shaping requires Segmentation gb = f ( font, size, direction, features, script, language, text, context ) Evolution of Chrome’s Text Stack Initial Architecture, before November 2013 Simple vs. Complex Text Path Simple Path Complex Path Typewriter-style glyph selection Shaping, Contextual glyph selection Horizontal advances only 2D glyph placement No typographic features Full typographic feature support Fails on scripts that require contextual Comprehensive script and language shaping support Simple vs. Complex Text Path Simple Complex Code Path Confusion Bugs Nov 2013 Using HarfBuzz on Windows Bugs: Shaping Differences, CoreText vs. HarfBuzz Sept 14 Switching to HarfBuzz on Mac M40 Issue: Regression test failures ● Line spacing issues ● Issues with degraded vertical text Dec 2014 Vertical Text through HarfBuzz Layout of a TextRun - No Word Cache Layout of a TextRun - With Word Cache July 2015 Accelerating Complex Path: Word Cache Fallback Mixup for Combining Marks U+0065 LATIN SMALL LETTER E U+0327 COMBINING CEDILLA U+0306 COMBINING BREVE Font Fallback Recap: Segmentation gb = f ( font, size, direction, features, script, language, text, context ) Before: Font Pre-Segmentation and Basic Script Resolution New Step 1: Run Segmentation Stage New Step 2: Shaper Driven Font Segmentation Oct 2015: Shaper Driven Font Segmentation Fallback Mixup for Combining Marks U+0065 LATIN SMALL LETTER E U+0327 COMBINING CEDILLA U+0306 COMBINING BREVE Grapheme Cluster Based Fallback & Font Selection U+0065 LATIN SMALL LETTER E U+0327 COMBINING CEDILLA U+0306 COMBINING BREVE Nov 2015 First attempt at switching to Complex M49 Memory Issues on Android “7.40% (+676.0 KiB) regression in ChromiumPerf/android-nexus5/memory.top_10_mobile/” ● Identified life cycle issues with the active font handles ● Removed redundant caching July 2016 Switching to Complex Text on Android M54 Oct 2016 Removing the Simple Path Recap: Challenges and features that address them ● Bugs through platform differences ● Bugs through code path differences ● Reduce platform specific code by harmonizing on one shaper ● Add vertical text support to this code path ● Improve performance by adding a word cache ● Modular, staged approach to text segmentation ● Improve quality through shaper driven font segmentation ● Enable complex text by default on all platforms ● Remove the simple text code path Reaping the Benefits True OpenType small caps: font-variant-caps Future Plans Continue to improve language support and typography in Chrome text-decoration-skip: ink Variation Fonts Recap ● High performance unified text shaping ● Chrome now treats all supported scripts/languages and OpenType typographic features as first class citizens Thanks! [email protected] [email protected].
Recommended publications
  • The Unicode Cookbook for Linguists: Managing Writing Systems Using Orthography Profiles
    Zurich Open Repository and Archive University of Zurich Main Library Strickhofstrasse 39 CH-8057 Zurich www.zora.uzh.ch Year: 2017 The Unicode Cookbook for Linguists: Managing writing systems using orthography profiles Moran, Steven ; Cysouw, Michael DOI: https://doi.org/10.5281/zenodo.290662 Posted at the Zurich Open Repository and Archive, University of Zurich ZORA URL: https://doi.org/10.5167/uzh-135400 Monograph The following work is licensed under a Creative Commons: Attribution 4.0 International (CC BY 4.0) License. Originally published at: Moran, Steven; Cysouw, Michael (2017). The Unicode Cookbook for Linguists: Managing writing systems using orthography profiles. CERN Data Centre: Zenodo. DOI: https://doi.org/10.5281/zenodo.290662 The Unicode Cookbook for Linguists Managing writing systems using orthography profiles Steven Moran & Michael Cysouw Change dedication in localmetadata.tex Preface This text is meant as a practical guide for linguists, and programmers, whowork with data in multilingual computational environments. We introduce the basic concepts needed to understand how writing systems and character encodings function, and how they work together. The intersection of the Unicode Standard and the International Phonetic Al- phabet is often not met without frustration by users. Nevertheless, thetwo standards have provided language researchers with a consistent computational architecture needed to process, publish and analyze data from many different languages. We bring to light common, but not always transparent, pitfalls that researchers face when working with Unicode and IPA. Our research uses quantitative methods to compare languages and uncover and clarify their phylogenetic relations. However, the majority of lexical data available from the world’s languages is in author- or document-specific orthogra- phies.
    [Show full text]
  • PDF Copy of My Gsoc Proposal
    GSoC Proposal for Haiku Add Haiku Support for new Harfbuzz library ● Full name: Deepanshu Goyal ​ ● Timezone: +0530 ​ ● Email address: [email protected] ​ ● IRC username (freenode.net): digib0y ​ ● Trac username (dev.haiku-os.org): digib0y ​ ● Trac ticket(s) containing patches for Haiku/ Pull requests: ○ https://github.com/haiku/website/pull/26 ○ https://github.com/haiku/website/pull/41 ○ https://github.com/haikuports/haikuports/pull/1204 ○ https://github.com/HaikuArchives/ArtPaint/pull/54 We also had technical discussions over few issues in ArtPaint which you can checkout: https://github.com/HaikuArchives/ArtPaint/issues , I have also commented few lines of code in one the ​ issues which you might be interested in! Apart from these I have submitted a patch to Haiku however most of the work on the patch was already done by a previous contributor . https://dev.haiku-os.org/attachment/ticket/11518/0001-Implemented-BFont-Blocks-added-build-featur e-for-fon.patch ● GitHub (or other public) repository: https://github.com/digib0y/ ​ ● Will you treat Google Summer of Code as full time employment? ​ ​ Yes, I do understand that Google Summer of Code is a full time virtual internship and I have no other commitment to any other internship, job, and exams. ● How many hours per week will you work? I will work for 40-50 hours a week, with give work update on every alternate day to the assigned mentor.. ● List all obligations (and their dates) that may take time away from GSoC (a second job, vacations, classes, ...): One day per week will be an off day, most probably weekend only if the goals for the week has been completed.
    [Show full text]
  • Digitale Typografie
    Digitale Typografie Andreas F. Borchert Universität Ulm 7. Juli 2016 Syllabus 2 Inhalte: • Einführung und historischer Überblick • Von der geometrisch definierten Fläche zum Pixelraster mit einer Einführung in PostScript und MetaPost • Digitale Repräsentierungen von Schriften • Einführung in die Typografie • Ausgewählte Algorithmen und Verfahrenstechniken Was ist Typografie? 3 • »Typography exists to honor content.« (Robert Bringhurst) • »Typografie ist keine Kunst. Typografie ist keine Wissenschaft. Typografie ist Handwerk.« (Hans Peter Willberg) • »Typografie, das ist die Inszenierung einer Mitteilung in der Fläche, so die kürzeste Definition, die ich kenne.« (Erik Spiekermann) • »Good typography therefore is a silent art; not its presence but rather its absence is noticeable.« (Mittelbach and Rowley: The pursuit of quality – How can automated typesetting achieve the highest standards of craft typography?) Wozu dient Typografie? 4 Robert Bringhurst fasst es folgendermaßen zusammen: »[...] typography should perform these services for the reader: I invite the reader into the text; I reveal the tenor and the meaning of the text; I clarify the structure and the order of the text; I link the text with other existing elements; I induce a state of energetic repose, which is the ideal condition for reading.« Was ist digitale Typografie? 5 • »Digital typography is the technology of using computers for the design, preparation, and presentation of documents, in which the graphical elements are organized, positioned, and themselves created under digital control.« (Richard Rubinstein) • »[...] the problem of printing beautiful books had changed from a problem of metallurgy to a problem of optics and then to a problem of computer science. [...] The future of typography depends on the people who know the most about creating patterns of 0s and 1s; it depends on mathematicians and computer scientists.« (Donald E.
    [Show full text]
  • Higher Quality 2D Text Rendering
    Journal of Computer Graphics Techniques Vol. 2, No. 1, 2013 Higher Quality 2D Text Rendering http://jcgt.org Higher Quality 2D Text Rendering Nicolas P. Rougier INRIA No hinting Native hinting Auto hinting Vertical hinting Figure 1. When displaying text on low-resolution devices (DPI < 150), one typically has to decide if one wants to respect the pixel grid (e.g., Cleartype technology / Microsoft / native hinting) for crisp rendering or, to privilege glyph shapes (Quartz technology / Apple / no hinting) at the cost of blurring. There is, however, a third way that may combine the best of the two technologies (vertical hinting). Abstract Even though text is pervasive in most 3D applications, there is surprisingly no native sup- port for text rendering in OpenGL. To cope with this absence, Mark Kilgard introduced the use of texture fonts [Kilgard 1997]. This technique is well known and widely used and en- sures both good performances and a decent quality in most situations. However, the quality may degrade strongly in orthographic mode (screen space) due to pixelation effects at large sizes and to legibility problems at small sizes due to incorrect hinting and positioning of glyphs. In this paper, we consider font-texture rendering to develop methods to ensure the highest quality in orthographic mode. The method used allows for both the accurate render- ing and positioning of any glyph on the screen. While the method is compatible with complex shaping and/or layout (e.g., the Arabic alphabet), these specific cases are not studied in this article. 50 Journal of Computer Graphics Techniques Vol.
    [Show full text]
  • Open Source Manifest Telmex Columbia Ph2 New STB HW Jan
    Telmex Columbia Open Source Manifest Jan 25th, 2018 Ph2 New STB HW Name Version Requested License ACL 2.2.52 LGPLv2.1 Arimo Apache License 2.0 ATK 2.20.0 LGPLv2 Attr 2.4.47 LGPLv2.1 bridge-utils 1.5 GPLv2 cairo 1.12.14 LGPLv2.1 Cairo-pixman 0.34.0 MIT License Chromium Source 46.0.2490.71 BSD 3-clause "New" or "Revised" License curl - curl 7.50.1 curl License Dbus 1.8.4 Academic Free License v2.1 dbus-glib-0.102 0.102 Academic Free License v2.1 dhcp 4.1-ESV-R11 ISC License DirectFB 1.7.7 LGPLv2.1 DirectFB - Linux Fusion 9.0.3 GPLv2 Droid Sans Font 1.0.0 build 113 Apache License 2.0 Droid Sans Mono Font 1.00 build 107 Apache License 2.0 e2fsprogs 1.43.1 GPLv2 Expat libexpat 2.2.0 MIT License FFmpeg 2.8.7 LGPLv2.1 Fontconfig 2.12.1 MIT License freetype2 2.6.2 Freetype Project License GConf D-BUS 2.16.0 GPLv2 GDK-Pixbuf 2.34.0 LGPLv2 glib-networking lib 2.44.0 LGPLv2.1 GMP - GNU Multiple Precision 4.2.1 LGPLv2.1 Arithmetic Library GnuTLS 3.3.17.1 LGPLv2.1 GPTFDISK 1.0.0 GPLv2 GStreamer 1.8.3 GPLv2 GStreamer plugins-bad 1.8.3 LGPLv2.1 Gstreamer Plugins-Base 1.8.3 LGPLv2.1 GStreamer Plugins-good 1.8.3 LGPLv2.1 GSTREAMER PLUGINS-UGLY 1.8.3 LGPLv2.1 GTK 2.24.30 LGPLv2 HarfBuzz 1.2.5 MIT License hwdata 0.267 GPLv2 ICU - International 57.1 ICU License Components for Unicode IPTables 1.6.0 GPLv2 json-c 0.12-20140410 MIT License keyutils 1.5.9 LGPLv2.1 kmod 23 GPLv2 libkmod 23 LGPLv2.1 libblkid 2.28 LGPLv2.1 libcap 2.25 BSD 3-clause "New" or "Revised" License libffi 3.2.1 MIT License libfuse 2.9.7 LGPLv2.1 libglib2 2.48.1 LGPLv2 libjpeg 9b Independent
    [Show full text]
  • LATEX News, Issues 1–34
    LATEX News, Issues 1–34 Contents Issue 6, December 19969 Welcome to LATEX News 6............9 Issue 1, June 19944 Mono-case file names...............9 Welcome to LATEX News.............4 Another input encoding.............9 LATEX 2ε—the new LATEX release........4 Better user-defined math display environments9 Docstrip improvements..............9 Why a new LATEX?................4 AMS LAT X update................9 Processing documents with LATEX 2ε ......4 E Graphics package update............9 New packages...................4 EC Fonts released................9 Further information...............4 Issue 7, June 1997 10 Issue 2, December 19945 T1 encoded Computer Modern fonts...... 10 Welcome to LATEX News 2............5 T1 encoded Concrete fonts........... 10 December 1994 release of LATEX.........5 Further input encodings............. 10 Accented input..................5 Normalising spacing after punctuation..... 10 AMS-LATEX....................5 Accessing Bold Math Symbols.......... 10 LATEX on the internet..............5 Policy on standard classes............ 10 Further information...............5 New addresses for TUG............. 10 Issue 3, June 19956 Issue 8, December 1997 11 New supported font encodings.......... 11 Welcome to LAT X News 3............6 E New input encodings............... 11 June 1995 release of LAT X............6 E Tools........................ 11 Additional input encodings...........6 Graphics...................... 11 LAT X getting smaller..............6 E LATEX3 experimental programming conventions 11 Distribution
    [Show full text]
  • Arabic Typesetting Using a METAFONT-Based Dynamic Font
    Arabic typesetting using a METAFONT-based dynamic font Amine Anane [email protected] TUG 2019 - Palo Alto, California, USA August 9-11, 2019 How the project started ? I cannot find a searchable pdf document of the Quran. PDF documents are raster images of hand-written book : cannot be searchable. big size. blurry image due to pixelation Other formats (Office Word, HTML [http://tanzil.net]) : based on Unicode text file + OpenType Font. 1 OpenType Font vs Handwritten text Much smaller font size to accommodate the widest line Increase in interword space for other lines 2 Objective Typeset an electronic copy of the Medina Mus’haf (book) re- specting calligraphic rules and having the same Font size, page number and line Why Medina book ? Quranic book is a reference in Arabic calligraphy Written by one of the most renowned Arabic calligrapher beautiful, clear, easy-to-read style each page finishes by a verse and each section (30 sections) in 20pages (15 lines each) Justification is applied extensively If objective is reached, we should reach ultimate goal : High-quality Arabic → typesetter fulfilling Arabic calligraphic rules 3 Where to start? Existing systems and technology for typesetting Arabic text Font standards such as OpenType and Apple Advanced Typography Advantage : Availability of tools Disadvantage : justification does not conform to Arabic calligraphy such as horizontal stretching using Kashida (Tatweel) ditroff/ffortid system Advantage : based on dynamic PostScript fonts Disadvantage : does not model the way stretching is done
    [Show full text]
  • LATEX News, Issues 1–33
    LATEX News, Issues 1–33 Contents Issue 6, December 19969 Welcome to LATEX News 6............9 Issue 1, June 19944 Mono-case file names...............9 Welcome to LATEX News.............4 Another input encoding.............9 LATEX 2ε—the new LATEX release........4 Better user-defined math display environments9 Docstrip improvements..............9 Why a new LATEX?................4 AMS LAT X update................9 Processing documents with LATEX 2ε ......4 E Graphics package update............9 New packages...................4 EC Fonts released................9 Further information...............4 Issue 7, June 1997 10 Issue 2, December 19945 T1 encoded Computer Modern fonts...... 10 Welcome to LATEX News 2............5 T1 encoded Concrete fonts........... 10 December 1994 release of LATEX.........5 Further input encodings............. 10 Accented input..................5 Normalising spacing after punctuation..... 10 AMS-LATEX....................5 Accessing Bold Math Symbols.......... 10 LATEX on the internet..............5 Policy on standard classes............ 10 Further information...............5 New addresses for TUG............. 10 Issue 3, June 19956 Issue 8, December 1997 11 New supported font encodings.......... 11 Welcome to LAT X News 3............6 E New input encodings............... 11 June 1995 release of LAT X............6 E Tools........................ 11 Additional input encodings...........6 Graphics...................... 11 LAT X getting smaller..............6 E LATEX3 experimental programming conventions 11 Distribution
    [Show full text]
  • Typesetting Bangla Script with Lualatex
    TUGboat, Volume 41 (2020), No. 1 69 Table 1: Example rendering with the various modes Typesetting Bangla script with LuaLATEX Ulrike Fischer, Marcel Krüger base কণ্যা এখন কি করিবে? node কণ্যা এখন িক কিরেব? In [2], Md Qutub Uddin Sajib describes some expe- harf কণ㖯া এখন �ক ক����? riences and insights concerning typesetting Bangla. While we don’t know Bangla, we want to share a font-by-font basis between the base mode (mostly A some additional information about the LuaLTEX used for math fonts), node mode (used for text) and side, especially about how to use the possibilities of the new harf mode (which has a number of sub- the new HarfBuzz library. modes). HarfBuzz is an addition to, not a replace- ment for, the existing font shapers. If the library 1 HarfBuzz in LuaLATEX — the engine choice isn’t used the new engine behaves like luatex. Typesetting a script is more than placing glyphs side Table 1 shows the rendering of an example text by side. Even in the rather simple western scripts in the three modes. In comparing the output one there are already ligatures, kerning and accents to can see — even if one doesn’t understand the script — handle and many scripts have much more complex that base mode doesn’t know much, node mode a A rules. Up to now LuaLTEX wasn’t very good with bit and harf mode a lot about the script. E.g., the such scripts. This wasn’t due to a fundamental third word is U+0995 U+09BF (corresponding to the deficiency, but a lack of manpower: To implement Bengali letters “KA”: ক and “I”: ি ).
    [Show full text]
  • Docsconverter License Table of Contents 1.1
    DocsConverter License table of contents 1.1. DocsConverter License 1.2. Font Types and Copyright Holders 1.3. Open Source Licenses used in DocsConverter 1.4. Customer Support and Product Info 1.1. DocsConverter License Hancom Inc. or subject developer reserves the copyrights and intellectual property rights for all programs and adjuncts included in DocsConverter. These rights are protected by the Copyright Act of Korea and international copyright treaties. You may not alter, modify or reproduce the included data files or documents without the prior written consent of Hancom Inc. Hancom Inc. does not guarantee fitness of the functions included in the Software to the user's particular requirements or needs, and is not liable for any and all outcomes derived from the use of the Software. All programs, data files, information booklets and content of the documents included in DocsConverter are protected by the Copyright Act of Korea and international copyright treaties. All programs, data and documents included in DocsConverter may not be resold after modifications or alternations for any purpose. 1.2. Font Types and Copyright Holders Fonts included in DocsConverter are copyright-protected and may only be used in conjunction with this product as per agreements between Hancom Inc. and the font copyright holders. Hancom Inc. shall not be held liable against claims arising from violations thereof. Please inquire directly with the concerned copyright holder if you intend to use copyrighted fonts with other products. More information regarding license of the fonts, or if you intend to distribute a converted PDF document that embeds copyrighted fonts, please inquire directly with the concerned copyright holders.
    [Show full text]
  • The Harfbuzz Experiment Devanagari क्रर्क Gujarati ક્રર્ક
    38 TUGboat, Volume 40 (2019), No. 1 ����Bengali ক্র �� ب Arabic ر ي Bringing world scripts to LuaTEX: The HarfBuzz experiment Devanagari क्र������ Gujarati ક્ર������ Khaled Hosny Gurmukhi ਕ੍ਰ쉍���� Kannada ಕ㒰ರ್ಕಿ Malayalam Myanmar 1 HarfBuzz ക്രര്കി ����ာ်ကြီး Unicode includes thousands of characters and hun- Oriya କ㜰ର୍ Sinhala ���� 1 dreds of scripts, but inclusion in Unicode is just Tamil ����ோ Telugu క㐰ర్క the start. Proper support for many of them is a much more involved process. (Figure 1 shows a few Figure 1: Sample texts from some of the world's examples.) scripts. To aid Unicode, there is a need for smart fonts; ل fonts that are not merely collections of glyphs. TEX's اط لرقعة ا جد ي ر:د قعة راع ف TFM fonts are a kind of smart fonts, as they contain خ ;rules for making ligatures based on certain contexts but meeting the needs of the world scripts requires � � � � � � more than ligatures. These needs lead to the devel- ���� �� �:�� ��� � ��� �� ����� � opment of several font and layout technologies that can fulfil them. Figure 2: Aref Ruqaa font as rendered with HarfBuzz One of these technologies is OpenType,2 which integration (above) and luaotfload (below). is widely supported on major operating systems and applications, making it the de facto standard for Unicode text layout. Others include Apple Advanced Unicode text, among other things. The LuaTEX philosophy is that it provides solutions, not answers, Typography3 (AAT) and Graphite.4 The text layout process can be seen as several so it does not come with an extended text layout successive steps. One particularly interesting and engine, and instead provides hooks to its internals rather complex step is called shaping, which basically so that its users (or macro packages) can extend it involves taking chunks of characters that have some as they see fit.
    [Show full text]
  • Luatex Reference Manual
    LuaTEX Reference Manual stable April 2021 Version 1.13 LuaTEX Reference Manual copyright : LuaTEX development team more info : www.luatex.org version : April 11, 2021 Contents Introduction 13 1 Preamble 17 2 Basic TEX enhancements 19 2.1 Introduction 19 2.1.1 Primitive behaviour 19 2.1.2 Version information 19 2.2 UNICODE text support 20 2.2.1 Extended ranges 20 2.2.2 \Uchar 21 2.2.3 Extended tables 21 2.3 Attributes 21 2.3.1 Nodes 21 2.3.2 Attribute registers 22 2.3.3 Box attributes 22 2.4 LUA related primitives 23 2.4.1 \directlua 23 2.4.2 \latelua and \lateluafunction 25 2.4.3 \luaescapestring 25 2.4.4 \luafunction, \luafunctioncall and \luadef 25 2.4.5 \luabytecode and \luabytecodecall 26 2.5 Catcode tables 27 2.5.1 Catcodes 27 2.5.2 \catcodetable 27 2.5.3 \initcatcodetable 27 2.5.4 \savecatcodetable 27 2.6 Suppressing errors 28 2.6.1 \suppressfontnotfounderror 28 2.6.2 \suppresslongerror 28 2.6.3 \suppressifcsnameerror 28 2.6.4 \suppressoutererror 28 2.6.5 \suppressmathparerror 28 2.6.6 \suppressprimitiveerror 29 2.7 Fonts 29 2.7.1 Font syntax 29 2.7.2 \fontid and \setfontid 29 2.7.3 \noligs and \nokerns 29 2.7.4 \nospaces 30 2.8 Tokens, commands and strings 30 2.8.1 \scantextokens 30 2.8.2 \toksapp, \tokspre, \etoksapp, \etokspre, \gtoksapp, \gtokspre, \xtoksapp, \xtokspre 30 2.8.3 \csstring, \begincsname and \lastnamedcs 31 1 2.8.4 \clearmarks 31 2.8.5 \alignmark and \aligntab 31 2.8.6 \letcharcode 31 2.8.7 \glet 32 2.8.8 \expanded, \immediateassignment and \immediateassigned 32 2.8.9 \ifcondition 33 2.9 Boxes, rules and leaders
    [Show full text]