rangeimpl.java

来自「JAVA的一些源码 JAVA2 STANDARD EDITION DEVELO」· Java 代码 · 共 1,767 行 · 第 1/5 页

JAVA
1,767
字号
/* * The Apache Software License, Version 1.1 * * * Copyright (c) 1999-2003 The Apache Software Foundation.  All rights  * reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright *    notice, this list of conditions and the following disclaimer.  * * 2. Redistributions in binary form must reproduce the above copyright *    notice, this list of conditions and the following disclaimer in *    the documentation and/or other materials provided with the *    distribution. * * 3. The end-user documentation included with the redistribution, *    if any, must include the following acknowledgment:   *       "This product includes software developed by the *        Apache Software Foundation (http://www.apache.org/)." *    Alternately, this acknowledgment may appear in the software itself, *    if and wherever such third-party acknowledgments normally appear. * * 4. The names "Xerces" and "Apache Software Foundation" must *    not be used to endorse or promote products derived from this *    software without prior written permission. For written  *    permission, please contact apache@apache.org. * * 5. Products derived from this software may not be called "Apache", *    nor may "Apache" appear in their name, without prior written *    permission of the Apache Software Foundation. * * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * ==================================================================== * * This software consists of voluntary contributions made by many * individuals on behalf of the Apache Software Foundation and was * originally based on software copyright (c) 1999, International * Business Machines, Inc., http://www.apache.org.  For more * information on the Apache Software Foundation, please see * <http://www.apache.org/>. */package com.sun.org.apache.xerces.internal.dom;import java.util.Vector;import org.w3c.dom.CharacterData;import org.w3c.dom.DOMException;import org.w3c.dom.DocumentFragment;import org.w3c.dom.Node;import org.w3c.dom.ranges.Range;import org.w3c.dom.ranges.RangeException;/** The RangeImpl class implements the org.w3c.dom.range.Range interface. *  <p> Please see the API documentation for the interface classes   *  and use the interfaces in your client programs. * * @version $Id: RangeImpl.java,v 1.28 2003/11/02 15:07:58 mrglavas Exp $ */public class RangeImpl  implements Range {        //    // Constants    //        //    // Data    //        DocumentImpl fDocument;    Node fStartContainer;    Node fEndContainer;    int fStartOffset;    int fEndOffset;    boolean fIsCollapsed;       boolean fDetach = false;    Node fInsertNode = null;    Node fDeleteNode = null;    Node fSplitNode = null;            /** The constructor. Clients must use DocumentRange.createRange(),     *  because it registers the Range with the document, so it can      *  be fixed-up.     */    public RangeImpl(DocumentImpl document) {        fDocument = document;        fStartContainer = document;        fEndContainer = document;        fStartOffset = 0;        fEndOffset = 0;        fDetach = false;    }        public Node getStartContainer() {        if ( fDetach ) {            throw new DOMException(                DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        return fStartContainer;    }        public int getStartOffset() {        if ( fDetach ) {            throw new DOMException(                DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        return fStartOffset;    }        public Node getEndContainer() {        if ( fDetach ) {            throw new DOMException(                DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        return fEndContainer;    }        public int getEndOffset() {        if ( fDetach ) {            throw new DOMException(                DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }            return fEndOffset;    }        public boolean getCollapsed() {        if ( fDetach ) {            throw new DOMException(                DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        return (fStartContainer == fEndContainer              && fStartOffset == fEndOffset);    }        public Node getCommonAncestorContainer() {        if ( fDetach ) {            throw new DOMException(                DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        Vector startV = new Vector();        Node node;        for (node=fStartContainer; node != null;              node=node.getParentNode())         {            startV.addElement(node);        }        Vector endV = new Vector();        for (node=fEndContainer; node != null;              node=node.getParentNode())         {            endV.addElement(node);        }        int s = startV.size()-1;        int e = endV.size()-1;        Object result = null;        while (s>=0 && e>=0) {            if (startV.elementAt(s) == endV.elementAt(e)) {                result = startV.elementAt(s);            } else {                break;            }            --s;            --e;        }        return (Node)result;     }            public void setStart(Node refNode, int offset)                         throws RangeException, DOMException    {    	if( fDetach) {    		throw new DOMException(    		DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        if ( !isLegalContainer(refNode)) {    		throw new RangeExceptionImpl(    		RangeException.INVALID_NODE_TYPE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_NODE_TYPE_ERR", null));        }        if ( fDocument != refNode.getOwnerDocument() && fDocument != refNode) {            throw new DOMException(                DOMException.WRONG_DOCUMENT_ERR,                DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "WRONG_DOCUMENT_ERR", null));        }                checkIndex(refNode, offset);                fStartContainer = refNode;        fStartOffset = offset;    }        public void setEnd(Node refNode, int offset)                       throws RangeException, DOMException    {    	if( fDetach) {    		throw new DOMException(    		DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        if ( !isLegalContainer(refNode)) {    		throw new RangeExceptionImpl(    		RangeException.INVALID_NODE_TYPE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_NODE_TYPE_ERR", null));        }        if ( fDocument != refNode.getOwnerDocument() && fDocument != refNode) {            throw new DOMException(                DOMException.WRONG_DOCUMENT_ERR,                DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "WRONG_DOCUMENT_ERR", null));        }                checkIndex(refNode, offset);                fEndContainer = refNode;        fEndOffset = offset;    }    public void setStartBefore(Node refNode)         throws RangeException     {    	if( fDetach) {    		throw new DOMException(    		DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        if ( !hasLegalRootContainer(refNode) ||            !isLegalContainedNode(refNode) )        {    		throw new RangeExceptionImpl(    		RangeException.INVALID_NODE_TYPE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_NODE_TYPE_ERR", null));        }        if ( fDocument != refNode.getOwnerDocument() && fDocument != refNode) {            throw new DOMException(                DOMException.WRONG_DOCUMENT_ERR,                DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "WRONG_DOCUMENT_ERR", null));        }        fStartContainer = refNode.getParentNode();        int i = 0;        for (Node n = refNode; n!=null; n = n.getPreviousSibling()) {            i++;        }        fStartOffset = i-1;    }        public void setStartAfter(Node refNode)        throws RangeException    {    	if( fDetach) {    		throw new DOMException(    		DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        if ( !hasLegalRootContainer(refNode) ||             !isLegalContainedNode(refNode)) {    		throw new RangeExceptionImpl(    		RangeException.INVALID_NODE_TYPE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_NODE_TYPE_ERR", null));        }        if ( fDocument != refNode.getOwnerDocument() && fDocument != refNode) {            throw new DOMException(                DOMException.WRONG_DOCUMENT_ERR,                DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "WRONG_DOCUMENT_ERR", null));        }        fStartContainer = refNode.getParentNode();        int i = 0;        for (Node n = refNode; n!=null; n = n.getPreviousSibling()) {            i++;        }        fStartOffset = i;    }        public void setEndBefore(Node refNode)        throws RangeException    {    	if( fDetach) {    		throw new DOMException(    		DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        if ( !hasLegalRootContainer(refNode) ||            !isLegalContainedNode(refNode)) {    		throw new RangeExceptionImpl(    		RangeException.INVALID_NODE_TYPE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_NODE_TYPE_ERR", null));        }        if ( fDocument != refNode.getOwnerDocument() && fDocument != refNode) {            throw new DOMException(                DOMException.WRONG_DOCUMENT_ERR,                DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "WRONG_DOCUMENT_ERR", null));        }        fEndContainer = refNode.getParentNode();        int i = 0;        for (Node n = refNode; n!=null; n = n.getPreviousSibling()) {            i++;        }        fEndOffset = i-1;    }                                                public void setEndAfter(Node refNode)        throws RangeException    {    	if( fDetach) {    		throw new DOMException(    		DOMException.INVALID_STATE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_STATE_ERR", null));        }        if ( !hasLegalRootContainer(refNode) ||            !isLegalContainedNode(refNode)) {    		throw new RangeExceptionImpl(    		RangeException.INVALID_NODE_TYPE_ERR,                 DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "INVALID_NODE_TYPE_ERR", null));        }        if ( fDocument != refNode.getOwnerDocument() && fDocument != refNode) {            throw new DOMException(                DOMException.WRONG_DOCUMENT_ERR,                DOMMessageFormatter.formatMessage(DOMMessageFormatter.DOM_DOMAIN, "WRONG_DOCUMENT_ERR", null));        }        fEndContainer = refNode.getParentNode();        int i = 0;        for (Node n = refNode; n!=null; n = n.getPreviousSibling()) {            i++;        }        fEndOffset = i;    }        public void collapse(boolean toStart) {        

⌨️ 快捷键说明

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