org.glassfish.hk2.xml.api.XmlRootHandle Maven / Gradle / Ivy
/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright (c) 2014-2015 Oracle and/or its affiliates. All rights reserved.
*
* The contents of this file are subject to the terms of either the GNU
* General Public License Version 2 only ("GPL") or the Common Development
* and Distribution License("CDDL") (collectively, the "License"). You
* may not use this file except in compliance with the License. You can
* obtain a copy of the License at
* https://glassfish.dev.java.net/public/CDDL+GPL_1_1.html
* or packager/legal/LICENSE.txt. See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each
* file and include the License file at packager/legal/LICENSE.txt.
*
* GPL Classpath Exception:
* Oracle designates this particular file as subject to the "Classpath"
* exception as provided by Oracle in the GPL Version 2 section of the License
* file that accompanied this code.
*
* Modifications:
* If applicable, add the following below the License Header, with the fields
* enclosed by brackets [] replaced by your own identifying information:
* "Portions Copyright [year] [name of copyright owner]"
*
* Contributor(s):
* If you wish your version of this file to be governed by only the CDDL or
* only the GPL Version 2, indicate your decision by adding "[Contributor]
* elects to include this software in this distribution under the [CDDL or GPL
* Version 2] license." If you don't indicate a single choice of license, a
* recipient has the option to distribute your version of this file under
* either the CDDL, the GPL Version 2 or to extend the choice of license to
* its licensees as provided above. However, if you add GPL Version 2 code
* and therefore, elected the GPL Version 2 license, then the option applies
* only if the new code is made subject to such option by the copyright
* holder.
*/
package org.glassfish.hk2.xml.api;
import java.net.URI;
/**
* This represents XML data and a JavaBean tree
*
* @author jwells
*
*/
public interface XmlRootHandle {
/**
* Gets the root of the JavaBean tree
*
* @return The root of the JavaBean tree. Will
* only return null if the tree has not yet
* been created
*/
public T getRoot();
/**
* Returns the root interface of this handle
*
* @return The root class or interface of this
* handle. Will not return null
*/
public Class getRootClass();
/**
* Represents the original URI from which this
* tree was parsed (or null if this tree did not
* come from a URI)
*
* @return The original URI from which this tree
* was parsed, or null if this tree did not come
* from a URI
*/
public URI getURI();
/**
* Returns true if this handles root and children
* are advertised in it service locator
*
* @return true if the root and children are
* advertised in the associated service locator
*/
public boolean isAdvertisedInLocator();
/**
* Returns true if this handles root and children
* are advertised in the {@link org.glassfish.hk2.configuration.hub.api.Hub}
*
* @return true if the root and children are
* advertised in the associated
* {@link org.glassfish.hk2.configuration.hub.api.Hub}
*/
public boolean isAdvertisedInHub();
/**
* This method returns a read-only copy of the existing
* tree. Any method that would change anything in this
* tree will fail. Methods that are customized will also
* fail
*
* If representsDefaults is true then getters for unset
* fields will return the default value. If representsDefaults
* is false then getters for unset fields will return null
* (or 0 (and false) for scalars). Setting representsDefault
* to false is useful if this tree is to be used to marshall
* back to XML, since JAXB will then not write the values back
* out to the file
*
* @param representDefaults If true getters will return default values,
* if false getters will return null (or zero/false for scalars)
* @return A read-only copy of this xml tree or null if there is
* no current root for this handle
*/
public T getReadOnlyRoot(boolean representDefaults);
/**
* Creates a copy of this tree that is not advertised.
* Modifications can be made to this copy and then
* merged back into the parent in a single transaction
*
* There is no requirement to call {@link XmlRootCopy#merge()}
* since the parent keeps no track of children. However,
* the {@link XmlRootCopy#merge()} method will fail if
* a modification has been made to the parent since the
* time the copy was created
*
* @return A non-null copy of this root that can be modified
* and then merged back in a single transaction
*/
public XmlRootCopy getXmlRootCopy();
/**
* This method overlays the current root and children with
* the root and children from newRoot. newRoot must
* have the same rootClass and must NOT be advertised
* in either the locator or the hub. The system will
* calculate the set of changes needed to convert this
* root into the root from newRoot.
*
* All nodes that are at the same spot in the tree (have the same
* xpath and same instance name) will not be modified, but will
* instead have attributes changed. All nodes present in newRoot
* but not in this root will be considered adds. All nodes
* not present in newRoot but in this root will be considered deletes
*
* The URI will not be modified by this call, nor will the
* state of advertisement
*
* @param newRoot The non-null root that will be overlayed
* onto this handle
*/
public void overlay(XmlRootHandle newRoot);
/**
* If this handle does not already have a
* root bean this method will add the one
* given
*
* @param root The non-null instance of the
* root type of this handle
* @throws IllegalStateException if this handle
* already has a root
*/
public void addRoot(T root);
/**
* This method can be used if the root of the
* tree has no required fields, and is the
* combination of {@link XmlService#createBean(Class)}
* and {@link #addRoot(Object)}. This method
* will throw an exception from the validator
* (if validation is enabled) if the root type
* has required fields or fails other validation
*/
public void addRoot();
/**
* If this handle has a root this method
* will delete it and all children, leaving
* the root of this tree null
*
* @return The root that was deleted, or null
* if the root was already null
*/
public T removeRoot();
}