public abstract class StreamScanner extends WstxInputData implements InputProblemReporter, InputConfigFlags, ParsingErrorMsgs
| Modifier and Type | Field and Description | 
|---|---|
| static char | CHAR_CR_LF_OR_NULLLast (highest) char code of the three, LF, CR and NULL | 
| protected static char | CHAR_FIRST_PURE_TEXTCharacter that allows quick check of whether a char can potentially
 be some kind of markup, WRT input stream processing;
 has to contain linefeeds, &, < and > (">" only matters when
 quoting text, as part of "]]>") | 
| protected static char | CHAR_LOWEST_LEGAL_LOCALNAME_CHARFirst character in Unicode (ie one with lowest id) that is legal
 as part of a local name (all valid name chars minus ':'). | 
| static int | INT_CR_LF_OR_NULL | 
| protected Map<String,IntEntity> | mCachedEntitiesCache of internal character entities; | 
| protected boolean | mCfgNsEnabledIf true, Reader is namespace aware, and should do basic checks
 (usually enforcing limitations on having colons in names) | 
| protected boolean | mCfgReplaceEntitiesnote: left non-final on purpose: sub-class may need to modify
 the default value after construction. | 
| protected boolean | mCfgTreatCharRefsAsEntitiesFlag for whether or not character references should be treated as entities | 
| protected ReaderConfig | mConfigCopy of the configuration object passed by the factory. | 
| protected int | mCurrDepthThis is the current depth of the input stack (same as what input
 element stack would return as its depth). | 
| protected EntityDecl | mCurrEntityEntity reference stream currently points to. | 
| protected String | mCurrNameLocal full name for the event, if it has one (note: element events
 do NOT use this variable; those names are stored in element stack):
 target for processing instructions. | 
| protected String | mDocInputEncodingInput stream encoding, if known (passed in, or determined by
 auto-detection); null if not. | 
| protected String | mDocXmlEncodingCharacter encoding from xml declaration, if any; null if no
 declaration, or it didn't specify encoding. | 
| protected int | mDocXmlVersionXML version as declared by the document; one of constants
 from  XmlConsts(likeXmlConsts.XML_V_10). | 
| protected int | mEntityExpansionCountNumber of times a parsed general entity has been expanded; used for
 (optionally) limiting number of expansion to guard against
 denial-of-service attacks like "Billion Laughs". | 
| protected XMLResolver | mEntityResolverCustom resolver used to handle external entities that are to be expanded
 by this reader (external param/general entity expander) | 
| protected WstxInputSource | mInputCurrently active input source; contains link to parent (nesting) input
 sources, if any. | 
| protected int | mInputTopDepth | 
| protected char[] | mNameBufferTemporary buffer used if local name can not be just directly
 constructed from input buffer (name is on a boundary or such). | 
| protected boolean | mNormalizeLFsFlag that indicates whether linefeeds in the input data are to
 be normalized or not. | 
| protected WstxInputSource | mRootInputTop-most input source this reader can use; due to input source
 chaining, this is not necessarily the root of all input; for example,
 external DTD subset reader's root input still has original document
 input as its parent. | 
