com.ctc.wstx.dtd.DTDSubset Maven / Gradle / Ivy
/* Woodstox XML processor
*
* Copyright (c) 2004- Tatu Saloranta, [email protected]
*
* Licensed under the License specified in the file LICENSE which is
* included with the source code.
* You may not use this file except in compliance with the License.
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.ctc.wstx.dtd;
import java.util.*;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.events.NotationDeclaration;
import org.codehaus.stax2.validation.*;
import com.ctc.wstx.ent.EntityDecl;
import com.ctc.wstx.sr.InputProblemReporter;
import com.ctc.wstx.util.PrefixedName;
/**
* This is the abstract base class that implements the standard Stax2
* validation schema base class ({@link XMLValidationSchema}, as well
* as specifies extended Woodstox-specific interface for accessing
* DTD-specific things like entity expansions and notation properties.
*
* API is separated from its implementation to reduce coupling; for example,
* it is possible to have DTD subset implementations that do not implement
* validation logics, just entity expansion.
*/
public abstract class DTDSubset
implements DTDValidationSchema
{
/*
//////////////////////////////////////////////////////
// Life-cycle
//////////////////////////////////////////////////////
*/
protected DTDSubset() { }
/**
* Method that will combine definitions from this internal subset with
* definitions from passed-in external subset, producing a new combined
* DTDSubset instance.
*/
public abstract DTDSubset combineWithExternalSubset(InputProblemReporter rep,
DTDSubset extSubset)
throws XMLStreamException;
/*
//////////////////////////////////////////////////////
// XMLValidationSchema implementation
//////////////////////////////////////////////////////
*/
@Override
public abstract XMLValidator createValidator(ValidationContext ctxt)
throws XMLStreamException;
@Override
public String getSchemaType() {
return XMLValidationSchema.SCHEMA_ID_DTD;
}
/*
//////////////////////////////////////////////////////
// And extended DTDValidationSchema
//////////////////////////////////////////////////////
*/
@Override
public abstract int getEntityCount();
@Override
public abstract int getNotationCount();
/*
//////////////////////////////////////////////////////
// Woodstox-specific API, caching support
//////////////////////////////////////////////////////
*/
public abstract boolean isCachable();
/**
* Method used in determining whether cached external subset instance
* can be used with specified internal subset. If ext. subset references
* any parameter entities int subset (re-)defines, it can not; otherwise
* it can be used.
*
* @return True if this (external) subset refers to a parameter entity
* defined in passed-in internal subset.
*/
public abstract boolean isReusableWith(DTDSubset intSubset);
/*
//////////////////////////////////////////////////////
// Woodstox-specific API, entity/notation handling
//////////////////////////////////////////////////////
*/
public abstract HashMap getGeneralEntityMap();
public abstract List getGeneralEntityList();
public abstract HashMap getParameterEntityMap();
public abstract HashMap getNotationMap();
public abstract List getNotationList();
public abstract HashMap getElementMap();
}