User-Defined Enumerations

From Wiki
Revision as of 22:14, 29 December 2021 by Adityam (talk | contribs) (→‎Examples)
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Sometimes, you might want to enumerate things using a number conversion (that is, the letter or symbol or whatever that "numbers" the item) which isn't one existing ConTeXt enumerations. (For a list of existing conversion, see \convertnumber. For example, Mojca Miklavec pointed out on the mailing list that, in Slovenian, it is traditional to letter things using the Slovenian alphabet, which doesn't quite match the English one. Hans provided this example of how to create a new enumeration in ConTeXt, which defines a "Mojcanian" numbering system, and a conversion based on those numbers:

\def\mojcaniannumber#1%
 {\ifcase#1 \or m\or o\or j\or c\or a\or
            m\or i\or k\or l\or a\or v\or e\or c\else
  \expandafter\mojcaniannumber\expandafter{\the\numexpr#1-13\relax}\fi}

\defineconversion[s][\mojcaniannumber]

(The last line of the definition is a cleverness to repeat the letters over and over as needed; more traditional orderings tend to replace that with a simple - to indicate an out-of-range letter.)

We can test this, using the following code:

\starttext
\startitemize[s,columns,five,packed,broad]
\dorecurse{50}{\item test\endgraf}
\stopitemize
\stoptext

Conversions can also be language-specific. For instance, suppose that we want the default "character" conversion to be Mojcanian numbers when the language is Slovenian. This can be done with the following conversion defintion:

\defineconversion[sl][a][\mojcaniannumber]

We can test this one like so:

\starttext
English:
\startitemize[a,columns,five,packed,broad]
\dorecurse{15}{\item test\endgraf}
\stopitemize

Slovenian:
\language[sl]
\startitemize[a,columns,five,packed,broad]
\dorecurse{15}{\item test\endgraf}
\stopitemize

\stoptext

An alternate way of defining conversions is via a list. This has the advantage of being simpler and clearer to program, but the disadvantage that one can't include clever things like repeating the letters ad infinitum, or doubling them up ("..., x, y, z, aa, ab, ac, ...") as the default character enumerations do. For example:

\defineconversion[s][m, o, j, c, a, m, i, k, l, a, v, e, c]

This produces the following, using an itemize environment much like the previous examples. Notice how, once we run out of letters, the conversion simply produces empty labels.

There are a number of additional examples of conversion definitions in core-con.lua, which is where ConTeXt's default conversions are defined.

Examples

  • Another example of conversion posted by Hans on the mailing list
 \defineconversion[ordinal][\enordinaldaynumber]

 \startitemize[ordinal,2*broad]
 \item test
 \item test
 \item test
 \item test
 \item test
 \stopitemize

\useMPlibrary[txt]
 \startitemize[fuzzy,2*broad]
 \item test
 \item test
 \item test
 \item test
 \item test
 \stopitemize