| protected int | mTokenInputColColumn on input row that current token starts; 0-based (although
 in the end it'll be converted to 1-based) | 
| protected int | mTokenInputRowInput row on which current token starts, 1-based | 
| protected long | mTokenInputTotalTotal number of characters read before start of current token. | 
CHAR_NULL, CHAR_SPACE, INT_NULL, INT_SPACE, MAX_UNICODE_CHAR, mCurrInputProcessed, mCurrInputRow, mCurrInputRowStart, mInputBuffer, mInputEnd, mInputPtr, mXml11CFG_AUTO_CLOSE_INPUT, CFG_CACHE_DTDS, CFG_CACHE_DTDS_BY_PUBLIC_ID, CFG_COALESCE_TEXT, CFG_INTERN_NAMES, CFG_INTERN_NS_URIS, CFG_LAZY_PARSING, CFG_NAMESPACE_AWARE, CFG_NORMALIZE_LFS, CFG_PRESERVE_LOCATION, CFG_REPLACE_ENTITY_REFS, CFG_REPORT_CDATA, CFG_REPORT_PROLOG_WS, CFG_SUPPORT_DTD, CFG_SUPPORT_DTDPP, CFG_SUPPORT_EXTERNAL_ENTITIES, CFG_TREAT_CHAR_REFS_AS_ENTS, CFG_VALIDATE_AGAINST_DTD, CFG_XMLID_TYPING, CFG_XMLID_UNIQ_CHECKSSUFFIX_EOF_EXP_NAME, SUFFIX_IN_ATTR_VALUE, SUFFIX_IN_CDATA, SUFFIX_IN_CLOSE_ELEMENT, SUFFIX_IN_COMMENT, SUFFIX_IN_DEF_ATTR_VALUE, SUFFIX_IN_DOC, SUFFIX_IN_DTD, SUFFIX_IN_DTD_EXTERNAL, SUFFIX_IN_DTD_INTERNAL, SUFFIX_IN_ELEMENT, SUFFIX_IN_ENTITY_REF, SUFFIX_IN_EPILOG, SUFFIX_IN_NAME, SUFFIX_IN_PROC_INSTR, SUFFIX_IN_PROLOG, SUFFIX_IN_TEXT, SUFFIX_IN_XML_DECL| Modifier | Constructor and Description | 
|---|---|
| protected  | StreamScanner(WstxInputSource input,
             ReaderConfig cfg,
             XMLResolver res)Constructor used when creating a complete new (main-level) reader that
 does not share its input buffers or state with another reader. | 
| Modifier and Type | Method and Description | 
|---|---|
| protected void | _reportProblem(XMLReporter rep,
              String probType,
              String msg,
              Location loc) | 
| protected void | _reportProblem(XMLReporter rep,
              org.codehaus.stax2.validation.XMLValidationProblem prob) | 
| protected void | closeAllInput(boolean force) | 
| protected WstxException | constructFromIOE(IOException ioe)Construct and return a  XMLStreamExceptionto throw
 as a result of a failed Typed Access operation (but one not
 caused by a Well-Formedness Constraint or Validation Constraint
 problem) | 
| protected XMLStreamException | constructLimitViolation(String type,
                       long limit) | 
| protected WstxException | constructNullCharException() | 
| protected WstxException | constructWfcException(String msg) | 
| protected boolean | ensureInput(int minAmount)Method called to make sure current main-level input buffer has at
 least specified number of characters available consequtively,
 without having to call  loadMore(). | 
| protected char[] | expandBy50Pct(char[] buf) | 
| protected EntityDecl | expandEntity(String id,
            boolean allowExt,
            Object extraArg)Helper method that will try to expand a parsed entity (parameter or
 generic entity). | 
| protected abstract EntityDecl | findEntity(String id,
          Object arg)Abstract method for sub-classes to implement, for finding
 a declared general or parsed entity. | 
| protected int | fullyResolveEntity(boolean allowExt)Method that does full resolution of an entity reference, be it
 character entity, internal entity or external entity, including
 updating of input buffers, and depending on whether result is
 a character entity (or one of 5 pre-defined entities), returns
 char in question, or null character (code 0) to indicate it had
 to change input source. | 
| WstxInputSource | getCurrentInput()Returns current input source this source uses. | 
| org.codehaus.stax2.XMLStreamLocation2 | getCurrentLocation() | 
| protected EntityDecl | getIntEntity(int ch,
            char[] originalChars)Returns an entity (possibly from cache) for the argument character using the encoded
 representation in mInputBuffer[entityStartPos ... | 
| protected WstxInputLocation | getLastCharLocation()Method that returns location of the last character returned by this
 reader; that is, location "one less" than the currently pointed to
 location. | 
| abstract Location | getLocation()Returns location of last properly parsed token; as per StAX specs,
 apparently needs to be the end of current event, which is the same
 as the start of the following event (or EOF if that's next). | 
| protected char[] | getNameBuffer(int minSize) | 
| protected int | getNext() | 
| protected int | getNextAfterWS()Method that will skip through zero or more white space characters,
 and return either the character following white space, or -1 to
 indicate EOF (end of the outermost input source)/ | 
| protected char | getNextChar(String errorMsg) | 
| protected char | getNextCharAfterWS(String errorMsg) | 
| protected char | getNextCharFromCurrent(String errorMsg)Similar to  getNextChar(java.lang.String), but will not read more characters
 from parent input source(s) if the current input source doesn't
 have more content. | 
| protected char | getNextInCurrAfterWS(String errorMsg) | 
| protected char | getNextInCurrAfterWS(String errorMsg,
                    char c) | 
| protected URL | getSource() | 
| org.codehaus.stax2.XMLStreamLocation2 | getStartLocation() | 
| protected String | getSystemId() | 
| protected abstract void | handleIncompleteEntityProblem(WstxInputSource closing) | 
| protected abstract void | handleUndeclaredEntity(String id)This method gets called if a declaration for an entity was not
 found in entity expanding mode (enabled by default for xml reader,
 always enabled for dtd reader). | 
| protected void | initInputSource(WstxInputSource newInput,
               boolean isExt,
               String entityId)Method called when an entity has been expanded (new input source
 has been created). | 
| protected int | inputInBuffer() | 
| protected boolean | loadMore()Method that will try to read one or more characters from currently
 open input sources; closing input sources if necessary. | 
| protected boolean | loadMore(String errorMsg) | 
| protected boolean | loadMoreFromCurrent() | 
| protected boolean | loadMoreFromCurrent(String errorMsg) | 
| protected void | markLF() | 
| protected void | markLF(int inputPtr) | 
| protected String | parseEntityName(char c) | 
| protected String | parseFNameForError()Method called to read in full name, including unlimited number of
 namespace separators (':'), for the purpose of displaying name in
 an error message. | 
| protected String | parseFullName()Method that will parse 'full' name token; what full means depends on
 whether reader is namespace aware or not. | 
| protected String | parseFullName(char c) | 
| protected String | parseFullName2(int start,
              int hash) | 
| protected String | parseLocalName(char c)Method that will parse name token (roughly equivalent to XML specs;
 although bit lenier for more efficient handling); either uri prefix,
 or local name. | 
| protected String | parseLocalName2(int start,
               int hash)Second part of name token parsing; called when name can continue
 past input buffer end (so only part was read before calling this
 method to read the rest). | 
| protected String | parsePublicId(char quoteChar,
             String errorMsg)Simple parsing method that parses system ids, which are generally
 used in entities (from DOCTYPE declaration to internal/external
 subsets). | 
| protected String | parseSystemId(char quoteChar,
             boolean convertLFs,
             String errorMsg)Simple parsing method that parses system ids, which are generally
 used in entities (from DOCTYPE declaration to internal/external
 subsets). | 
| protected void | parseUntil(TextBuffer tb,
          char endChar,
          boolean convertLFs,
          String errorMsg) | 
| protected int | peekNext()Similar to  getNext(), but does not advance pointer
 in input buffer. | 
| protected void | pushback()Method to push back last character read; can only be called once,
 that is, no more than one char can be guaranteed to be succesfully
 returned. | 
| void | reportProblem(Location loc,
             String probType,
             String format,
             Object arg,
             Object arg2) | 
| void | reportProblem(String probType,
             String format,
             Object arg,
             Object arg2) | 
| void | reportValidationProblem(Location loc,
                       String msg) | 
| void | reportValidationProblem(String msg) | 
| void | reportValidationProblem(String msg,
                       int severity) | 
| void | reportValidationProblem(String format,
                       Object arg,
                       Object arg2) | 
| void | reportValidationProblem(org.codehaus.stax2.validation.XMLValidationProblem prob)
 Note: this is the base implementation used for implementing
  ValidationContext | 
| protected int | resolveCharOnlyEntity(boolean checkStd)Method called to resolve character entities, and only character
 entities (except that pre-defined char entities -- amp, apos, lt,
 gt, quote -- MAY be "char entities" in this sense, depending on
 arguments). | 
| protected EntityDecl | resolveNonCharEntity()Reverse of  resolveCharOnlyEntity(boolean); will only resolve entity
 if it is NOT a character entity (or pre-defined 'generic' entity;
 amp, apos, lt, gt or quot). | 
| protected int | resolveSimpleEntity(boolean checkStd)Method that tries to resolve a character entity, or (if caller so
 specifies), a pre-defined internal entity (lt, gt, amp, apos, quot). | 
| protected boolean | skipCRLF(char c)Method called when a CR has been spotted in input; checks if next
 char is LF, and if so, skips it. | 
| protected int | skipFullName(char c)Note: does not check for number of colons, amongst other things. | 
| protected void | throwFromIOE(IOException ioe) | 
| protected void | throwFromStrE(XMLStreamException strex) | 
| protected void | throwInvalidSpace(int i) | 
| protected WstxException | throwInvalidSpace(int i,
                 boolean deferErrors) | 
| protected void | throwLazyError(Exception e)Method called to report an error, when caller's signature only
 allows runtime exceptions to be thrown. | 
| protected void | throwNullChar() | 
| protected void | throwNullParent(WstxInputSource curr) | 
| void | throwParseError(String msg) | 
| void | throwParseError(String format,
               Object arg,
               Object arg2)Throws generic parse error with specified message and current parsing
 location. | 
| protected void | throwUnexpectedChar(int i,
                   String msg) | 
| protected void | throwUnexpectedEOB(String msg)Similar to  throwUnexpectedEOF(java.lang.String), but only indicates ending
 of an input block. | 
| protected void | throwUnexpectedEOF(String msg) | 
| WstxException | throwWfcException(String msg,
                 boolean deferErrors) | 
| protected String | tokenTypeDesc(int type) | 
| protected void | verifyLimit(String type,
           long maxValue,
           long currentValue) | 
copyBufferStateFrom, findIllegalNameChar, findIllegalNmtokenChar, getCharDesc, isNameChar, isNameChar, isNameStartChar, isNameStartChar, isSpaceCharpublic static final char CHAR_CR_LF_OR_NULL
public static final int INT_CR_LF_OR_NULL
protected static final char CHAR_FIRST_PURE_TEXT
protected static final char CHAR_LOWEST_LEGAL_LOCALNAME_CHAR
protected final ReaderConfig mConfig
protected final boolean mCfgNsEnabled
protected boolean mCfgReplaceEntities
protected String mCurrName
Currently used for proc. instr. target, and entity name (at least when current entity reference is null).
Note: this variable is generally not cleared, since it comes from a symbol table, ie. this won't be the only reference.
protected WstxInputSource mInput
protected final WstxInputSource mRootInput
protected XMLResolver mEntityResolver
protected int mCurrDepth
 Basically this value is compared to mInputTopDepth, which
 indicates what was the depth at the point where the currently active
 input scope/block was started.
protected int mInputTopDepth
protected int mEntityExpansionCount
protected boolean mNormalizeLFs
protected char[] mNameBuffer
protected long mTokenInputTotal
protected int mTokenInputRow
protected int mTokenInputCol
protected String mDocInputEncoding
protected String mDocXmlEncoding
protected int mDocXmlVersion
XmlConsts (like XmlConsts.XML_V_10).protected Map<String,IntEntity> mCachedEntities
protected boolean mCfgTreatCharRefsAsEntities
protected EntityDecl mCurrEntity
protected StreamScanner(WstxInputSource input, ReaderConfig cfg, XMLResolver res)
protected WstxInputLocation getLastCharLocation()
protected URL getSource() throws IOException
IOExceptionprotected String getSystemId()
public abstract Location getLocation()
getLocation in interface InputProblemReporterpublic org.codehaus.stax2.XMLStreamLocation2 getStartLocation()
public org.codehaus.stax2.XMLStreamLocation2 getCurrentLocation()
public WstxException throwWfcException(String msg, boolean deferErrors) throws WstxException
WstxExceptionpublic void throwParseError(String msg) throws XMLStreamException
throwParseError in interface InputProblemReporterXMLStreamExceptionpublic void throwParseError(String format, Object arg, Object arg2) throws XMLStreamException
Note: public access only because core code in other packages needs to access it.
throwParseError in interface InputProblemReporterXMLStreamExceptionpublic void reportProblem(String probType, String format, Object arg, Object arg2) throws XMLStreamException
XMLStreamExceptionpublic void reportProblem(Location loc, String probType, String format, Object arg, Object arg2) throws XMLStreamException
reportProblem in interface InputProblemReporterXMLStreamExceptionprotected void _reportProblem(XMLReporter rep, String probType, String msg, Location loc) throws XMLStreamException
XMLStreamExceptionprotected void _reportProblem(XMLReporter rep, org.codehaus.stax2.validation.XMLValidationProblem prob) throws XMLStreamException
XMLStreamExceptionpublic void reportValidationProblem(org.codehaus.stax2.validation.XMLValidationProblem prob)
                             throws XMLStreamException
 Note: this is the base implementation used for implementing
 ValidationContext
reportValidationProblem in interface InputProblemReporterXMLStreamExceptionpublic void reportValidationProblem(String msg, int severity) throws XMLStreamException
XMLStreamExceptionpublic void reportValidationProblem(String msg) throws XMLStreamException
reportValidationProblem in interface InputProblemReporterXMLStreamExceptionpublic void reportValidationProblem(Location loc, String msg) throws XMLStreamException
XMLStreamExceptionpublic void reportValidationProblem(String format, Object arg, Object arg2) throws XMLStreamException
reportValidationProblem in interface InputProblemReporterXMLStreamExceptionprotected WstxException constructWfcException(String msg)
protected WstxException constructFromIOE(IOException ioe)
XMLStreamException to throw
 as a result of a failed Typed Access operation (but one not
 caused by a Well-Formedness Constraint or Validation Constraint
 problem)protected WstxException constructNullCharException()
protected void throwUnexpectedChar(int i,
                       String msg)
                            throws WstxException
WstxExceptionprotected void throwNullChar()
                      throws WstxException
WstxExceptionprotected void throwInvalidSpace(int i)
                          throws WstxException
WstxExceptionprotected WstxException throwInvalidSpace(int i, boolean deferErrors) throws WstxException
WstxExceptionprotected void throwUnexpectedEOF(String msg) throws WstxException
WstxExceptionprotected void throwUnexpectedEOB(String msg) throws WstxException
throwUnexpectedEOF(java.lang.String), but only indicates ending
 of an input block. Used when reading a token that can not span
 input block boundaries (ie. can not continue past end of an
 entity expansion).WstxExceptionprotected void throwFromIOE(IOException ioe) throws WstxException
WstxExceptionprotected void throwFromStrE(XMLStreamException strex) throws WstxException
WstxExceptionprotected void throwLazyError(Exception e)
protected String tokenTypeDesc(int type)
public final WstxInputSource getCurrentInput()
Note: public only because some implementations are on different package.
protected final int inputInBuffer()
protected final int getNext()
                     throws XMLStreamException
XMLStreamExceptionprotected final int peekNext()
                      throws XMLStreamException
getNext(), but does not advance pointer
 in input buffer.
Note: this method only peeks within current input source; it does not close it and check nested input source (if any). This is necessary when checking keywords, since they can never cross input block boundary.
XMLStreamExceptionprotected final char getNextChar(String errorMsg) throws XMLStreamException
XMLStreamExceptionprotected final char getNextCharFromCurrent(String errorMsg) throws XMLStreamException
getNextChar(java.lang.String), but will not read more characters
 from parent input source(s) if the current input source doesn't
 have more content. This is often needed to prevent "runaway" content,
 such as comments that start in an entity but do not have matching
 close marker inside entity; XML specification specifically states
 such markup is not legal.XMLStreamExceptionprotected final int getNextAfterWS()
                            throws XMLStreamException
XMLStreamExceptionprotected final char getNextCharAfterWS(String errorMsg) throws XMLStreamException
XMLStreamExceptionprotected final char getNextInCurrAfterWS(String errorMsg) throws XMLStreamException
XMLStreamExceptionprotected final char getNextInCurrAfterWS(String errorMsg, char c) throws XMLStreamException
XMLStreamExceptionprotected final boolean skipCRLF(char c)
                          throws XMLStreamException
XMLStreamExceptionprotected final void markLF()
protected final void markLF(int inputPtr)
protected final void pushback()
protected void initInputSource(WstxInputSource newInput, boolean isExt, String entityId) throws XMLStreamException
entityId - Name of the entity being expandedXMLStreamExceptionprotected boolean loadMore()
                    throws XMLStreamException
XMLStreamExceptionprotected final boolean loadMore(String errorMsg) throws XMLStreamException
XMLStreamExceptionprotected boolean loadMoreFromCurrent()
                               throws XMLStreamException
XMLStreamExceptionprotected final boolean loadMoreFromCurrent(String errorMsg) throws XMLStreamException
XMLStreamExceptionprotected boolean ensureInput(int minAmount)
                       throws XMLStreamException
loadMore(). It can only be called
 when input comes from main-level buffer; further, call can shift
 content in input buffer, so caller has to flush any data still
 pending. In short, caller has to know exactly what it's doing. :-)
Note: method does not check for any other input sources than the current one -- if current source can not fulfill the request, a failure is indicated.
XMLStreamExceptionprotected void closeAllInput(boolean force)
                      throws XMLStreamException
XMLStreamExceptionprotected void throwNullParent(WstxInputSource curr)
curr - Input source currently in useprotected int resolveSimpleEntity(boolean checkStd)
                           throws XMLStreamException
Note: On entry we are guaranteed there are at least 3 more characters in this buffer; otherwise we shouldn't be called.
checkStd - If true, will check pre-defined internal entities
   (gt, lt, amp, apos, quot); if false, will only check actual
   character entities.XMLStreamExceptionprotected int resolveCharOnlyEntity(boolean checkStd)
                             throws XMLStreamException
Most often this method is called when reader is not to expand non-char entities automatically, but to return them as separate events.
Main complication here is that we need to do 5-char lookahead. This is problematic if chars are on input buffer boundary. This is ok for the root level input buffer, but not for some nested buffers. However, according to XML specs, such split entities are actually illegal... so we can throw an exception in those cases.
checkStd - If true, will check pre-defined internal entities
   (gt, lt, amp, apos, quot) as character entities; if false, will only
   check actual 'real' character entities.XMLStreamExceptionprotected EntityDecl resolveNonCharEntity() throws XMLStreamException
resolveCharOnlyEntity(boolean); will only resolve entity
 if it is NOT a character entity (or pre-defined 'generic' entity;
 amp, apos, lt, gt or quot). Only used in cases where entities
 are to be separately returned unexpanded (in non-entity-replacing
 mode); which means it's never called from dtd handler.XMLStreamExceptionprotected int fullyResolveEntity(boolean allowExt)
                          throws XMLStreamException
allowExt - If true, is allowed to expand external entities
   (expanding text); if false, is not (expanding attribute value).XMLStreamExceptionprotected EntityDecl getIntEntity(int ch, char[] originalChars)
protected EntityDecl expandEntity(String id, boolean allowExt, Object extraArg) throws XMLStreamException
note: called by sub-classes (dtd parser), needs to be protected.
id - Name of the entity being expandedallowExt - Whether external entities can be expanded or not; if
   not, and the entity to expand would be external one, an exception
   will be thrownXMLStreamExceptionprotected abstract EntityDecl findEntity(String id, Object arg) throws XMLStreamException
id - Identifier of the entity to findarg - Optional argument passed from caller; needed by DTD
    reader.XMLStreamExceptionprotected abstract void handleUndeclaredEntity(String id) throws XMLStreamException
XMLStreamExceptionprotected abstract void handleIncompleteEntityProblem(WstxInputSource closing) throws XMLStreamException
XMLStreamExceptionprotected String parseLocalName(char c) throws XMLStreamException
Much of complexity in this method has to do with the intention to try to avoid any character copies. In this optimal case algorithm would be fairly simple. However, this only works if all data is already in input buffer... if not, copy has to be made halfway through parsing, and that complicates things.
One thing to note is that String returned has been canonicalized and (if necessary) added to symbol table. It can thus be compared against other such (usually id) Strings, with simple equality operator.
c - First character of the name; not yet checked for validityXMLStreamExceptionprotected String parseLocalName2(int start, int hash) throws XMLStreamException
Note that this isn't heavily optimized, on assumption it's not called very often.
XMLStreamExceptionprotected String parseFullName() throws XMLStreamException
 Similar to parseLocalName(char), much of complexity stems from
 trying to avoid copying name characters from input buffer.
 Note that returned String will be canonicalized, similar to
 parseLocalName(char), but without separating prefix/local name.
XMLStreamExceptionprotected String parseFullName(char c) throws XMLStreamException
XMLStreamExceptionprotected String parseFullName2(int start, int hash) throws XMLStreamException
XMLStreamExceptionprotected String parseFNameForError() throws XMLStreamException
XMLStreamExceptionprotected final String parseEntityName(char c) throws XMLStreamException
XMLStreamExceptionprotected int skipFullName(char c)
                    throws XMLStreamException
XMLStreamExceptionprotected final String parseSystemId(char quoteChar, boolean convertLFs, String errorMsg) throws XMLStreamException
 NOTE: returned String is not canonicalized, on assumption that
 external ids may be longish, and are not shared all that often, as
 they are generally just used for resolving paths, if anything.
 Also note that this method is not heavily optimized, as it's not
 likely to be a bottleneck for parsing.
XMLStreamExceptionprotected final String parsePublicId(char quoteChar, String errorMsg) throws XMLStreamException
As per xml specs, the contents are actually normalized.
 NOTE: returned String is not canonicalized, on assumption that
 external ids may be longish, and are not shared all that often, as
 they are generally just used for resolving paths, if anything.
 Also note that this method is not heavily optimized, as it's not
 likely to be a bottleneck for parsing.
XMLStreamExceptionprotected final void parseUntil(TextBuffer tb, char endChar, boolean convertLFs, String errorMsg) throws XMLStreamException
XMLStreamExceptionprotected final char[] getNameBuffer(int minSize)
protected final char[] expandBy50Pct(char[] buf)
protected void verifyLimit(String type, long maxValue, long currentValue) throws XMLStreamException
XMLStreamExceptionprotected XMLStreamException constructLimitViolation(String type, long limit) throws XMLStreamException
XMLStreamExceptionCopyright © 2018 FasterXML. All rights reserved.