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

📄 textimpl.java

📁 数据仓库工具
💻 JAVA
字号:
/*
    Copyright (C) 2003  Together

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
    License as published by the Free Software Foundation; either
    version 2.1 of the License, or (at your option) any later version.

    This library is distributed in the hope that it will be useful,
    but WITHOUT ANY WARRANTY; without even the implied warranty of
    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
    Lesser General Public License for more details.

    You should have received a copy of the GNU Lesser General Public
    License along with this library; if not, write to the Free Software
    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
*/

package org.enhydra.xml;

import org.w3c.dom.DOMException;
import org.w3c.dom.Node;
import org.w3c.dom.Text;

/**
 * @author Tweety
 *
 * A class representing a node in a meta-data tree, which implements
 * the <a href="../../../../api/org/w3c/dom/Element.html">
 *
 * <p> Namespaces are ignored in this implementation.  The terms "tag
 * name" and "node name" are always considered to be synonymous.
 *
 * @version 1.0
 */
public class TextImpl extends CharacterDataImpl implements Text {


	/**
	 * Constructs a <code>TextImpl</code> from the given node.
	 *
	 * @param node , as a <code>TextImpl</code>.
	 */
	public TextImpl(TextImpl node) {
		super((NodeImpl)node);
	}


	/**
	 * Constructs a <code>TextImpl</code> from the given node value.
	 *
	 * @param value , as a <code>String</code>.
	 */
	public TextImpl(String value) {
		nodeValue = value;
		type = Node.TEXT_NODE;
	}


	/**
	 * Constructs a <code>TextImpl</code> from a given node,
	 * as a <code>Node</code>
	 *
	 * @param node , as <code>Node</code>.
	 */
	public TextImpl(Node node) {
		super(node);
	}


	/**
	 * Returns the node type.
	 *
	 * @return the <code>TEXT_NODE</code> node type.
	 */
    public short getNodeType() {
        return Node.TEXT_NODE;
    }

    /**
	 * Returns the name ("#text") associated with this node.
	 *
	 * @return the name, as a <code>String</code>.
	 */
    public String getNodeName() {
        return "#text";
    }


    /**
	 * Returns the trimed node value associated with this node.
	 *
	 * @return the node value, as a <code>String</code>.
         * @throws DOMException
	 */
	public String getNodeValue() throws DOMException {
//          String nodeVal = nodeValue.trim().replaceAll("&","&amp;");
          String nodeVal = nodeValue.trim();
          return nodeVal;
	}


	/**
	 * Method beginToString for this class writes the value
	 * of this node (text).It should replace all special characters with their escape entitys.
	 *
	 * @param sb string buffer to add resulting string.
	 * @param indent used in formating the output.
	 */
	protected void beginToString(StringBuffer sb, Indent indent) {
          String nodeVal = nodeValue.trim();
          nodeVal = Utils.replaceAll(nodeVal, "&", "&amp;");
          sb.append(nodeVal);
	}

	/**
	 * Method endToString does nothing.
         * @param sb is StringBuffer
         * @param indent is indentation
	 */
	protected void endToString(StringBuffer sb, Indent indent) {
	}


	/**
	 * @see org.w3c.dom.Text#splitText(int)
	 *
     * Break a text node into two sibling nodes.  (Note that if the
     * current node has no parent, they won't wind up as "siblings" --
     * they'll both be orphans.)
     *
     * @param offset The offset at which to split. If offset is at the
     * end of the available data, the second node will be empty.
     *
     * @return A reference to the new node (containing data after the
     * offset point). The original node will contain data up to that
     * point.
     *
     * @throws DOMException(INDEX_SIZE_ERR) if offset is <0 or >length.
     *
     * @throws DOMException (NO_MODIFICATION_ALLOWED_ERR) if node is read-only.
     */
    public Text splitText(int offset)
        throws DOMException {

    	if (offset < 0 || offset > nodeValue.length() ) {
            throw new DOMException(DOMException.INDEX_SIZE_ERR, "Index out of bounds");
        }

        // split text into two separate nodes
    	TextImpl newText = new TextImpl(nodeValue.substring(offset));
    	nodeValue = nodeValue.substring(0, offset);

        // insert new text node
        Node parentNode = getParentNode();
    	if (parentNode != null) {
    		parentNode.insertBefore(newText, nextSibling);
        }

    	return newText;

    }

}

⌨️ 快捷键说明

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