SubdocumentContext

open class SubdocumentContext(val parent: MutableContext, val subdocument: Subdocument, _fileSystem: FileSystem? = null) : MutableContext, ChildContext<MutableContext>

A context that is the result of a fork from an original parent Context. All properties are inherited from it, but not all, such as libraries, are shared mutably.

This is mainly designed to be forked for subdocuments, where a new context is needed to process them. Each subdocument context shares most properties with its parent context, but maintains its own state for certain aspects like document info.

ScopeContext inherits from this class, and shares the parent's document info instead.

Parameters

parent

context this scope was forked from

subdocument

the subdocument this context is processing

_fileSystem

file system to use in this context. Overrides the attached pipeline's file system if provided

Inheritors

Constructors

Link copied to clipboard
constructor(parent: MutableContext, subdocument: Subdocument, _fileSystem: FileSystem? = null)

Properties

Link copied to clipboard
open override val attachedPipeline: Pipeline?

The pipeline this context is attached to, if it exists. A context can have up to 1 attached pipeline.

Link copied to clipboard
open override val attributes: <Error class: unknown class>
Link copied to clipboard
open override var documentInfo: DocumentInfo

Mutable information about the final document that is being created.

Link copied to clipboard
open override val fileSystem: FileSystem

If a file system is provided during construction, it is used. Otherwise, BaseContext's implementation is used, which retrieves it from attachedPipeline.

Link copied to clipboard
open override val flavor: MarkdownFlavor
Link copied to clipboard
open override val libraries: MutableSet<Library>
Link copied to clipboard
open override val loadableLibraries: <Error class: unknown class>

External libraries that can be loaded by the user into libraries. These libraries are, for instance, fetched from the library directory (--libs option) and can be loaded via the .include {name} function.

Link copied to clipboard
open override val localizationTables: <Error class: unknown class>

Tables that store key-value localization pairs for each supported locale. Each table is identified by a unique name.

Link copied to clipboard

Media storage that contains all the media files that are referenced within the document. For example, if an image node references a local image file "image.png", the local file needs to be exported to the output directory in order for a browser to look it up. This storage is used to keep track of all the media files that may need to be exported.

Link copied to clipboard
open override val options: <Error class: unknown class>

Global properties that affect several behaviors and that can be altered through function calls.

Link copied to clipboard
open override val parent: MutableContext
Link copied to clipboard
open override val subdocument: Subdocument
Link copied to clipboard
open override var subdocumentGraph: <Error class: unknown class>

Directed graph of the subdocuments that are part of the document complex. Each subdocument is a separate document file that can be rendered independently, and is referenced by a link from the main document or another subdocument.

Functions

Link copied to clipboard

Returns a copy of the queue containing registered function calls and clears the original one.

Link copied to clipboard
open override fun fork(): ScopeContext
Link copied to clipboard
open override fun getFunctionByName(name: String): Function<*>?

If no matching function is found among this SubdocumentContext's own libraries, parent's libraries are scanned.

Link copied to clipboard
Link copied to clipboard
open fun lastParentOrNull(predicate: (Context) -> Boolean): Context?
Link copied to clipboard

Loads a loadable library by name and registers it in the context. After a successful load, the library is removed from loadableLibraries and added to libraries, with its Library.onLoad action executed.

Link copied to clipboard
open override fun localize(tableName: String, key: String, locale: Locale): String

Localizes a string to this context's language (the locale set in documentInfo) by looking up a key in a localization table.

Link copied to clipboard
fun Context.localizeOrDefault(tableName: String = STDLIB_LOCALIZATION_TABLE_NAME, key: String): String?

Localizes a key from the stdlib table. If the key is not found in the context's locale, it falls back to the default locale (English).

Link copied to clipboard
fun Context.localizeOrNull(tableName: String = STDLIB_LOCALIZATION_TABLE_NAME, key: String, locale: Locale? = null): String?

Localizes a key from a table.

Link copied to clipboard

Performs an action locking the enqueuing of function calls. This causes register to do nothing until the action is completed. Any function call enqueued during the action is discarded and won't be expanded by the pipeline.

Link copied to clipboard
open fun newUuid(): String

Generates a new UUID via ContextOptions.uuidSupplier.

Link copied to clipboard
open fun register(linkDefinition: LinkDefinition)

Registers a new LinkDefinition, which can be later looked up via resolve to produce a concrete link from a reference.

open fun register(functionCall: FunctionCallNode)

Enqueues a new FunctionCallNode, which is executed in the next stage of the pipeline. Nothing happens if enqueuing is locked via lockFunctionCallEnqueuing.

Link copied to clipboard
open override fun resolve(reference: ReferenceLink): LinkNode?

Tries to resolve a reference link to an actual link. If the resolution succeeds, ReferenceLink.onResolve callbacks are executed.

open override fun resolve(call: FunctionCallNode): FunctionCall<*>?
Link copied to clipboard
Link copied to clipboard
Link copied to clipboard