net.sf.saxon.tree.tiny.TinyProcInstImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of saxon-he Show documentation
Show all versions of saxon-he Show documentation
An OSGi bundle for Saxon-HE
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2013 Saxonica Limited.
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
package net.sf.saxon.tree.tiny;
import net.sf.saxon.event.Receiver;
import net.sf.saxon.om.AtomicSequence;
import net.sf.saxon.trans.XPathException;
import net.sf.saxon.tree.util.Navigator;
import net.sf.saxon.type.Type;
import net.sf.saxon.value.StringValue;
/**
* TProcInstImpl is an implementation of ProcInstInfo
* @author Michael H. Kay
* @version 16 July 1999
*/
final class TinyProcInstImpl extends TinyNodeImpl {
public TinyProcInstImpl(TinyTree tree, int nodeNr) {
this.tree = tree;
this.nodeNr = nodeNr;
}
public String getStringValue() {
int start = tree.alpha[nodeNr];
int len = tree.beta[nodeNr];
if (len==0) {
return ""; // need to special-case this for the Microsoft JVM
}
char[] dest = new char[len];
tree.commentBuffer.getChars(start, start+len, dest, 0);
return new String(dest, 0, len);
}
/**
* Get the typed value of this node.
* Returns the string value, as an instance of xs:string
*/
public AtomicSequence atomize() {
return new StringValue(getStringValue());
}
public final int getNodeKind() {
return Type.PROCESSING_INSTRUCTION;
}
/**
* Get the base URI of this processing instruction node.
*/
public String getBaseURI() {
return Navigator.getBaseURI(this);
}
/**
* Copy this node to a given outputter
*/
public void copy(Receiver out, int copyOptions, int locationId) throws XPathException {
out.processingInstruction(getDisplayName(), getStringValue(), 0, 0);
}
// DOM methods
/**
* The target of this processing instruction. XML defines this as being
* the first token following the markup that begins the processing
* instruction.
* @return the "target", or in XDM terms, the name of the processing instruction
*/
public String getTarget() {
return getDisplayName();
}
/**
* The content of this processing instruction. This is from the first non
* white space character after the target to the character immediately
* preceding the ?>
.
* @return the content of the processing instruction (in XDM this is the
* same as its string value)
*/
/*@NotNull*/ public String getData() {
return getStringValue();
}
}