docs.roxen.comBack to normal mode
DocsRoxenWebServer 5.2Web Developer ManualVariable Tags
Copyright © 2015, Roxen Internet Software
Suggestions, comments & compliments
manuals@roxen.com

<define></define>

Provided by module: Tags: RXML tags

Defines new tags, containers and if-callers. Can also be used to set variable values.

The attributes "tag", "container", "if" and "variable" specifies what is being defined. Exactly one of them are required. See the respective attributes below for further information.


Attributes

variable="name"

Sets the value of the variable to the contents of the container.


tag="name"

Defines a tag with the given name that doesn't take any content. When the defined tag is used, the content of this <define> is RXML parsed and the result is inserted in place of the defined tag. The arguments to the defined tag are available in the current scope in the <define>. An example:
<define tag='my-tag'> <inc variable='var.counter'/> A counter: &var.counter;<br /> The 'foo' argument is: &_.foo;<br /> </define> <my-tag/> <my-tag foo='bar'/>
A counter: 1
The 'foo' argument is:
A counter: 2
The 'foo' argument is: bar


container="name"

Like the 'tag' attribute, but the defined tag may also take content. The unevaluated content is available in &_.contents; inside the <define> (see the scope description below). You can also get the content after RXML evaluation with the <contents> tag - see below for further details.


if="name"

Defines an if-caller that compares something with the contents of the container.


trimwhites

Trim all white space characters from the beginning and the end of the contents.


preparse

Sends the definition through the RXML parser when the <define> is executed instead of when the defined tag is used.

Compatibility notes: If the compatibility level is 2.2 or earlier, the result from the RXML parse is parsed again when the defined tag is used, which can be a potential security problem. Also, if the compatibility level is 2.2 or earlier, the <define> tag does not set up a local scope during the preparse pass, which means that the enclosed code will still use the closest surrounding '_' scope.


&_.args; (provided by Tags: RXML tags)

The full list of the attributes, and their arguments, given to the tag.


&_.contents; (provided by Tags: RXML tags)

The unevaluated contents of the container.


&_.rest-args; (provided by Tags: RXML tags)

A list of the attributes, and their arguments, given to the tag, excluding attributes with default values defined.


<attrib></attrib>

Provided by module: Tags: RXML tags

When defining a tag or a container the tag <attrib> can be used to define default values of the attributes that the tag/container can have. The attrib tag must be the first tag(s) in the define tag.


Attributes

name="name"

The name of the attribute which default value is to be set.


<contents/>

Provided by module: Tags: RXML tags

Inserts the whole or some part of the arguments or the contents passed to the defined tag or container.

The passed contents are RXML evaluated in the first encountered <contents>; the later ones reuses the result of that. (However, if it should be compatible with 2.2 or earlier then it's reevaluated each time unless there's a 'copy-of' or 'value-of' attribute.)

Note that when the preparse attribute is used, this tag is converted to a special variable reference on the form '&_.__contents__n;', which is then substituted with the real value when the defined tag is used. It's that way to make the expansion work when the preparsed code puts it in an attribute value. (This is mostly an internal implementation detail, but it can be good to know since the variable name might show up.)


Attributes

scope="scope"

Associate this <contents> tag with the innermost <define> container with the given scope. The default is to associate it with the innermost <define>.


eval

When this attribute exists, the passed content is (re)evaluated unconditionally before being inserted. Normally the evaluated content from the preceding <contents> tag is reused, and it's only evaluated if this is the first encountered <contents>.


copy-of="expression"

Selects a part of the content node tree to copy. As opposed to the value-of attribute, all the selected nodes are copied, with all markup.

If the result-set attribute is not used then the selected nodes are returned as a string, otherwise they are returned as an array with one node per element (see the result-set attribute for details).

The expression is a simplified variant of an XPath location path: It consists of one or more steps delimited by '/' or '//'. Each step selects some part(s) of the tree starting from the current node. The first step operates on the defined tag or container itself.

A step preceded by '/' is only matched against the immediate children of the node currently selected by the preceding step. A step preceded by '//' is matched against any node in the tree below that node.

Note: An expression cannot begin with '/' or '//'. Use './' or './/' instead.

A step may be any of the following:

  • 'name' selects all elements (i.e. tags or containers) with the given name in the content. The name can be '*' to select all.

  • '@name' selects the element attribute with the given name. The name can be '*' to select all.

  • 'comment()' selects all comments in the content.

  • 'text()' selects all text pieces in the content.

  • 'processing-instruction(name)' selects all processing instructions with the given name in the content. The name may be left out to select all.

  • 'node()' selects all the different sorts of nodes in the content, i.e. the whole content.

  • '.' selects the currently selected element itself.

A step may be followed by '[test]' to filter the selected set in various ways. The test may be any of the following:

  • If test is an integer then the item on that position in the set is selected. The index n may be negative to select an element in reverse order, i.e. -1 selects the last element, -2 the second-to-last, etc.

  • If test is a path on the form described above then that path is evaluated for each node in the selected set, and only the nodes where the path finds a match remain in the set.

    E.g. a test on the form '@name' accepts only elements that have an attribute with the given name.

  • If test is on the form 'path=value' then path is evaluated for each node in the selected set, and only the nodes where at least one path result matches value remain in the set. value is a string literal delimited by either " or '.

    E.g. '@name=value' filters out the elements that have an attribute with the given name and value.

An example: The expression 'p/*[2]/@href' first selects all <p> elements in the content. In the content of each of these, the second element with any name is selected. It's not an error if some of the <p> elements have less than two child elements; those who haven't are simply ignored. Lastly, all 'href' attributes of all those elements are selected. Again it's not an error if some of the elements lack 'href' attributes.

Note that an attribute node is both the name and the value, so in the example above the result might be 'href="index.html"' and not 'index.html'. If you only want the value, use the value-of attribute instead.


value-of="expression"

Selects a part of the content node tree and inserts its text value. As opposed to the copy-of attribute, only the node values are inserted. The expression is the same as for the copy-of attribute.

If the result-set attribute is not used then only the first node value in the selected set is returned, otherwise all values are returned as an array (see the result-set attribute for details).

The text value of an element node is all the text in it and all its subelements, without the elements themselves or any processing instructions.


result-set

Used together with the copy-of or value-of attributes. Add this attribute to make them return the selected nodes or values as a set instead of a plain string.

The result can not be inserted directly into the page in this case, but it can be assigned to a variable and manipulated further, e.g. fed to <emit> to iterate over the elements in the set. An example:

<define container='sort-items'> <set variable='_.item'><contents copy-of='item' result-set=''/></set> <emit source='values' variable='_.item' sort='value'>&_.value;</emit> </define> <sort-items> <item>one</item> <item>two</item> <item>three</item> </sort-items>
<item>one</item><item>three</item><item>two</item>

The set is normally an array (in document order), but if used with copy-of and the expression selects an attribute set then that set is returned as a mapping.