built-in shelf
A built-in stream that starts out with one item for each entry in every library
rule in the OmniMark program, or in a "-library" file at run-time. The key of each item is a public identifier, and the value of each item is the corresponding system identifier.
The #library
shelf is initialized from the "-library" specifications on the command line only if, somewhere in the OmniMark program, there is some action that initiates SGML or XML parsing (i.e. a do sgml-parse
or do xml-parse
action). If there is no such markup parsing action, the "-library" command-line arguments are ignored. However, if there are any library rules in an OmniMark program, they are always used to initialize the #library
shelf.
The default "current item" of the #library
shelf is the lastmost item, as is the case with programmer-declared shelves.
One of the main uses of the #library
stream is shown by the way the "%epq" and "%epv" format items are interpreted.
If the OmniMark program contains no external-text-entity
rules, any change made to the #library
stream also determines how OmniMark's built-in entity manager interprets public identifiers in referenced external text entities.