Skip to content

Commit

Permalink
Attempt to clarify the semantics of static options
Browse files Browse the repository at this point in the history
  • Loading branch information
ndw committed May 28, 2024
1 parent 75f7865 commit 0a2faf3
Showing 1 changed file with 28 additions and 9 deletions.
37 changes: 28 additions & 9 deletions xproc/src/main/xml/specification.xml
Original file line number Diff line number Diff line change
Expand Up @@ -3025,15 +3025,34 @@ Variable names are always expressed as
<section xml:id="statics">
<title>Static Options</title>

<para>A <tag>p:option</tag> may be declared “static”; options declared within a <tag>p:library</tag> <rfc2119>must</rfc2119>
be static.</para>
<para><error code="S0109">It is a <glossterm>static error</glossterm> if options that are the direct children of
<tag>p:library</tag> are not declared “static”</error>.</para>
<para>The values of static options are computed during <link linkend="initiating">static
analysis</link>.</para>

<para>XProc defines a single, global scope for static options. Every static option must have exactly one
in-scope declaration.</para>
<para>A <tag>p:option</tag> may be declared “static”; options declared
within a <tag>p:library</tag> <rfc2119>must</rfc2119> be static.
<error code="S0109">It is a <glossterm>static error</glossterm> if
options that are the direct children of <tag>p:library</tag> are not
declared “static”</error>.</para>

<para>The values of static options are computed during
<link linkend="initiating">static analysis</link>. Consequently, expressions which
initialize static options may not refer to the context item, variables, or
other options that are not static.</para>

<para>Every static option must have exactly one in-scope declaration.
<error code="S0088">It is
a <glossterm>static error</glossterm> if the qualified name of a static option
<glossterm baseform="shadow">shadows</glossterm>
the name of another static option.</error></para>

<para>It is not an error if two static options with the same name appear
in different scopes, but it is not good practice. Bear in mind, for
example, that if the implementation provides a mechanism for specifying
default values for static options at compile time, the value provided for
any option must satisfy the type specified on every static option declaration
with that name. Any mechanism for specifying default values for static options
applies equally to options whether they are public or private.</para>

<para>Libraries that define static options, especially private ones, are
encouraged to use namespaces so that collision with the names of options in
the calling pipeline, or other imported libraries are unlikely.</para>
</section>

<section xml:id="varopt-types">
Expand Down

0 comments on commit 0a2faf3

Please sign in to comment.