src.java.com.ctc.wstx.dtd.DTDIdRefAttr Maven / Gradle / Ivy
package com.ctc.wstx.dtd;
import javax.xml.stream.Location;
import org.codehaus.stax2.validation.XMLValidationException;
import com.ctc.wstx.cfg.ErrorConsts;
import com.ctc.wstx.io.WstxInputData;
import com.ctc.wstx.sr.InputProblemReporter;
import com.ctc.wstx.util.WordResolver;
/**
* Attribute class for attributes that contain references
* to elements that have matching identifier specified.
*/
public final class DTDIdRefAttr
extends DTDAttribute
{
/*
///////////////////////////////////////////////////
// Life-cycle
///////////////////////////////////////////////////
*/
/**
* Main constructor.
*/
public DTDIdRefAttr(NameKey name, DefaultAttrValue defValue, int specIndex,
boolean nsAware, boolean xml11)
{
super(name, defValue, specIndex, nsAware, xml11);
}
public DTDAttribute cloneWith(int specIndex)
{
return new DTDIdRefAttr(mName, mDefValue, specIndex, mCfgNsAware, mCfgXml11);
}
/*
///////////////////////////////////////////////////
// Public API
///////////////////////////////////////////////////
*/
public int getValueType() {
return TYPE_IDREF;
}
/*
///////////////////////////////////////////////////
// Public API, validation
///////////////////////////////////////////////////
*/
/**
* Method called by the validator
* to let the attribute do necessary normalization and/or validation
* for the value.
*/
public String validate(DTDValidatorBase v, char[] cbuf, int start, int end, boolean normalize)
throws XMLValidationException
{
/* Let's skip leading/trailing white space, even if we are not
* to normalize visible attribute value. This allows for better
* round-trip handling, but still allow validation.
*/
while (start < end && WstxInputData.isSpaceChar(cbuf[start])) {
++start;
}
if (start >= end) { // empty (all white space) value?
return reportValidationProblem(v, "Empty IDREF value");
}
--end; // so that it now points to the last char
while (end > start && WstxInputData.isSpaceChar(cbuf[end])) {
--end;
}
// Ok, need to check char validity, and also calc hash code:
char c = cbuf[start];
if (!WstxInputData.isNameStartChar(c, mCfgNsAware, mCfgXml11)) {
return reportInvalidChar(v, c, "not valid as the first IDREF character");
}
int hash = (int) c;
for (int i = start+1; i <= end; ++i) {
c = cbuf[i];
if (!WstxInputData.isNameChar(c, mCfgNsAware, mCfgXml11)) {
return reportInvalidChar(v, c, "not valid as an IDREF character");
}
hash = (hash * 31) + (int) c;
}
// Ok, let's check and update id ref list...
ElementIdMap m = v.getIdMap();
Location loc = v.getLocation();
ElementId id = m.addReferenced(cbuf, start, (end - start + 1), hash,
loc, v.getElemName(), mName);
// and that's all; no more checks needed here
return normalize ? id.getId() : null;
}
/**
* Method called by the validator
* to ask attribute to verify that the default it has (if any) is
* valid for such type.
*/
public void validateDefault(InputProblemReporter rep, boolean normalize)
throws XMLValidationException
{
String def = validateDefaultName(rep, normalize);
if (normalize) {
mDefValue.setValue(def);
}
}
/*
///////////////////////////////////////////////////
// Internal methods
///////////////////////////////////////////////////
*/
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy