⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 textadapter.java

📁 开源框架
💻 JAVA
字号:
/*
 * $Id: TextAdapter.java,v 1.4 2006/01/29 18:56:55 geoffm74 Exp $
 * $Source: /cvsroot/domify/domify/src/java/org/infohazard/domify/TextAdapter.java,v $
 */

package org.infohazard.domify;

import org.apache.log4j.Category;
import org.w3c.dom.*;

/**
 */
public class TextAdapter extends NodeAdapter implements Text
{
	/** Logging category for log4j. */
	protected static Category log = Category.getInstance(TextAdapter.class.getName());

	/**
	 */
	protected static final char CR = 0x0d;
	protected static final char LF = 0x0a;

	/**
	 */
	protected String wrapped;

	/**
	 */
	protected TextAdapter(String wrapme, Node parent, int ordinal)
	{
		super(parent, ordinal);

		// Convert any instance of CRLF or CR by itself to just LF, as required by
		// the XML specification:  http://www.w3.org/TR/REC-xml#sec-line-ends

		StringBuffer buf = new StringBuffer(wrapme.length());

		boolean ignoreLF = false;

		for (int i=0; i<wrapme.length(); i++)
		{
			char c = wrapme.charAt(i);

			if (c == CR)
			{
				buf.append(LF);
				ignoreLF = true;
			}
			else if (c == LF)
			{
				if (!ignoreLF)
					buf.append(LF);

				ignoreLF = false;
			}
			else
			{
				buf.append(c);

				ignoreLF = false;
			}
		}

		this.wrapped = buf.toString();
	}

	/**
	 */
	public short getNodeType()
	{
		log.debug("getNodeType()");

		return TEXT_NODE;
	}

    public String getBaseURI() {
        throw new UnsupportedOperationException();
    }

    public short compareDocumentPosition(Node other) throws DOMException {
        throw new UnsupportedOperationException();
    }

    public String getTextContent() throws DOMException {
        throw new UnsupportedOperationException();
    }

    public void setTextContent(String textContent) throws DOMException {
        throw new UnsupportedOperationException();
    }

    public boolean isSameNode(Node other) {
        throw new UnsupportedOperationException();
    }

    public String lookupPrefix(String namespaceURI) {
        throw new UnsupportedOperationException();
    }

    public boolean isDefaultNamespace(String namespaceURI) {
        throw new UnsupportedOperationException();
    }

    public String lookupNamespaceURI(String prefix) {
        throw new UnsupportedOperationException();
    }

    public boolean isEqualNode(Node arg) {
        throw new UnsupportedOperationException();
    }

    public Object getFeature(String feature, String version) {
        throw new UnsupportedOperationException();
    }

    public Object setUserData(String key, Object data, UserDataHandler handler) {
        throw new UnsupportedOperationException();
    }

    public Object getUserData(String key) {
        throw new UnsupportedOperationException();
    }

    /**
	 */
	public String getNodeName()
	{
		log.debug("getNodeName()");

		return "#text";
	}

	/**
	 * @return the text of this node; this is the whole point, really.
	 */
	public String getNodeValue() throws DOMException
	{
		log.debug("getNodeValue()");

		return this.wrapped;
	}

	/**
	 * @return the text of this node; this is the whole point, really.
	 */
	public String getData() throws DOMException
	{
		log.debug("getData()");

		return this.wrapped;
	}

	/**
	 * Breaks this node into two nodes at the specified <code>offset</code>,
	 * keeping both in the tree as siblings. After being split, this node
	 * will contain all the content up to the <code>offset</code> point. A
	 * new node of the same type, which contains all the content at and
	 * after the <code>offset</code> point, is returned. If the original
	 * node had a parent node, the new node is inserted as the next sibling
	 * of the original node. When the <code>offset</code> is equal to the
	 * length of this node, the new node has no data.
	 * @param offset The 16-bit unit offset at which to split, starting from
	 *   <code>0</code>.
	 * @return The new node, of the same type as this node.
	 * @exception DOMException
	 *   INDEX_SIZE_ERR: Raised if the specified offset is negative or greater
	 *   than the number of 16-bit units in <code>data</code>.
	 *   <br>NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
	 */
	public Text splitText(int offset)
						  throws DOMException
	{
		throw new UnsupportedOperationException();
	}

    public boolean isElementContentWhitespace() {
        throw new UnsupportedOperationException();
    }

    public String getWholeText() {
        throw new UnsupportedOperationException();
    }

    public Text replaceWholeText(String content) throws DOMException {
        throw new UnsupportedOperationException();
    }

    /**
	 * The character data of the node that implements this interface. The DOM
	 * implementation may not put arbitrary limits on the amount of data
	 * that may be stored in a <code>CharacterData</code> node. However,
	 * implementation limits may mean that the entirety of a node's data may
	 * not fit into a single <code>DOMString</code>. In such cases, the user
	 * may call <code>substringData</code> to retrieve the data in
	 * appropriately sized pieces.
	 * @exception DOMException
	 *   NO_MODIFICATION_ALLOWED_ERR: Raised when the node is readonly.
	 * @exception DOMException
	 *   DOMSTRING_SIZE_ERR: Raised when it would return more characters than
	 *   fit in a <code>DOMString</code> variable on the implementation
	 *   platform.
	 */
	public void setData(String data) throws DOMException
	{
		throw new UnsupportedOperationException();
	}

	/**
	 * The number of 16-bit units that are available through <code>data</code>
	 * and the <code>substringData</code> method below. This may have the
	 * value zero, i.e., <code>CharacterData</code> nodes may be empty.
	 */
	public int getLength()
	{
		throw new UnsupportedOperationException();
	}

	/**
	 * Extracts a range of data from the node.
	 * @param offset Start offset of substring to extract.
	 * @param count The number of 16-bit units to extract.
	 * @return The specified substring. If the sum of <code>offset</code> and
	 *   <code>count</code> exceeds the <code>length</code>, then all 16-bit
	 *   units to the end of the data are returned.
	 * @exception DOMException
	 *   INDEX_SIZE_ERR: Raised if the specified <code>offset</code> is
	 *   negative or greater than the number of 16-bit units in
	 *   <code>data</code>, or if the specified <code>count</code> is
	 *   negative.
	 *   <br>DOMSTRING_SIZE_ERR: Raised if the specified range of text does
	 *   not fit into a <code>DOMString</code>.
	 */
	public String substringData(int offset,
								int count)
								throws DOMException
	{
		throw new UnsupportedOperationException();
	}

	/**
	 * Append the string to the end of the character data of the node. Upon
	 * success, <code>data</code> provides access to the concatenation of
	 * <code>data</code> and the <code>DOMString</code> specified.
	 * @param arg The <code>DOMString</code> to append.
	 * @exception DOMException
	 *   NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
	 */
	public void appendData(String arg)
						   throws DOMException
	{
		throw new UnsupportedOperationException();
	}

	/**
	 * Insert a string at the specified 16-bit unit offset.
	 * @param offset The character offset at which to insert.
	 * @param arg The <code>DOMString</code> to insert.
	 * @exception DOMException
	 *   INDEX_SIZE_ERR: Raised if the specified <code>offset</code> is
	 *   negative or greater than the number of 16-bit units in
	 *   <code>data</code>.
	 *   <br>NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
	 */
	public void insertData(int offset,
						   String arg)
						   throws DOMException
	{
		throw new UnsupportedOperationException();
	}

	/**
	 * Remove a range of 16-bit units from the node. Upon success,
	 * <code>data</code> and <code>length</code> reflect the change.
	 * @param offset The offset from which to start removing.
	 * @param count The number of 16-bit units to delete. If the sum of
	 *   <code>offset</code> and <code>count</code> exceeds
	 *   <code>length</code> then all 16-bit units from <code>offset</code>
	 *   to the end of the data are deleted.
	 * @exception DOMException
	 *   INDEX_SIZE_ERR: Raised if the specified <code>offset</code> is
	 *   negative or greater than the number of 16-bit units in
	 *   <code>data</code>, or if the specified <code>count</code> is
	 *   negative.
	 *   <br>NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
	 */
	public void deleteData(int offset,
						   int count)
						   throws DOMException
	{
		throw new UnsupportedOperationException();
	}

	/**
	 * Replace the characters starting at the specified 16-bit unit offset
	 * with the specified string.
	 * @param offset The offset from which to start replacing.
	 * @param count The number of 16-bit units to replace. If the sum of
	 *   <code>offset</code> and <code>count</code> exceeds
	 *   <code>length</code>, then all 16-bit units to the end of the data
	 *   are replaced; (i.e., the effect is the same as a <code>remove</code>
	 *	method call with the same range, followed by an <code>append</code>
	 *	method invocation).
	 * @param arg The <code>DOMString</code> with which the range must be
	 *   replaced.
	 * @exception DOMException
	 *   INDEX_SIZE_ERR: Raised if the specified <code>offset</code> is
	 *   negative or greater than the number of 16-bit units in
	 *   <code>data</code>, or if the specified <code>count</code> is
	 *   negative.
	 *   <br>NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
	 */
	public void replaceData(int offset,
							int count,
							String arg)
							throws DOMException
	{
		throw new UnsupportedOperationException();
	}

}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -