Class Comment

All Implemented Interfaces:
ExportAgent, Locatable, IdentityComparable, Traceable

public final class Comment extends SimpleNodeConstructor
An instruction representing an xsl:comment element in the stylesheet.
  • Constructor Details

    • Comment

      public Comment()
      Construct the instruction
  • Method Details

    • getInstructionNameCode

      public int getInstructionNameCode()
      Get the instruction name, for diagnostics and tracing return the string "xsl:comment"
      Overrides:
      getInstructionNameCode in class Instruction
      Returns:
      a code identifying the instruction: typically but not always the fingerprint of a name in the XSLT namespace
    • getItemType

      public ItemType getItemType()
      Description copied from class: Instruction
      Get the item type of the items returned by evaluating this instruction
      Overrides:
      getItemType in class Instruction
      Returns:
      the static item type of the instruction
    • getCardinality

      public int getCardinality()
      Description copied from class: Expression
      Determine the static cardinality of the expression. This establishes how many items there will be in the result of the expression, at compile time (i.e., without actually evaluating the result.
      Overrides:
      getCardinality in class Expression
      Returns:
      one of the values Cardinality.ONE_OR_MORE, Cardinality.ZERO_OR_MORE, Cardinality.EXACTLY_ONE, Cardinality.ZERO_OR_ONE, Cardinality.EMPTY. This default implementation returns ZERO_OR_MORE (which effectively gives no information).
    • copy

      public Expression copy(RebindingMap rebindings)
      Copy an expression. This makes a deep copy.
      Specified by:
      copy in class Expression
      Parameters:
      rebindings - variables to be re-bound
      Returns:
      the copy of the original expression
    • localTypeCheck

      public void localTypeCheck(ExpressionVisitor visitor, ContextItemStaticInfo contextItemType) throws XPathException
      Description copied from class: SimpleNodeConstructor
      Method to perform type-checking specific to the kind of instruction
      Specified by:
      localTypeCheck in class SimpleNodeConstructor
      Parameters:
      visitor - an expression visitor
      contextItemType - the static type of the context item
      Throws:
      XPathException - if a type error is detected
    • processValue

      public void processValue(UnicodeString value, Outputter output, XPathContext context) throws XPathException
      Process the value of the node, to create the new node.
      Specified by:
      processValue in class SimpleNodeConstructor
      Parameters:
      value - the string value of the new node
      output - the destination for the result
      context - the dynamic evaluation context
      Throws:
      XPathException - if a dynamic error occurs
    • checkContent

      public UnicodeString checkContent(UnicodeString comment, XPathContext context) throws XPathException
      Check the content of the node, and adjust it if necessary
      Overrides:
      checkContent in class SimpleNodeConstructor
      Parameters:
      comment - the supplied content
      context - the dynamic context
      Returns:
      the original content, unless adjustments are needed
      Throws:
      XPathException - if the content is invalid
    • checkContentXSLT

      public static UnicodeString checkContentXSLT(UnicodeString comment)
      Check the content of the comment according to the XSLT rules (which fix it if it is wrong)
      Parameters:
      comment - the proposed text of the comment
      Returns:
      the adjusted text of the comment
    • checkContentXQuery

      public static UnicodeString checkContentXQuery(UnicodeString comment) throws XPathException
      Check the content of the comment according to the XQuery rules (which throw an error if it is wrong)
      Parameters:
      comment - the proposed text of the comment
      Returns:
      the adjusted text of the comment (always the same as the original if there is no error)
      Throws:
      XPathException - if the content is invalid
    • export

      public void export(ExpressionPresenter out) throws XPathException
      Diagnostic print of expression structure. The abstract expression tree is written to the supplied output destination.
      Specified by:
      export in interface ExportAgent
      Specified by:
      export in class Expression
      Parameters:
      out - the expression presenter used to display the structure
      Throws:
      XPathException - if the export fails, for example if an expression is found that won't work in the target environment.
    • getElaborator

      public Elaborator getElaborator()
      Make an elaborator for this expression
      Overrides:
      getElaborator in class Expression
      Returns:
      a suitable elaborator