1 /* 2 * Copyright 2001-2005 (C) MetaStuff, Ltd. All Rights Reserved. 3 * 4 * This software is open source. 5 * See the bottom of this file for the licence. 6 */ 7 8 package org.dom4j.tree; 9 10 import org.dom4j.Element; 11 12 /*** 13 * <p> 14 * <code>DefaultEntity</code> is the default Entity implementation. It is a 15 * doubly linked node which supports the parent relationship and can be modified 16 * in place. 17 * </p> 18 * 19 * @author <a href="mailto:jstrachan@apache.org">James Strachan </a> 20 * @version $Revision: 1.11 $ 21 */ 22 public class DefaultEntity extends FlyweightEntity { 23 /*** The parent of this node */ 24 private Element parent; 25 26 /*** 27 * Creates the <code>Entity</code> with the specified name 28 * 29 * @param name 30 * is the name of the entity 31 */ 32 public DefaultEntity(String name) { 33 super(name); 34 } 35 36 /*** 37 * Creates the <code>Entity</code> with the specified name and text. 38 * 39 * @param name 40 * is the name of the entity 41 * @param text 42 * is the text of the entity 43 */ 44 public DefaultEntity(String name, String text) { 45 super(name, text); 46 } 47 48 /*** 49 * Creates the <code>Entity</code> with the specified name and text. 50 * 51 * @param parent 52 * is the parent element 53 * @param name 54 * is the name of the entity 55 * @param text 56 * is the text of the entity 57 */ 58 public DefaultEntity(Element parent, String name, String text) { 59 super(name, text); 60 this.parent = parent; 61 } 62 63 public void setName(String name) { 64 this.name = name; 65 } 66 67 public void setText(String text) { 68 this.text = text; 69 } 70 71 public Element getParent() { 72 return parent; 73 } 74 75 public void setParent(Element parent) { 76 this.parent = parent; 77 } 78 79 public boolean supportsParent() { 80 return true; 81 } 82 83 public boolean isReadOnly() { 84 return false; 85 } 86 } 87 88 /* 89 * Redistribution and use of this software and associated documentation 90 * ("Software"), with or without modification, are permitted provided that the 91 * following conditions are met: 92 * 93 * 1. Redistributions of source code must retain copyright statements and 94 * notices. Redistributions must also contain a copy of this document. 95 * 96 * 2. Redistributions in binary form must reproduce the above copyright notice, 97 * this list of conditions and the following disclaimer in the documentation 98 * and/or other materials provided with the distribution. 99 * 100 * 3. The name "DOM4J" must not be used to endorse or promote products derived 101 * from this Software without prior written permission of MetaStuff, Ltd. For 102 * written permission, please contact dom4j-info@metastuff.com. 103 * 104 * 4. Products derived from this Software may not be called "DOM4J" nor may 105 * "DOM4J" appear in their names without prior written permission of MetaStuff, 106 * Ltd. DOM4J is a registered trademark of MetaStuff, Ltd. 107 * 108 * 5. Due credit should be given to the DOM4J Project - http://www.dom4j.org 109 * 110 * THIS SOFTWARE IS PROVIDED BY METASTUFF, LTD. AND CONTRIBUTORS ``AS IS'' AND 111 * ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 112 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 113 * ARE DISCLAIMED. IN NO EVENT SHALL METASTUFF, LTD. OR ITS CONTRIBUTORS BE 114 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 115 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 116 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 117 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 118 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) 119 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE 120 * POSSIBILITY OF SUCH DAMAGE. 121 * 122 * Copyright 2001-2005 (C) MetaStuff, Ltd. All Rights Reserved. 123 */