|Related Syntax||Related Concepts|
attributes treats the set of all declared attributes of an element as a shelf. The name of the attribute is used as the key, and the value of the attribute is obtained from the value of the item.
To reference the attributes of a specific element, the element can be qualified in all of the same ways as attribute references. The
attributes shelf doesn't really have a name, so aliases are used to identify items in the set of attributes. There is no default current item in a set of attributes, and one must be defined by the programmer with
attributes shelf is indexed as follows:
specifiedqualifier is not given
specifiedqualifier is given
For example, the following output action gives the value of the first attribute declared for the current element, no matter what its name or where its value is specified in a start tag. The following is an error if there are no attributes declared for the currently opened element, or if the first declared attribute doesn't have a specified (or defaulted) value:
In the following output action, however, the value of the first attribute specified in the start tag is output, no matter where it appears in the order of declarations. This action is an error if no attributes are specified in the start tag, even if there are declared attributes and they all have default values.
output specified attributes
has key test to the
attributes shelf determines whether an element has a declared attribute. Note, however, that just because an attribute is declared, it does not necessarily have a value.
The number of attributes declared for an element can be determined by applying
number of to
The following example shows how the
of element element qualifier can be used to refer to an attribute of the currently opened element:
output attribute this-one of element
The following down-translate program uses the attributes shelf to add "id" attributes to elements that can have them:
down-translate global integer id-count element #implied output "<%q" do when attributes has key 'id' do when attribute id is cdata output " id='%q/%d(id-count)'" else output " id='%d(id-count)'" done increment id-count done output ">%c" output "</%q>" when element isnt empty
Using the attribures shelf for normalization
This code fragment illustrates the utility of the
attributes shelf. When used, it will output "normalized" start tags and end tags around the content of the current element, with all specified attribute values included.
This example can be used as a simple but complete OmniMark program that "normalizes" an SGML document. In practice, such a program will also need to:
element #implied output "<%q" repeat over specified attributes as this-attribute output " " || key of attribute this-attribute || "=%"%v(this-attribute)%"" again output ">" _ "%c" output "</%q>" when content isnt (empty | conref)
Attribute tests on items of the "attributes" shelf
Attributes: order of indexing
Copyright © OmniMark Technologies Corporation, 1988-2000.