Save This Page
Home » Xerces-J-src.2.9.1 » org.apache.xerces » impl » dtd » models » [javadoc | source]
org.apache.xerces.impl.dtd.models
public class: DFAContentModel [javadoc | source]
java.lang.Object
   org.apache.xerces.impl.dtd.models.DFAContentModel

All Implemented Interfaces:
    ContentModelValidator

DFAContentModel is the derivative of ContentModel that does all of the non-trivial element content validation. This class does the conversion from the regular expression to the DFA that it then uses in its validation algorithm.

Note: Upstream work insures that this class will never see a content model with PCDATA in it. Any model with PCDATA is 'mixed' and is handled via the MixedContentModel class since mixed models are very constrained in form and easily handled via a special case. This also makes implementation of this class much easier.

Constructor:
 public DFAContentModel(CMNode syntaxTree,
    int leafCount,
    boolean mixed) 
    Constructs a DFA content model.
    Parameters:
    syntaxTree - The syntax tree of the content model.
    leafCount - The number of leaves.
    mixed -
Method from org.apache.xerces.impl.dtd.models.DFAContentModel Summary:
validate
Methods from java.lang.Object:
equals,   getClass,   hashCode,   notify,   notifyAll,   toString,   wait,   wait,   wait
Method from org.apache.xerces.impl.dtd.models.DFAContentModel Detail:
 public int validate(QName[] children,
    int offset,
    int length) 
    Check that the specified content is valid according to this content model. This method can also be called to do 'what if' testing of content models just to see if they would be valid.

    A value of -1 in the children array indicates a PCDATA node. All other indexes will be positive and represent child elements. The count can be zero, since some elements have the EMPTY content model and that must be confirmed.