User Tools

Site Tools


org.gramar.base:index

org.gramar.base

Extension org.gramar.base contains the core set of Gramar tags and functions

Usage and examples

Place a <taglib> element within <taglibs> element in the gramar.config file in the root of your gramar:

  <taglibs>
      <taglib  prefix="c" extension="org.gramar.base" />
  </taglibs>

Tags

The org.gramar.base extension provides the following production markup tags

  • addElement - adds a new child node with a given name to a given node in the model.
  • addTextElement - adds a new child text node with a given name to a given node in the model.
  • choose - provides case-style conditional logic. The choose tag will have nested some number of when tags and possibly an otherwise tag. The first when tag to test true will be resolved to become the processing result of the entire choose tag. If no when tag tests true and an otherwise tag is present, the otherwise tag is resolved to produce the result of the entire choose tag.
  • copyElement - copies an element in a primary or secondary model to anoher location in the same or different model. The copy can be shallow or deep.
  • copyFile - copies a binary file from within the gramar to the output file store..
  • dump - Writes a string representation of the specified node and its children.
  • file - copies a binary file from within the gramar to the output file store.
  • folder - creates a new folder with the given name if that folder does not already exist.
  • flow - Allows for the text flow of the tag's content across several lines of output where each line must have a constant prefix, such as with a Javadoc comment.
  • flowContent - scopes the actual content to be flowed. The width attribute specifies the maximum length of each line of flowed text. The template content before the flowContent tag but after the containing flow tag is the prefix to be prepended to each flowed line of text.
  • formatNow - writes the current time using the format specified.
  • get - Resolves to the string representation of the value of an XPath expression
  • if - Evaluates an XPath expression and processes the tag content if the value is true.
  • include - Processes another template in the gramar in-line as resolves to the text content produced by that template.
  • initialCode - Scopes a region of template processing that might be modified by the user after generation and should therefore be kept (not overwritten on subsequent gramar invocations).
  • iterate - Iterates over a collection of nodes.
  • load - parses the content of the tag into a secondary DOM.
  • loadContent - parses the content of the tag into a secondary DOM.
  • log - processes and writes its content to the platform-appropriate console.
  • milliseconds - resolves to the current epoch time in milliseconds.
  • newModel - Creates a new secondary DOM with a single root node. The node is given the specified name and is associated with the given context variable
  • otherwise - provides a “last-resort” case for a containing choose tag. If no when tags in that choose tag test true, the contents of the otherwise tag become the processing result of the choose tag.
  • project - creates a new project with the given name if that project does not already exist.
  • RemoveElement - Removes a node from the model.
  • set - Sets the value of an attribute on a given node to the resolved content of the tag.
  • setUsingNext - Set's an attribute on each of a set of nodes using an XPath expression sourced by each node's successor node
  • setVariable - Sets a context variable to the resolved value of an XPath expression.
  • stringTokens - Parses a string into tokens and iterates over the tokens.
  • userRegion - scopes a region of template processing that might be modified by the user after generation and should therefore be kept (not overwritten on subsequent gramar invocations).
  • when - acts as a single case clause for a containing choose tag. Within a choose tag's scope, the first when tag to test true will become the processing result of the entire choose tag.

XPath functions

  • camelCase - returns a single-token string from the given text where whitespace has been removed and the first character of each token has been upper-cased
  • cardinality - returns a boolean value depending on whether the cardinality of the collection of nodes is present in the cards string
  • className - returns the class name from a given fully-qualified Java class name
  • isVariableDefined - returns whether the specified variable has an associated value in the Gramar context
  • lowercaseFirst - returns the given string value with the first character appropriately lower-cased
  • lower-case - returns the given string value with every character appropriately lower-cased
  • packageName - returns the package name from a given fully-qualified Java class name
  • singleToken - returns a single-token string from the given text where whitespace has been removed and the first character of each token, except the first, has been uppercased
  • sort - sorts and returns the given collection using the key XPath expression to calculate a sort key for each node in the collection.
  • unique - filters and returns the given collection using the key XPath expression to calculate a key for each node in the collection.
  • uppercaseFirst - returns the given string value with the first character appropriately upper-cased
  • upper-case - returns the given string value with every character appropriately upper-cased

Return to index

org.gramar.base/index.txt · Last modified: 2016/06/27 20:35 (external edit)