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

📄 textimpl.java

📁 用Java写的面相对象的数据库管理系统
💻 JAVA
字号:
/** * org/ozone-db/xml/dom/TextImpl.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. *  * 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 the textual content (termed  character data) of a {@link * org.w3c.dom.Element} or {@link org.w3c.dom.Attr}. If there is no markup * inside an element's content, the text is contained in a single object * implementing the {@link org.w3c.dom.Text} interface; if there is markup, * it is parsed into a list of elements and {@link org.w3c.dom.Text} nodes * that form the list of children of the element. * <P> * Notes: * <OLl> * <LI>Node type is {@link org.w3c.dom.Node#TEXT_NODE} * <LI>Node does not support childern * <LI>Node name is always "#text" * <LI>One of two nodes that may be added to an attribute * </OL> * * * @version $Revision: 1.13 $ $Date: 2000/10/28 16:55:23 $ * @author <a href="mailto:arkin@trendline.co.il">Assaf Arkin</a> * @see org.w3c.dom.Text * @see CharacterDataImpl */public class TextImpl extends CharacterDataImpl implements TextProxy {        final static long serialVersionUID = 1;            public short getNodeType() {        return TEXT_NODE;    }             public synchronized final Text splitText( int offset ) throws DOMException {        TextProxy next = null;                if (isReadOnly()) {            throw new DOMExceptionImpl( DOMException.NO_MODIFICATION_ALLOWED_ERR );        }         if (offset < 0 || offset > getLength()) {            throw new DOMExceptionImpl( DOMException.INDEX_SIZE_ERR, "Offest is negative or greater than text size." );        }         // Create new Text node, splice the first section and place it in the new        // text node, then add it before this node. Splice the second section and        // place it in the existing node. Note that this Text node might not have        // a parent.        try {            next = (TextProxy)database().createObject( TextImpl.class.getName() );            next.init( _ownerDocument, substringData( 0, offset ) );        } catch (Exception except) {            throw new DOMExceptionImpl( DOMExceptionImpl.PDOM_ERR, except.getMessage() );        }         if (getParentNode() != null) {            getParentNode().insertBefore( next, this );        }         setData( substringData( offset, getLength() - offset ) );        return next;    }             public String toString() {        String value;                value = getData();        if (value.length() > 64) {            value = value.substring( 0, 64 ) + "..";        }         value = value.replace( '\n', '|' );        return "Text node: [" + value + "]";    }             public Object clone() {        TextProxy clone = null;        try {            clone = (TextProxy)database().createObject( TextImpl.class.getName() );            clone.init( _ownerDocument, getNodeValue() );            cloneInto( (NodeProxy)clone, true );        } catch (Exception except) {            throw new DOMExceptionImpl( DOMExceptionImpl.PDOM_ERR, except.getMessage() );        }         return clone;    }             public Node cloneNode( boolean deep ) {        TextProxy clone = null;        try {            clone = (TextProxy)database().createObject( TextImpl.class.getName() );            clone.init( _ownerDocument, getNodeValue() );            cloneInto( (NodeProxy)clone, deep );        } catch (Exception except) {            throw new DOMExceptionImpl( DOMExceptionImpl.PDOM_ERR, except.getMessage() );        }         return clone;    }             /**     * Constructor requires only owner document and initial text.     *     * @param owner The owner of this document     * @param text The initial text     */    TextImpl( DocumentImpl owner, String text ) {        super( owner, "#text", text );    }            /**     * Constructor for {@link CDATASectionImpl}.     */    TextImpl( DocumentImpl owner, String name, String text ) {        super( owner, name, text );    }            public TextImpl() {        super();    }            public void init( DocumentProxy owner, String text ) {        super.init( owner, "#text", text );    } }

⌨️ 快捷键说明

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