📄 paramentity.java
字号:
/**
* org/ozone-db/xml/dom/ParamEntity.java
*
* The contents of this file are subject to the OpenXML Public
* License Version 1.0; you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
* http://www.openxml.org/license.html
*
* THIS SOFTWARE IS DISTRIBUTED ON AN "AS IS" BASIS WITHOUT WARRANTY
* OF ANY KIND, EITHER EXPRESSED OR IMPLIED. THE INITIAL DEVELOPER
* AND ALL CONTRIBUTORS SHALL NOT BE LIABLE FOR ANY DAMAGES AS A
* RESULT OF USING, MODIFYING OR DISTRIBUTING THIS SOFTWARE OR ITS
* DERIVATIVES. SEE THE LICENSE FOR THE SPECIFIC LANGUAGE GOVERNING
* RIGHTS AND LIMITATIONS UNDER THE LICENSE.
*
* The Initial Developer of this code under the License is Assaf Arkin.
* Portions created by Assaf Arkin are Copyright (C) 1998, 1999.
* All Rights Reserved.
*/
/**
* Changes for Persistent DOM running with ozone are
* Copyright 1999 by SMB GmbH. All rights reserved.
*/
package org.ozoneDB.xml.dom;
import org.w3c.dom.*;
/**
* Implements a parameter entity.
* <P>
* Notes:
* <OL>
* <LI>Node type is {@link NodeImpl#PARAM_ENTITY_NODE}
* <LI>Node supports childern
* <LI>Node does not have a value
* <LI>Node only accessible from {@link org.w3c.dom.DocumentType}
* </OL>
*
*
* @version $Revision: 1.2 $ $Date: 2003/11/20 23:18:42 $
* @author <a href="mailto:arkin@trendline.co.il">Assaf Arkin</a>
* @see NodeImpl
*/
public class ParamEntity extends NodeImpl implements ParamEntityProxy {
final static long serialVersionUID = 1;
public short getNodeType() {
return PARAM_ENTITY_NODE;
}
public String getPublicId() {
return _publicId;
}
public void setPublicId( String publicId ) {
_publicId = publicId;
}
public String getSystemId() {
return _systemId;
}
public void setSystemId( String systemId ) {
_systemId = systemId;
}
/**
* Returns true if entity is an internal entity. An internal entity is one
* for which a value has been defined. An external entity is one for which
* an external entity has been assigned through either system or public
* identifiers.
*
* @return True if internal entity
*/
public boolean isInternal() {
return _internalValue != null;
}
/**
* Returns the parsing state of this entity.
*
* @return State of entity
*/
public short getState() {
return _state;
}
/**
* Changes the parsing state of this entity. Note that only some changes
* are allowed: from declared to parsing, parsed or not found; from parsing
* to parsed or not found; from not found to declared.
*
* @param newState New state of entity
*/
public void setState( short newState ) {
if (_state == STATE_DECLARED && newState == STATE_PARSING || _state == STATE_NOT_FOUND && newState
== STATE_DECLARED) {
_state = newState;
} else if ((_state == STATE_DECLARED || _state == STATE_PARSING) && (newState == STATE_PARSED || newState
== STATE_NOT_FOUND)) {
_state = newState;
} else {
throw new IllegalStateException( "Cannot switch from state " + _state + " to state " + newState + "." );
}
}
public final String getInternal() {
return _internalValue;
}
public final void setInternal( String internalValue ) {
_internalValue = internalValue;
}
public synchronized boolean equals( Object other ) {
ParamEntityProxy otherX;
// Test for node equality (this covers entity name and all its children)
// and then test for specific entity qualities.
if (super.equals( other )) {
otherX = (ParamEntityProxy)other;
// If this entity is internal, both entities must be internal and have
// equal internal value.
if (this.isInternal()) {
return otherX.isInternal() && this.getInternal().equals( otherX.getInternal() );
}
// External or unparsed: either public id are both null, or public id
// equals in both (and same for system id).
return
(this.getPublicId() == null && otherX.getPublicId() == null || this.getPublicId() != null
&& this.getPublicId().equals( otherX.getPublicId() )) && (this.getSystemId() == null
&& otherX.getSystemId() == null || this.getSystemId() != null && this.getSystemId().equals(
otherX.getSystemId() ));
}
return false;
}
public final Object clone() {
ParamEntityProxy clone = null;
try {
clone = (ParamEntityProxy)database().createObject( ParamEntity.class.getName() );
clone.init( _ownerDocument, getNodeName(), null, true );
cloneInto( clone, true );
} catch (Exception except) {
}
return clone;
}
public final Node cloneNode( boolean deep ) {
ParamEntityProxy clone = null;
try {
clone = (ParamEntityProxy)database().createObject( ParamEntity.class.getName() );
(clone).init( _ownerDocument, getNodeName(), null, true );
cloneInto( clone, deep );
} catch (Exception except) {
}
return clone;
}
public String toString() {
String name;
String value;
name = getNodeName();
if (name.length() > 32) {
name = name.substring( 0, 32 ) + "..";
}
if (isInternal()) {
value = getInternal();
if (value.length() > 64) {
value = value.substring( 0, 64 ) + "..";
}
name = name + "] [" + value;
} else {
if (getSystemId() != null) {
name = name + "] SYSTEM [" + getSystemId();
}
if (getPublicId() != null) {
name = name + "] PUBLIC [" + getPublicId();
}
}
return "PEntity decl: [" + name + "]";
}
public synchronized void cloneInto( NodeProxy into, boolean deep ) {
super.cloneInto( into, deep );
((ParamEntityProxy)into).setSystemId( this.getSystemId() );
((ParamEntityProxy)into).setPublicId( this.getPublicId() );
((ParamEntityProxy)into).setInternal( this.getInternal() );
((ParamEntityProxy)into).setState( this.getState() );
}
/**
* Constructs an external parameter entity. Entity system identifier must be
* provided, public identifier is optional.
*
* @param owner The owner document
* @param name The entity name
* @param systemId The system identifier
* @param publicId The public identifier, if specified
*/
public ParamEntity( DocumentImpl owner, String name, String systemId, String publicId ) {
super( owner, name, null, true );
if (systemId == null) {
throw new NullPointerException( "Argument 'systemId' cannot be null." );
}
_systemId = systemId;
_publicId = publicId;
_state = STATE_DECLARED;
}
/**
* Constructs an internal parameter entity. Entity value must be provided.
*
* @param owner The owner document
* @param name The entity name
* @param internalValue The unparsed entity value
*/
public ParamEntity( DocumentImpl owner, String name, String internalValue ) {
super( owner, name, null, true );
init( owner, name, internalValue );
}
private ParamEntity( DocumentImpl owner, String name ) {
super( owner, name, null, true );
}
public ParamEntity() {
super();
}
public void init( DocumentProxy owner, String name ) {
super.init( owner, name, null, true );
}
public void init( DocumentProxy owner, String name, String value ) {
super.init( owner, name, null, true );
if (value == null) {
throw new NullPointerException( "Argument 'internalValue' cannot be null." );
}
_systemId = null;
_publicId = null;
_state = STATE_DECLARED;
_internalValue = value;
}
public void init( DocumentProxy owner, String name, String systemId, String publicId ) {
}
/**
* The system identifier of this entity, if specified.
*/
private String _systemId;
/**
* The public identifier of this entity, if specified.
*/
private String _publicId;
/**
* Identifies the state of this entity as yet to be parsed, being parsed,
* has been parsed, or cannot be found.
*/
private short _state;
/**
* Holds the internal value of the entity.
*/
private String _internalValue;
/**
* Entity has been declared but not parsed. This is the initial state for
* an entity after it has been declared in the DTD but before it is used
* in the document contents.
*/
public final static short STATE_DECLARED = 0;
/**
* Entity is being parsed. This state designates that the entity is being
* parsed right now. State is used to identify circular references.
*/
public final static short STATE_PARSING = 1;
/**
* Entity has been parsed. This state indicates that entity has been parsed
* and it's parsed contents is contained in its child nodes.
*/
public final static short STATE_PARSED = 2;
/**
* Entity not found. The entity could not be parsed before.
*/
public final static short STATE_NOT_FOUND = 3;
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -