The Luatex Way: \Framed

Total Page:16

File Type:pdf, Size:1020Kb

The Luatex Way: \Framed The LuaTEX way: \framed Hans Hagen Pragma ADE http://pragma-ade.com Abstract ConTEXt's \framed macro has many flexible options for typesetting a paragraph. This short note discusses its reimplementation in Lua for ConTEXt MkIV. 1 \framed and its width Here the outer \hsize was made a bit smaller. As you can see the frame is determined by the widest One of the more powerful commands in ConTEXt is \framed. You can pass quite a few parameters line. Because it was one of the first features we that control the spacing, alignment, backgrounds needed, the code in ConTEXt that is involved in de- and more. This command is used all over the place termining the maximum natural width is pretty old. (although often hidden from the user) which means It boils down to unboxing a \vbox and stepwise grab- that it also has to be quite stable. bing the last box, penalty, kern and skip. That is, Unfortunately, there is one nasty bit of code we unwind the box backwards. that is hard to get right. Calculating the height of a However, one cannot grab everything; or, in T X speak: there is only a limited number of box is not that complex: the height that TEX reports E is indeed the height. However, the width of box is \lastsomething commands. Special nodes, such as determined by the value of \hsize at the time of whatsits, cannot be grabbed and make the analyzer typesetting. The actual content can be smaller. In abort its analysis. There is no way that we can solve the \framed macro by default the width is calculated this in traditional TEX and in ConTEXt MkII. automatically. 2 \framed with LuaTEX \framed So how about LuaT X and ConT Xt MkIV? The [align=middle,width=fit] E E {Out beyond the ethernet the spectrum spreads macro used in the \framed command is: \unknown} \doreshapeframedbox{do something this shows up as (taken from ‘Casino Nation' by with \box\framebox} Jackson Browne): In LuaTEX we can manipulate box content at Out beyond the ethernet the Lua level. Instead of providing a truckload of ex- the spectrum spreads . tra primitives (which would also introduce new data types at the TEX end) we delegate the job to Lua. Or take this quote (from ‘A World Without Us' \def\doreshapeframedbox by Alan Weisman): {\ctxlua{commands.doreshapeframedbox \hsize=.6\hsize (\number\framebox)}} \framed [align=middle,width=fit] Here \ctxlua is our reserved instance for Con- {\input weisman } TEXt, and commands provides the namespace for This gives a multi-line paragraph: commands that we delegate to Lua (so, there are Since the mid-1990s, humans more of them). The amount of Lua code is far have taken an unprecedented smaller than the TEX code (which we will not show step in Earthly annals by here; it's in supp-box.tex if you want to see it). introducing not just exotic function commands.doreshapeframedbox(n) flora or fauna from one if tex.wd[n] ~= 0 then ecosystem into another, but local hpack = node.hpack actually inserting exotic genes local free = node.free into the operating systems of local copy = node.copy_list individual plants and animals, local noflines, lastlinelength, width = 0,0,0 where they're intended to do local list = tex.box[n].list exactly the same thing: copy local done = false themselves, over and over. for h in node.traverse_id('hlist',list) do done = true 462 TUGboat, Volume 29 (2008), No. 3 — TUG 2008 Conference Proceedings The LuaTEX way: \framed local p = hpack(copy(h.list)) we repack the content again, this time permanently. lastlinelength = p.width Now we use the maximum encountered width which if lastlinelength > width then is forced by the keyword exactly. Because all glue is width = lastlinelength still present we automatically get the desired align- end ment. We create local shortcuts to some node func- p.list = nil tions which makes it run faster; keep in mind that free(p) this is a core function called many times in a regular end if done then ConTEXt job. if width ~= 0 then In looking at ConTEXt MkIV you will find quite for h in node.traverse_id('hlist',list) do a lot of Lua code and often it looks rather complex, if h.width ~= width then especially if you have no clue why it's needed. Think h.list = hpack(h.list,width,'exactly') of OpenType font handling which involves locating h.width = width fonts, loading and caching them, storing features and end later on applying them to node lists, etc. end However, once we are beyond the stage of de- end veloping all the code that is needed to support the tex.wd[n] = width basics, we will start doing the things that relate more end to the typesetting process itself, such as the previous -- we can also work with lastlinelength end code. One of the candidates for a similar Lua-based end solution is for instance column balancing. From the previous example code you can deduce that manipu- In the first loop we inspect all lines (nodes with lating the node lists from Lua can make that easier. type hlist) and repack them to their natural width Of course we'll be a few more years down the road with node.hpack. In the process we keep track of by then. the maximum natural width. In the second loop TUGboat, Volume 29 (2008), No. 3 — TUG 2008 Conference Proceedings 463.
Recommended publications
  • The Luacode Package
    The luacode package Manuel Pégourié-Gonnard <[email protected]> v1.2a 2012/01/23 Abstract Executing Lua code from within TEX with \directlua can sometimes be tricky: there is no easy way to use the percent character, counting backslashes may be hard, and Lua comments don’t work the way you expect. This package provides the \luaexec command and the luacode(*) environments to help with these problems, as well as helper macros and a debugging mode. Contents 1 Documentation1 1.1 Lua code in LATEX...................................1 1.2 Helper macros......................................3 1.3 Debugging........................................3 2 Implementation3 2.1 Preliminaries......................................4 2.2 Internal code......................................5 2.3 Public macros and environments...........................7 3 Test file 8 1 Documentation 1.1 Lua code in LATEX For an introduction to the most important gotchas of \directlua, see lualatex-doc.pdf. Before presenting the tools in this package, let me insist that the best way to manage a non- trivial piece of Lua code is probably to use an external file and source it from Lua, as explained in the cited document. \luadirect First, the exact syntax of \directlua has changed along version of LuaTEX, so this package provides a \luadirect command which is an exact synonym of \directlua except that it doesn’t have the funny, changing parts of its syntax, and benefits from the debugging facilities described below (1.3).1 The problems with \directlua (or \luadirect) are mainly with TEX special characters. Actually, things are not that bad, since most special characters do work, namely: _, ^, &, $, {, }. Three are a bit tricky but they can be managed with \string: \, # and ~.
    [Show full text]
  • Luatex Reference Manual
    LuaTEX Reference Manual stable July 2021 Version 1.10 LuaTEX Reference Manual copyright : LuaTEX development team more info : www.luatex.org version : July 23, 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]
  • A Guide to Lualatex
    A guide to LuaLATEX Manuel Pégourié-Gonnard <[email protected]> May 5, 2013 1 吀his document is a map, or touristic guide, for the new worldAT ofLuaL EX. 吀he intended audience ranges from complete newcomers (with a working knowledge of conventional LATEX) to package developers. 吀his guide is intended to be compre- hensive in the following sense: it contains pointers to all relevant sources, gathers information that is otherwise sca琀tered, and adds introductory material. Feedback and suggestions for improvement are most welcome. 吀his document is work in progress; thanks for your comprehension and patience. 1 Introduction 2 1.1 Just what is LuaLATEX? ................................ 2 1.2 Switching from LATEX to LuaLATEX ......................... 3 1.3 A Lua-in-TEX primer ................................ 4 1.4 Other things you should know ........................... 6 2 Essential packages and practices 7 2.1 User-level ...................................... 7 2.2 Developer-level ................................... 7 3 Other packages 10 3.1 User-level ...................................... 10 3.2 Developer-level ................................... 10 4 吀he luatex and lualatex formats 11 5 吀hings that just work, partially work, or don't work (yet) 13 5.1 Just working ..................................... 13 5.2 Partially working .................................. 13 5.3 Not working (yet) .................................. 14 1 吀hough focusing on LuaLATEX, it includes relevant information about LuaTEX with the Plain format, too. 1 1 Introduction 1.1 Just what is LuaLATEX? To answer this question, we need to mention a few details about the TEX world that you may usually ignore: the difference between an engine and a format. An engine is an actual computer program, while a format is a set of macros executed by an engine, usually preloaded when the engine is invoked with a particular name.
    [Show full text]
  • LUATEX 0.60 P Taco Hoekwater, Hartmut Henkel Cahiers Gutenberg, N 56 (2011), P
    Cahiers O m LUATEX 0.60 P Taco Hoekwater, Hartmut Henkel Cahiers GUTenberg, nO 56 (2011), p. 127-133. <http://cahiers.gutenberg.eu.org/fitem?id=CG_2011___56_127_0> © Association GUTenberg, 2011, tous droits réservés. L’accès aux articles des Cahiers GUTenberg (http://cahiers.gutenberg.eu.org/), implique l’accord avec les conditions générales d’utilisation (http://cahiers.gutenberg.eu.org/legal.html). Toute utilisation commerciale ou impression systématique est constitutive d’une infraction pénale. Toute copie ou impression de ce fichier doit contenir la présente mention de copyright. LuaTEX 0.60 Taco Hoekwater, Hartmut Henkel Abstract:TEXLive 2010 will contain LuaTEX 0.60. This article gives an overview of the changes between this version and the version on last year’s TEXLive. Highlights of this release: cweb code base, dynamic loading of lua modules, various font subsystem improvements including support for Apple .dfont, font collection files, braced input file names, extended pdf Lua table, and access to the line breaking algorithm from Lua code. Key words: Lua, LuaTEX, verze 0.60 Abstrakt: Článek představuje změny a novinky ve verzi LuaTEXu 0.60. Klíčová slova: programovací jazyk Lua, LuaTEX, verze 0.60 References [1] LuaTEX Available at URL: http://www.luatex.org/ [2] The Programming Language Lua. Home page. Available at URL: http://www.lua.org/ taco (at) elvenkind (dot) com Elvenkind BV, Spuiboulevard 269, 3311 GP Dordrecht, The Netherlands doi: 10.5300/2011-2-4/127 127 72 72 72 General changes Some of the changes can be organised into sections, but not all. So first, here are the changes that are more or less standalone.
    [Show full text]
  • Using Plain TEX TUG 2009 Although We Use Context for Testing We Also Need to Check Basic Behaviour with a Minimal Macro Set and Bare Definitions
    LuaTEX using plain TEX TUG 2009 Although we use ConTEXt for testing we also need to check basic behaviour with a minimal macro set and bare definitions. Most tests with plain TEX are done with no additional code loaded (like running the TEXbook). It can be handy to check at least basic OpenType font support in plain TEX. And using mplib in its simple form also makes sense. Why We don't touch the plain TEX format. Format generation happens via luatex-plain.tex. There some code is hooked into \everyjob so that a few extra files are loaded. Additional font support uses files from the ConTEXt distribution but fancy features are not available. Also MetaPost library support is loaded, but again with no fancy extensions. In order not to get burdened by ConTEXt beta versions, all font related code can be loaded from a merge file. Principles As there is no high level font interface, the input method is similar to X TE EX but we also support location prefixes (file: and name:) and have a few more keys. Fonts can be loaded in base mode in which case TEX's traditional mechanisms for ligature building and kerning are used. We can also use node mode where we use Lua instead. This is needed when we use more complex OpenType features. We do support OpenType math fonts but keep in mind that plain has its own font model and math setup as it's not an all-purpose macro package. Fonts The extensions are loaded as follows: \input plain \directlua {tex.enableprimitives('', tex.extraprimitives())} \pdfoutput=1 \everyjob \expandafter {% \the\everyjob \input luatex-basics\relax \input luatex-fonts\relax \input luatex-mplib\relax } \edef\fmtversion{\fmtversion+luatex} The basics provide a \newattribute macro.
    [Show full text]
  • Connecting Luatex to Mongodb (Arstexnica, Numero 26, 2018)
    Connecting LuaTEX to MongoDB Roberto Giacomelli Abstract primary and foreign key constraint, the not null clause and so on. This paper describes in details a way to connect Secondly, the valuable advantage is that avoiding LuaT X to a MongoDB database server. As a con- E intermediate layer between data and T X means sequence, the Lua-powered typesetting engine be- E speeding up modifications. comes a candidate, along with other tools, to gen- I have frequently adapted project entity- erate beautiful reports. relationship diagrams whenever improvements From local-wide project to large web ap- were (e.g., the addition of a complex set of eco- plications, MongoDB—the popular NoSQL nomic information). So, I learned a lot about how database—creates a new point of view on datasets to translate real world entities into conceptual SQL also adopted by LuaT X. This could extend the E models, trying to keep minimalism in mind as much development perspectives. as possible. Changes were easy to apply but, after six years Sommario of development, things are no longer so easy to Questo articolo descrive in dettaglio un modo per keep up-to-date despite the success of the project. connettere LuaTEX a un database server Mon- After all, the world is constantly changing. And goDB, dimostrando come il motore di composi- I consider more important finding out database zione dotato dell’interprete Lua possa candidarsi, systems to allow a better data representation than insieme ad altri strumenti, a generare bellissimi incrementing data bandwidth as fast as hardware report. potentially could do. In other words, I’m looking Dal piccolo progetto alle grandi applicazioni web, for more natural criteria to model a reality in rapid MongoDB — il noto database di tipo NoSQL — and unpredictable evolution.
    [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]
  • TEX: a Branch in Desktop Publishing Evolution, Part 2
    HISTORY OF DESKTOP PUBLISHING: BUILDING THE INDUSTRY THEME ARTICLE: HISTORY OF DESKTOP PUBLISHING: BUILDING THE INDUSTRY TEX: A Branch in Desktop Publishing Evolution, Part 2 Donald Knuth began the development of TEX in 1977 and had an initial version running in 1978, with the Barbara Beeton American Mathematical Society aim of typesetting mathematical documents with the Karl Berry highest quality, and with archival reproducibility far TEX Users Group into the future. Its usage spread, and today the TEX David Walden system remains in use by a vibrant user community. However, the world of TEX has always been somewhat out of sync with the commercial desktop publishing systems that began to come out in the mid-1980s and are now ubiquitous in the worlds of publishing and printing. Part 1 of this history (Annals vol. 40, no. 3) was about the creation of TEX at Stanford and how it began to spread. This part is about (a) the expansion of TEX-based and TEX-related technology, and development of a worldwide community of TEX users and developers following the lead of Knuth’s original collaboration model, and (b) the impact TEX has had on the broader world. In Part 1 we were primarily talking about TEX as developed by Knuth. In Part 2 we sometimes speak of (LA)TEX, meaning TEX or LATEX but mostly LATEX. We also often say TEX when we mean TEX and everything that has been built on top of and around TEX; we hope the distinction between the TEX program itself and these extended meanings is clear from the context.
    [Show full text]
  • The Ucharcat Package∗
    The ucharcat Package∗ David Carlisle November 19, 2015 1 Introduction The 2015 release of XeTEX introduced a new command \Ucharcat, this is an extension of the \Uchar comand that has been available in XeTEX and luaTEX for some time. It takes a second integer value, that specifies the category code of the token to be produced. This allows character tokens to be constructed via expansion, which has many potential uses in producing expandable case changing, numeric counter represntations, etc. \Uchar 65 12 produces a catcode 12 A for example. This package provides a lua implementation of \Ucharcat for use with luatex, it silently accepts XeTEX and does nothing in that case if \Ucharcat is defined. The main difference between the lua implementation and the XeTEX primitive is that the lua implementation takes two expansions to produce the token. \edef\tmp{\Uchar 65 11 } is the same as \def\tmp{A} with both systems but \expandafter\def\expandafter\tmp\expandafter{\Uchar 65 11 } the same as \def\tmp{A} with XeTEX, but in luaTEX it is equivalent to \def\tmp{\directlua{UcharcatLua() 65 11 } 2 Examples This section will be omitted if this document is not processed with a suitable format. ∗This file has version number v0.03, last revised 2015/11/19. Please report any issues at https://github.com/davidcarlisle/dpctex/issues 1 • \Ucharcat 65 11 A is a capital A. • \Ucharcat 65 12 This is a catcode 12 A: yes. • \Ucharcat 65 1 and \Ucharcat 65 2 Bold is grouped by catcode 1 and 2 A. 3 Implementation Note that the current implementation uses \directlua and a dedicated lu- atex catcode array.
    [Show full text]
  • Latex2e News Issue 31
    LATEX News Issue 31, February 2020 Contents The current release has been tested by a number of people, and we have had valuable feedback on a range Experiences with the LATEX -dev formats 1 of the new ideas. This has allowed us to fix issues in several of the new features, as described below. A Concerning this release . (LuaLTEX engine) 1 We wish to thank all the dedicated users who have been trying out the development formats, and we Improved load-times for expl3 1 encourage others to do so. Pre-testing in this way does mean that, for the vast majority of users, problems are Improvements to LATEX font selection: NFSS 2 Extending the shape management in NFSS . 2 solved before they even appear! Extending the font series management in NFSS 2 Concerning this release . (LuaLATEX engine) Font series defaults per document family . 3 Handling of nested emphasis . 3 The new LuaHBTEX engine is LuaTEX with an Providing font family substitutions . 3 embedded HarfBuzz library. HarfBuzz can be used by Providing all text companion symbols by default 3 setting a suitable renderer in the font declaration. A New alias size function for use in .fd files . 4 basic interface for that is provided by fontspec. This Suppress unnecessary font substitution warnings 4 additional font renderer will greatly improve the shaping of various scripts when using LuaLATEX, many of which Other changes to the LATEX kernel 4 are currently handled correctly only by X TE EX, which UTF-8 characters in package descriptions . 4 always uses HarfBuzz. Fix inconsistent hook setting when To simplify testing of the new engine, binaries have loading packages .
    [Show full text]
  • Pdftex Users Manual
    %PDF-1.4 4 0 obj %ÐÔÅØ << 3 0 obj /Type /Font << /Subtype /Type1 /Length 119 /BaseFont /Times-Roman >> /FontDescriptor 8 0 R stream /FirstChar 33 BT /LastChar 116 /F1 9.9626 Tf 72 713.245 Td /Widths 7 0 R [(W)80(elcome)-250(to)-250(pdfT)]TJ /Encoding 6 0 R 67.818 -2.241 Td [(E)]TJ 4.842 >> 2.241 Td [(X!)]TJ endobj ET 5 0 obj endstream << endobj /Type /Pages 2 0 obj /Count 1 << /Kids [2 0 R] /Type /Page >> /Contents 3 0 R endobj /Resources 1 0 R 9 0 obj /MediaBox [0 0 612 792] << /Parent 5 0 R /Type /Catalog >> /Pages 5 0 R endobj >> 1 0 obj endobj << 10 0 obj /Font << /F1 4 0 R >> << /ProcSet [ /PDF /Text ] /Producer (pdfTeX-1.40.22) >> /Creator (TeX) endobj /CreationDate 7 0 obj (D:20210227094347-08’00’) [333 408 500 500 833 778 333 333 /ModDate (D:20210227094347-08’00’) 333 500 564 250 333 250 278 500 /Trapped /False 500 500 500 500 500 500 500 500 /PTEX.Fullbanner (This is pdfTeX, 500 278 278 564 564 564 444 921 Version 3.141592653-2.6-1.40.22 722 667 667 722 611 556 722 722 (TeX Live 2021) kpathsea version 333 389 722 611 889 722 722 556 722 6.3.3) 667 556 611 722 722 944 722 722 611 >> X user manual 333 278 333 469 500 333 444 500 444 endobj 500 444 333 500 500 278 278 500 278 xref 778 500 500 500 500 333 389 278] 0 11 E endobj 0000000000 65535 f 8 0 obj 0000000296 00000 n << 0000000192 00000 n /Type /FontDescriptor 0000000015 00000 n /FontName /Times-Roman 0000001010 00000 n /Flags 2 0000001162 00000 n /FontBBox [0 -216 1000 678] 0000000898 00000 n /Ascent 678 0000000363 00000 n /CapHeight 651 0000000716 00000 n /Descent -216 0000001219 00000 n /ItalicAngle 0 0000001268 00000 n /StemV 83 trailer /XHeight 450 << /Size 11 >> /Root 9 0 R endobj /Info 10 0 R 6 0 obj /ID << [<AFF1F3A60D0EC01BEC9335B601213F77> /Type /Encoding <AFF1F3A60D0EC01BEC9335B601213F77>] /Differences [33/exclam 69/E 84/T >> 87/W/X 99/c/d/e/f 108/l/m 111/o/p startxref 116/t] 1529 >> %%EOF endobj The pdfT The pdfTEX user manual Hàn Thê´ Thành Sebastian Rahtz Hans Hagen Hartmut Henkel Paweł Jackowski Martin Schröder Karl Berry February 18, 2021 Rev.
    [Show full text]
  • The Fontspec Package Font Selection for X LE ATEX and Lualatex
    The fontspec package Font selection for X LE ATEX and LuaLATEX WILL ROBERTSON With contributions by Khaled Hosny, Philipp Gesang, Joseph Wright, and others. http://wspr.io/fontspec/ 2020/02/21 v2.7i Contents I Getting started 5 1 History 5 2 Introduction 5 2.1 Acknowledgements ............................... 5 3 Package loading and options 6 3.1 Font encodings .................................. 6 3.2 Maths fonts adjustments ............................ 6 3.3 Configuration .................................. 6 3.4 Warnings ..................................... 6 4 Interaction with LATEX 2ε and other packages 7 4.1 Commands for old-style and lining numbers ................. 7 4.2 Italic small caps ................................. 7 4.3 Emphasis and nested emphasis ......................... 7 4.4 Strong emphasis ................................. 7 II General font selection 8 1 Main commands 8 2 Font selection 9 2.1 By font name ................................... 9 2.2 By file name ................................... 10 2.3 By custom file name using a .fontspec file . 11 2.4 Querying whether a font ‘exists’ ........................ 12 1 3 Commands to select font families 13 4 Commands to select single font faces 13 4.1 More control over font shape selection ..................... 14 4.2 Specifically choosing the NFSS family ...................... 15 4.3 Choosing additional NFSS font faces ....................... 16 4.4 Math(s) fonts ................................... 17 5 Miscellaneous font selecting details 18 III Selecting font features 19 1 Default settings 19 2 Working with the currently selected features 20 2.1 Priority of feature selection ........................... 21 3 Different features for different font shapes 21 4 Selecting fonts from TrueType Collections (TTC files) 23 5 Different features for different font sizes 23 6 Font independent options 24 6.1 Colour .....................................
    [Show full text]