43 KiB
None
A value that indicates the absence of any other value.
The none type has exactly one value: {none}
.
When inserted into the document, it is not visible. This is also the value that is produced by empty code blocks. It can be joined with any value, yielding the other value.
Example
Not visible: #none
Auto
A value that indicates a smart default.
The auto type has exactly one value: {auto}
.
Parameters that support the {auto}
value have some smart default or contextual
behaviour. A good example is the text direction parameter.
Setting it to {auto}
lets Typst automatically determine the direction from the
text language.
Boolean
Either {true}
or {false}
.
The boolean type has two values: {true}
and {false}
. It denotes whether
something is active or enabled.
Example
#false \
#true \
#(1 < 2)
Integer
A whole number.
The number can be negative, zero, or positive. As Typst uses 64 bits to store
integers, integers cannot be smaller than {-9223372036854775808}
or larger than
{9223372036854775807}
.
The number can also be specified as hexadecimal, octal, or binary by starting it
with a zero followed by either x
, o
, or b
.
You can convert a value to an integer with the int
function.
Example
#(1 + 2) \
#(2 - 5) \
#(3 + 4 < 8)
#0xff \
#0o10 \
#0b1001
Float
A floating-point number.
A limited-precision representation of a real number. Typst uses 64 bits to store floats. Wherever a float is expected, you can also pass an integer.
You can convert a value to a float with the float
function.
Example
#3.14 \
#1e4 \
#(10 / 4)
Length
A size or distance, possibly expressed with contextual units. Typst supports the following length units:
- Points:
{72pt}
- Millimeters:
{254mm}
- Centimeters:
{2.54cm}
- Inches:
{1in}
- Relative to font size:
{2.5em}
A length has the following fields:
abs
: A length with just the absolute component of the current length (that is, excluding theem
component).em
: The amount ofem
units in this length, as a float.
You can multiply lengths with and divide them by integers and floats.
Example
#rect(width: 20pt)
#rect(width: 2em)
#rect(width: 1in)
#(3em + 5pt).em
#(20pt).em
#(40em + 2pt).abs
#(5em).abs
Methods
pt()
Converts this length to points.
Fails with an error if this length has non-zero em
units (such as 5em + 2pt
instead of just 2pt
). Use the abs
field (such as in (5em + 2pt).abs.pt()
)
to ignore the em
component of the length (thus converting only its absolute
component).
- returns: float
mm()
Converts this length to millimeters.
Fails with an error if this length has non-zero em
units (such as 5em + 2pt
instead of just 2pt
). See the pt
method for more info.
- returns: float
cm()
Converts this length to centimeters.
Fails with an error if this length has non-zero em
units (such as 5em + 2pt
instead of just 2pt
). See the pt
method for more info.
- returns: float
inches()
Converts this length to inches.
Fails with an error if this length has non-zero em
units (such as 5em + 2pt
instead of just 2pt
). See the pt
method for more info.
- returns: float
Angle
An angle describing a rotation. Typst supports the following angular units:
- Degrees:
{180deg}
- Radians:
{3.14rad}
Example
#rotate(10deg)[Hello there!]
Methods
deg()
Converts this angle to degrees.
- returns: float
rad()
Converts this angle to radians.
- returns: float
Ratio
A ratio of a whole.
Written as a number, followed by a percent sign.
Example
#set align(center)
#scale(x: 150%)[
Scaled apart.
]
Relative Length
A length in relation to some known length.
This type is a combination of a length with a ratio. It results from addition and subtraction of a length and a ratio. Wherever a relative length is expected, you can also use a bare length or ratio.
A relative length has the following fields:
length
: Its length component.ratio
: Its ratio component.
Example
#rect(width: 100% - 50pt)
#(100% - 50pt).length
#(100% - 50pt).ratio
Fraction
Defines how the the remaining space in a layout is distributed.
Each fractionally sized element gets space based on the ratio of its fraction to the sum of all fractions.
For more details, also see the h and v functions and the grid function.
Example
Left #h(1fr) Left-ish #h(2fr) Right
Color
A color in a specific color space.
Typst supports:
- sRGB through the
rgb
function - Device CMYK through
cmyk
function - D65 Gray through the
luma
function
Furthermore, Typst provides the following built-in colors:
black
, gray
, silver
, white
, navy
, blue
, aqua
, teal
, eastern
,
purple
, fuchsia
, maroon
, red
, orange
, yellow
, olive
, green
, and
lime
.
Methods
kind()
Returns the constructor function for this color's kind
(rgb
, cmyk
or luma
).
#let color = cmyk(1%, 2%, 3%, 4%)
#(color.kind() == cmyk)
- returns: function
lighten()
Lightens a color.
- amount: ratio (positional, required) The factor to lighten the color by.
- returns: color
darken()
Darkens a color.
- amount: ratio (positional, required) The factor to darken the color by.
- returns: color
negate()
Produces the negative of the color.
- returns: color
hex()
Returns the color's RGB(A) hex representation (such as #ffaa32
or #020304fe
).
The alpha component (last two digits in #020304fe
) is omitted if it is equal
to ff
(255 / 100%).
- returns: string
rgba()
Converts this color to sRGB and returns its components (R, G, B, A) as an array of integers.
- returns: array
cmyk()
Converts this color to Digital CMYK and returns its components (C, M, Y, K) as an array of ratios. Note that this function will throw an error when applied to an rgb color, since its conversion to CMYK is not available.
- returns: array
luma()
If this color was created with luma, returns the integer value used on construction. Otherwise (for rgb and cmyk colors), throws an error.
- returns: integer
Datetime
Represents a date, a time, or a combination of both. Can be created by either
specifying a custom datetime using the datetime
function or
getting the current date with datetime.today
.
Example
#let date = datetime(
year: 2020,
month: 10,
day: 4,
)
#date.display() \
#date.display(
"y:[year repr:last_two]"
)
#let time = datetime(
hour: 18,
minute: 2,
second: 23,
)
#time.display() \
#time.display(
"h:[hour repr:12][period]"
)
Format
You can specify a customized formatting using the
display
method. The format of a datetime is
specified by providing components with a specified number of modifiers. A
component represents a certain part of the datetime that you want to display,
and with the help of modifiers you can define how you want to display that
component. In order to display a component, you wrap the name of the component
in square brackets (e.g. [[year]]
will display the year). In order to add
modifiers, you add a space after the component name followed by the name of the
modifier, a colon and the value of the modifier (e.g. [[month repr:short]]
will display the short representation of the month).
The possible combination of components and their respective modifiers is as follows:
year
: Displays the year of the datetime.padding
: Can be eitherzero
,space
ornone
. Specifies how the year is padded.repr
Can be eitherfull
in which case the full year is displayed orlast_two
in which case only the last two digits are displayed.sign
: Can be eitherautomatic
ormandatory
. Specifies when the sign should be displayed.
month
: Displays the month of the datetime.padding
: Can be eitherzero
,space
ornone
. Specifies how the month is padded.repr
: Can be eithernumerical
,long
orshort
. Specifies if the month should be displayed as a number or a word. Unfortunately, when choosing the word representation, it can currently only display the English version. In the future, it is planned to support localization.
day
: Displays the day of the datetime.padding
: Can be eitherzero
,space
ornone
. Specifies how the day is padded.
week_number
: Displays the week number of the datetime.padding
: Can be eitherzero
,space
ornone
. Specifies how the week number is padded.repr
: Can be eitherISO
,sunday
ormonday
. In the case ofISO
, week numbers are between 1 and 53, while the other ones are between 0 and 53.
weekday
: Displays the weekday of the date.repr
Can be eitherlong
,short
,sunday
ormonday
. In the case oflong
andshort
, the corresponding English name will be displayed (same as for the month, other languages are currently not supported). In the case ofsunday
andmonday
, the numerical value will be displayed (assuming Sunday and Monday as the first day of the week, respectively).one_indexed
: Can be eithertrue
orfalse
. Defines whether the numerical representation of the week starts with 0 or 1.
hour
: Displays the hour of the date.padding
: Can be eitherzero
,space
ornone
. Specifies how the hour is padded.repr
: Can be either24
or12
. Changes whether the hour is displayed in the 24-hour or 12-hour format.
period
: The AM/PM part of the hourcase
: Can belower
to display it in lower case andupper
to display it in upper case.
minute
: Displays the minute of the date.padding
: Can be eitherzero
,space
ornone
. Specifies how the minute is padded.
second
: Displays the second of the date.padding
: Can be eitherzero
,space
ornone
. Specifies how the second is padded.
Keep in mind that not always all components can be used. For example, if
you create a new datetime with {datetime(year: 2023, month: 10, day: 13)}
, it
will be stored as a plain date internally, meaning that you cannot use
components such as hour
or minute
, which would only work on datetimes
that have a specified time.
Methods
display()
Displays the datetime in a certain way. Depending on whether you have defined
just a date, a time or both, the default format will be different.
If you specified a date, it will be [[year]-[month]-[day]]
. If you specified a
time, it will be [[hour]:[minute]:[second]]
. In the case of a datetime, it
will be [[year]-[month]-[day] [hour]:[minute]:[second]]
.
- pattern: string (positional) The format used to display the datetime.
- returns: string
year()
Returns the year of the datetime, if it exists. Otherwise, it returns {none}
.
- returns: integer or none
month()
Returns the month of the datetime, if it exists. Otherwise, it returns {none}
.
- returns: integer or none
weekday()
Returns the weekday of the datetime as a number starting with 1 from Monday, if
it exists. Otherwise, it returns {none}
.
- returns: integer or none
day()
Returns the day of the datetime, if it exists. Otherwise, it returns {none}
.
- returns: integer or none
hour()
Returns the hour of the datetime, if it exists. Otherwise, it returns {none}
.
- returns: integer or none
minute()
Returns the minute of the datetime, if it exists. Otherwise, it returns
{none}
.
- returns: integer or none
second()
Returns the second of the datetime, if it exists. Otherwise, it returns
{none}
.
- returns: integer or none
ordinal()
Returns the ordinal (day of the year) of the datetime, if it exists.
Otherwise, it returns {none}
.
- returns: integer or none
Duration
Represents a span of time. Can be created by either specifying a custom
duration using the duration
function or by subtracting two
datetimes.
Example
#let duration = duration(
days: 4,
hours: 2,
minutes: 10,
)
#duration.hours()
Methods
seconds()
Returns the duration in seconds as a floating-point value.
This function returns the total duration represented in seconds as a floating-point number. It does not provide the second component of the duration, but rather gives the overall duration in terms of seconds.
- returns: float
minutes()
Returns the duration in minutes as a floating-point value.
This function returns the total duration represented in minutes as a floating-point number. It does not provide the minute component of the duration, but rather gives the overall duration in terms of minutes.
- returns: float
hours()
Returns the duration in hours as a floating-point value.
This function returns the total duration represented in hours as a floating-point number. It does not provide the hour component of the duration, but rather gives the overall duration in terms of hours.
- returns: float
days()
Returns the duration in days as a floating-point value.
This function returns the total duration represented in days as a floating-point number. It does not provide the day component of the duration, but rather gives the overall duration in terms of days.
- returns: float
weeks()
Returns the duration in weeks as a floating-point value.
This function returns the total duration represented in weeks as a floating-point number. It does not provide the week component of the duration, but rather gives the overall duration in terms of weeks.
- returns: float
Symbol
A Unicode symbol.
Typst defines common symbols so that they can easily be written with standard keyboards. The symbols are defined in modules, from which they can be accessed using field access notation:
- General symbols are defined in the
sym
module - Emoji are defined in the
emoji
module
Moreover, you can define custom symbols with the symbol function.
#sym.arrow.r \
#sym.gt.eq.not \
$gt.eq.not$ \
#emoji.face.halo
Many symbols have different variants, which can be selected by appending the modifiers with dot notation. The order of the modifiers is not relevant. Visit the documentation pages of the symbol modules and click on a symbol to see its available variants.
$arrow.l$ \
$arrow.r$ \
$arrow.t.quad$
Bytes
A sequence of bytes.
This is conceptually similar to an array of integers between
{0}
and {255}
, but represented much more efficiently.
You can convert
- a string or an array of integers to bytes with
the
bytes
function - bytes to a string with the
str
function - bytes to an array of integers with the
array
function
When reading data from a file, you can decide whether to load it as a string or as raw bytes.
#bytes((123, 160, 22, 0)) \
#bytes("Hello 😃")
#let data = read(
"rhino.png",
encoding: none,
)
// Magic bytes.
#array(data.slice(0, 4)) \
#str(data.slice(1, 4))
Methods
len()
The length in bytes.
- returns: integer
at()
Returns the byte at the specified index. Returns the default value if the index is out of bounds or fails with an error if no default value was specified.
- index: integer (positional, required) The index at which to retrieve the byte.
- default: any (named) A default value to return if the index is out of bounds.
- returns: integer or any
slice()
Extract a subslice of the bytes. Fails with an error if the start or index is out of bounds.
- start: integer (positional, required) The start index (inclusive).
- end: integer (positional) The end index (exclusive). If omitted, the whole slice until the end is extracted.
- count: integer (named)
The number of bytes to extract. This is equivalent to passing
start + count
as theend
position. Mutually exclusive withend
. - returns: bytes
String
A sequence of Unicode codepoints.
You can iterate over the grapheme clusters of the string using a
for loop. Grapheme clusters are basically characters but
keep together things that belong together, e.g. multiple codepoints that
together form a flag emoji. Strings can be added with the +
operator,
joined together and multiplied with integers.
Typst provides utility methods for string manipulation. Many of these methods
(e.g., split
, trim
and replace
) operate on patterns: A pattern can be
either a string or a regular expression. This makes the methods
quite versatile.
All lengths and indices are expressed in terms of UTF-8 characters. Indices are zero-based and negative indices wrap around to the end of the string.
You can convert a value to a string with the str
function.
Example
#"hello world!" \
#"\"hello\n world\"!" \
#"1 2 3".split() \
#"1,2;3".split(regex("[,;]")) \
#(regex("\d+") in "ten euros") \
#(regex("\d+") in "10 euros")
Escape sequences
Just like in markup, you can escape a few symbols in strings:
[\\]
for a backslash[\"]
for a quote[\n]
for a newline[\r]
for a carriage return[\t]
for a tab[\u{1f600}]
for a hexadecimal Unicode escape sequence
Methods
len()
The length of the string in UTF-8 encoded bytes.
- returns: integer
first()
Extract the first grapheme cluster of the string. Fails with an error if the string is empty.
- returns: any
last()
Extract the last grapheme cluster of the string. Fails with an error if the string is empty.
- returns: any
at()
Extract the first grapheme cluster after the specified index. Returns the default value if the index is out of bounds or fails with an error if no default value was specified.
- index: integer (positional, required) The byte index.
- default: any (named) A default value to return if the index is out of bounds.
- returns: string or any
slice()
Extract a substring of the string. Fails with an error if the start or end index is out of bounds.
- start: integer (positional, required) The start byte index (inclusive).
- end: integer (positional) The end byte index (exclusive). If omitted, the whole slice until the end of the string is extracted.
- count: integer (named)
The number of bytes to extract. This is equivalent to passing
start + count
as theend
position. Mutually exclusive withend
. - returns: string
clusters()
Returns the grapheme clusters of the string as an array of substrings.
- returns: array
codepoints()
Returns the Unicode codepoints of the string as an array of substrings.
- returns: array
contains()
Whether the string contains the specified pattern.
This method also has dedicated syntax: You can write {"bc" in "abcd"}
instead
of {"abcd".contains("bc")}
.
- pattern: string or regex (positional, required) The pattern to search for.
- returns: boolean
starts-with()
Whether the string starts with the specified pattern.
- pattern: string or regex (positional, required) The pattern the string might start with.
- returns: boolean
ends-with()
Whether the string ends with the specified pattern.
- pattern: string or regex (positional, required) The pattern the string might end with.
- returns: boolean
find()
Searches for the specified pattern in the string and returns the first match
as a string or {none}
if there is no match.
- pattern: string or regex (positional, required) The pattern to search for.
- returns: string or none
position()
Searches for the specified pattern in the string and returns the index of the
first match as an integer or {none}
if there is no match.
- pattern: string or regex (positional, required) The pattern to search for.
- returns: integer or none
match()
Searches for the specified pattern in the string and returns a dictionary
with details about the first match or {none}
if there is no match.
The returned dictionary has the following keys:
start
: The start offset of the matchend
: The end offset of the matchtext
: The text that matched.captures
: An array containing a string for each matched capturing group. The first item of the array contains the first matched capturing, not the whole match! This is empty unless thepattern
was a regex with capturing groups.
- pattern: string or regex (positional, required) The pattern to search for.
- returns: dictionary or none
matches()
Searches for the specified pattern in the string and returns an array of dictionaries with details about all matches. For details about the returned dictionaries, see above.
- pattern: string or regex (positional, required) The pattern to search for.
- returns: array
replace()
Replaces all or a specified number of matches of a pattern with a replacement string and returns the resulting string.
- pattern: string or regex (positional, required) The pattern to search for.
- replacement: string or function (positional, required) The string to replace the matches with or a function that gets a dictionary for each match and can return individual replacement strings.
- count: integer (named)
If given, only the first
count
matches of the pattern are placed. - returns: string
rev()
Reverses the grapheme clusters and returns the resulting string.
- returns: string
trim()
Removes matches of a pattern from one or both sides of the string, once or repeatedly and returns the resulting string.
- pattern: string or regex (positional, required) The pattern to search for.
- at: alignment (named)
Can be
start
orend
to only trim the start or end of the string. If omitted, both sides are trimmed. - repeat: boolean (named)
Whether to repeatedly removes matches of the pattern or just once.
Defaults to
{true}
. - returns: string
split()
Splits a string at matches of a specified pattern and returns an array of the resulting parts.
- pattern: string or regex (positional) The pattern to split at. Defaults to whitespace.
- returns: array
Content
A piece of document content.
This type is at the heart of Typst. All markup you write and most functions you call produce content values. You can create a content value by enclosing markup in square brackets. This is also how you pass content to functions.
Type of *Hello!* is
#type([*Hello!*])
Content can be added with the +
operator,
joined together and multiplied with
integers. Wherever content is expected, you can also pass a
string or {none}
.
Representation
Content consists of elements with fields. When constructing an element with its element function, you provide these fields as arguments and when you have a content value, you can access its fields with field access syntax.
Some fields are required: These must be provided when constructing an element and as a consequence, they are always available through field access on content of that type. Required fields are marked as such in the documentation.
Most fields are optional: Like required fields, they can be passed to the element function to configure them for a single element. However, these can also be configured with set rules to apply them to all elements within a scope. Optional fields are only available with field access syntax when they are were explicitly passed to the element function, not when they result from a set rule.
Each element has a default appearance. However, you can also completely customize its appearance with a show rule. The show rule is passed the element. It can access the element's field and produce arbitrary content from it.
In the web app, you can hover over a content variable to see exactly which
elements the content is composed of and what fields they have. Alternatively,
you can inspect the output of the repr
function.
Methods
func()
The content's element function. This function can be used to create the element contained in this content. It can be used in set and show rules for the element. Can be compared with global functions to check whether you have a specific kind of element.
- returns: function
has()
Whether the content has the specified field.
- field: string (positional, required) The field to look for.
- returns: boolean
at()
Access the specified field on the content. Returns the default value if the field does not exist or fails with an error if no default value was specified.
- field: string (positional, required) The field to access.
- default: any (named) A default value to return if the field does not exist.
- returns: any
fields()
Return the fields of this content.
#rect(
width: 10cm,
height: 10cm,
).fields()
- returns: dictionary
location()
The location of the content. This is only available on content returned by query, for other content it will fail with an error. The resulting location can be used with counters, state and queries.
- returns: location
Array
A sequence of values.
You can construct an array by enclosing a comma-separated sequence of values in parentheses. The values do not have to be of the same type.
You can access and update array items with the .at()
method. Indices are
zero-based and negative indices wrap around to the end of the array. You can
iterate over an array using a for loop.
Arrays can be added together with the +
operator,
joined together and multiplied with
integers.
Note: An array of length one needs a trailing comma, as in {(1,)}
. This is
to disambiguate from a simple parenthesized expressions like {(1 + 2) * 3}
.
An empty array is written as {()}
.
Example
#let values = (1, 7, 4, -3, 2)
#values.at(0) \
#(values.at(0) = 3)
#values.at(-1) \
#values.find(calc.even) \
#values.filter(calc.odd) \
#values.map(calc.abs) \
#values.rev() \
#(1, (2, 3)).flatten() \
#(("A", "B", "C")
.join(", ", last: " and "))
Methods
len()
The number of values in the array.
- returns: integer
first()
Returns the first item in the array. May be used on the left-hand side of an assignment. Fails with an error if the array is empty.
- returns: any
last()
Returns the last item in the array. May be used on the left-hand side of an assignment. Fails with an error if the array is empty.
- returns: any
at()
Returns the item at the specified index in the array. May be used on the left-hand side of an assignment. Returns the default value if the index is out of bounds or fails with an error if no default value was specified.
- index: integer (positional, required) The index at which to retrieve the item.
- default: any (named) A default value to return if the index is out of bounds.
- returns: any
push()
Add a value to the end of the array.
- value: any (positional, required) The value to insert at the end of the array.
pop()
Remove the last item from the array and return it. Fails with an error if the array is empty.
- returns: any The removed last value.
insert()
Insert a value into the array at the specified index. Fails with an error if the index is out of bounds.
- index: integer (positional, required) The index at which to insert the item.
- value: any (positional, required) The value to insert into the array.
remove()
Remove the value at the specified index from the array and return it.
- index: integer (positional, required) The index at which to remove the item.
- returns: any
slice()
Extract a subslice of the array. Fails with an error if the start or index is out of bounds.
- start: integer (positional, required) The start index (inclusive).
- end: integer (positional) The end index (exclusive). If omitted, the whole slice until the end of the array is extracted.
- count: integer (named)
The number of items to extract. This is equivalent to passing
start + count
as theend
position. Mutually exclusive withend
. - returns: array
contains()
Whether the array contains the specified value.
This method also has dedicated syntax: You can write {2 in (1, 2, 3)}
instead
of {(1, 2, 3).contains(2)}
.
- value: any (positional, required) The value to search for.
- returns: boolean
find()
Searches for an item for which the given function returns {true}
and
returns the first match or {none}
if there is no match.
- searcher: function (positional, required) The function to apply to each item. Must return a boolean.
- returns: any or none
position()
Searches for an item for which the given function returns {true}
and
returns the index of the first match or {none}
if there is no match.
- searcher: function (positional, required) The function to apply to each item. Must return a boolean.
- returns: integer or none
filter()
Produces a new array with only the items from the original one for which the given function returns true.
- test: function (positional, required) The function to apply to each item. Must return a boolean.
- returns: array
map()
Produces a new array in which all items from the original one were transformed with the given function.
- mapper: function (positional, required) The function to apply to each item.
- returns: array
enumerate()
Returns a new array with the values alongside their indices.
The returned array consists of (index, value)
pairs in the form of length-2
arrays. These can be destructured with a let binding or
for loop.
- start: integer (named)
The index returned for the first pair of the returned list.
Defaults to
{0}
. - returns: array
zip()
Zips the array with other arrays. If the arrays are of unequal length, it will only zip up until the last element of the shortest array and the remaining elements will be ignored. The return value is an array where each element is yet another array, the size of each of those is the number of zipped arrays.
This method is variadic, meaning that you can zip multiple arrays together at
once: (1, 2, 3).zip((3, 4, 5), (6, 7, 8))
returning:
((1, 3, 6), (2, 4, 7), (3, 5, 8))
.
- others: array (variadic) The other arrays which should be zipped with the current one.
- returns: array
fold()
Folds all items into a single value using an accumulator function.
- init: any (positional, required) The initial value to start with.
- folder: function (positional, required) The folding function. Must have two parameters: One for the accumulated value and one for an item.
- returns: any
sum()
Sums all items (works for any types that can be added).
- default: any (named) What to return if the array is empty. Must be set if the array can be empty.
- returns: any
product()
Calculates the product all items (works for any types that can be multiplied)
- default: any (named) What to return if the array is empty. Must be set if the array can be empty.
- returns: any
any()
Whether the given function returns {true}
for any item in the array.
- test: function (positional, required) The function to apply to each item. Must return a boolean.
- returns: boolean
all()
Whether the given function returns {true}
for all items in the array.
- test: function (positional, required) The function to apply to each item. Must return a boolean.
- returns: boolean
flatten()
Combine all nested arrays into a single flat one.
- returns: array
rev()
Return a new array with the same items, but in reverse order.
- returns: array
join()
Combine all items in the array into one.
- separator: any (positional) A value to insert between each item of the array.
- last: any (named) An alternative separator between the last two items
- returns: any
intersperse()
Returns a new array with a separator placed between adjacent items.
- separator: any (positional) The value to insert between each item of the array.
sorted()
Return a new array with the same items, but sorted.
- key: function (named) If given, applies this function to the elements in the array to determine the keys to sort by.
- returns: array
dedup()
Returns a new array with all duplicate items removed.
Only the first element of each duplicate is kept.
#{
(1, 1, 2, 3, 1).dedup() == (1, 2, 3)
}
- key: function (named) If given, applies this function to the elements in the array to determine the keys to deduplicate by.
- returns: array
Dictionary
A map from string keys to values.
You can construct a dictionary by enclosing comma-separated key: value
pairs
in parentheses. The values do not have to be of the same type. Since empty
parentheses already yield an empty array, you have to use the special (:)
syntax to create an empty dictionary.
A dictionary is conceptually similar to an array, but it is indexed by strings
instead of integers. You can access and create dictionary entries with the
.at()
method. If you know the key statically, you can alternatively use
field access notation (.key
) to access
the value. Dictionaries can be added with the +
operator and
joined together.
To check whether a key is present in the dictionary, use the in
keyword.
You can iterate over the pairs in a dictionary using a for loop. This will iterate in the order the pairs were inserted / declared.
Example
#let dict = (
name: "Typst",
born: 2019,
)
#dict.name \
#(dict.launch = 20)
#dict.len() \
#dict.keys() \
#dict.values() \
#dict.at("born") \
#dict.insert("city", "Berlin ")
#("name" in dict)
Methods
len()
The number of pairs in the dictionary.
- returns: integer
at()
Returns the value associated with the specified key in the dictionary. May be used on the left-hand side of an assignment if the key is already present in the dictionary. Returns the default value if the key is not part of the dictionary or fails with an error if no default value was specified.
- key: string (positional, required) The key at which to retrieve the item.
- default: any (named) A default value to return if the key is not part of the dictionary.
- returns: any
insert()
Insert a new pair into the dictionary and return the value. If the dictionary already contains this key, the value is updated.
- key: string (positional, required) The key of the pair that should be inserted.
- value: any (positional, required) The value of the pair that should be inserted.
keys()
Returns the keys of the dictionary as an array in insertion order.
- returns: array
values()
Returns the values of the dictionary as an array in insertion order.
- returns: array
pairs()
Returns the keys and values of the dictionary as an array of pairs. Each pair is represented as an array of length two.
- returns: array
remove()
Remove a pair from the dictionary by key and return the value.
- key: string (positional, required) The key of the pair that should be removed.
- returns: any
Function
A mapping from argument values to a return value.
You can call a function by writing a comma-separated list of function
arguments enclosed in parentheses directly after the function name.
Additionally, you can pass any number of trailing content blocks arguments to a
function after the normal argument list. If the normal argument list would
become empty, it can be omitted. Typst supports positional and named arguments.
The former are identified by position and type, while the later are written as
name: value
.
Within math mode, function calls have special behaviour. See the math documentation for more details.
Example
// Call a function.
#list([A], [B])
// Named arguments and trailing
// content blocks.
#enum(start: 2)[A][B]
// Version without parentheses.
#list[A][B]
Functions are a fundamental building block of Typst. Typst provides functions for a variety of typesetting tasks. Moreover, the markup you write is backed by functions and all styling happens through functions. This reference lists all available functions and how you can use them. Please also refer to the documentation about set and show rules to learn about additional ways you can work with functions in Typst.
Element functions
Some functions are associated with elements like headings or tables. When called, these create an element of their respective kind. In contrast to normal functions, they can further be used in set rules, show rules, and selectors.
Function scopes
Functions can hold related definitions in their own scope, similar to a
module. Examples of this are
assert.eq
or list.item
. However, this
feature is currently only available for built-in functions.
Defining functions
You can define your own function with a let binding that has a parameter list after the binding's name. The parameter list can contain positional parameters, named parameters with default values and argument sinks. The right-hand side of the binding can be a block or any other expression. It defines the function's return value and can depend on the parameters.
#let alert(body, fill: red) = {
set text(white)
set align(center)
rect(
fill: fill,
inset: 8pt,
radius: 4pt,
[*Warning:\ #body*],
)
}
#alert[
Danger is imminent!
]
#alert(fill: blue)[
KEEP OFF TRACKS
]
Unnamed functions
You can also created an unnamed function without creating a binding by
specifying a parameter list followed by =>
and the function body. If your
function has just one parameter, the parentheses around the parameter list are
optional. Unnamed functions are mainly useful for show rules, but also for
settable properties that take functions like the page function's
footer
property.
#show "once?": it => [#it #it]
once?
Notable fact
In Typst, all functions are pure. This means that for the same arguments, they always return the same result. They cannot "remember" things to produce another value when they are called a second time.
The only exception are built-in methods like
array.push(value)
. These can modify the values they are
called on.
Methods
with()
Returns a new function that has the given arguments pre-applied.
- arguments: any (variadic) The named and positional arguments to apply.
- returns: function
where()
Returns a selector that filters for elements belonging to this function whose fields have the values of the given arguments.
- fields: any (named, variadic) The field values to filter by.
- returns: selector
Arguments
Captured arguments to a function.
Argument Sinks
Like built-in functions, custom functions can also take a variable number of
arguments. You can specify an argument sink which collects all excess
arguments as ..sink
. The resulting sink
value is of the arguments
type. It
exposes methods to access the positional and named arguments.
#let format(title, ..authors) = {
let by = authors
.pos()
.join(", ", last: " and ")
[*#title* \ _Written by #by;_]
}
#format("ArtosFlow", "Jane", "Joe")
Spreading
Inversely to an argument sink, you can spread arguments, arrays and
dictionaries into a function call with the ..spread
operator:
#let array = (2, 3, 5)
#calc.min(..array)
#let dict = (fill: blue)
#text(..dict)[Hello]
Methods
pos()
Returns the captured positional arguments as an array.
- returns: array
named()
Returns the captured named arguments as a dictionary.
- returns: dictionary
Selector
A filter for selecting elements within the document.
You can construct a selector in the following ways:
- you can use an element function
- you can filter for an element function with specific fields
- you can use a string or regular expression
- you can use a
{<label>}
- you can use a
location
- call the
selector
function to convert any of the above types into a selector value and use the methods below to refine it
Selectors are used to apply styling rules to elements. You can also use selectors to query the document for certain types of elements.
Furthermore, you can pass a selector to several of Typst's built-in functions to configure their behaviour. One such example is the outline where it can be used to change which elements are listed within the outline.
Multiple selectors can be combined using the methods shown below. However, not all kinds of selectors are supported in all places, at the moment.
Example
#locate(loc => query(
heading.where(level: 1)
.or(heading.where(level: 2)),
loc,
))
= This will be found
== So will this
=== But this will not.
Methods
or()
Allows combining any of a series of selectors. This is used to select multiple components or components with different properties all at once.
- other: selector (variadic, required) The list of selectors to match on.
and()
Allows combining all of a series of selectors. This is used to check whether a component meets multiple selection rules simultaneously.
- other: selector (variadic, required) The list of selectors to match on.
before()
Returns a modified selector that will only match elements that occur before the first match of the selector argument.
- end: selector (positional, required)
The original selection will end at the first match of
end
. - inclusive: boolean (named)
Whether
end
itself should match or not. This is only relevant if both selectors match the same type of element. Defaults to{true}
.
after()
Returns a modified selector that will only match elements that occur after the first match of the selector argument.
- start: selector (positional, required)
The original selection will start at the first match of
start
. - inclusive: boolean (named)
Whether
start
itself should match or not. This is only relevant if both selectors match the same type of element. Defaults to{true}
.
Module
An evaluated module, either built-in or resulting from a file.
You can access definitions from the module using field access notation and interact with it using the import and include syntaxes.
Example
<<< #import "utils.typ"
<<< #utils.add(2, 5)
<<< #import utils: sub
<<< #sub(1, 4)
>>> #7
>>>
>>> #(-3)