All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.tools.xjc.reader.xmlschema.bindinfo.BIDeclaration Maven / Gradle / Ivy

There is a newer version: 4.0.5
Show newest version
/*
 * Copyright (c) 1997, 2018 Oracle and/or its affiliates. All rights reserved.
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Distribution License v. 1.0, which is available at
 * http://www.eclipse.org/org/documents/edl-v10.php.
 *
 * SPDX-License-Identifier: BSD-3-Clause
 */

package com.sun.tools.xjc.reader.xmlschema.bindinfo;

import java.util.Collection;

import javax.xml.namespace.QName;

import com.sun.tools.xjc.reader.xmlschema.BGMBuilder;

import org.xml.sax.Locator;

/**
 * Base interface for all binding customization declarations.
 * 
 * 

* Because of the setParent method, one customization declaration * can be attached to one component alone. * * @author * Kohsuke Kawaguchi ([email protected]) */ public interface BIDeclaration { /** * Sets the parent BindInfo object of this declaration. * A declaration object can use this pointer to access * context information, such as other customizations. * *

* This method can be only called from {@link BindInfo}, * and only once. This is a good opportunity to do some * follow-up initialization after JAXB unmarshalling * populated {@link BIDeclaration}. */ void setParent( BindInfo parent ); /** * Gets the name of this binding declaration, * which is the same as the tag name of the binding element. */ QName getName(); /** * Gets the source location where this declaration was written. * For declarations that are generated by XJC itself, * this method returns null. */ Locator getLocation(); /** * Marks this declaration to be acknowledged -- either actually * used or the existence is admitted (for example when * a property customization is given at the point of definition.) * *

* Declarations that are not acknowledged will be considered * as an error. */ void markAsAcknowledged(); /** * Checks if this declaration was acknowledged. */ boolean isAcknowledged(); /** * Called when the parent {@link BindInfo} got its owner set. * * This is when declarations are connected to {@link BGMBuilder} and * its sibling components. */ void onSetOwner(); /** * Gets child {@link BIDeclaration}s if any. * * @return * can be empty but always non-null. read-only. */ Collection getChildren(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy