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

org.jibx.ws.wsdl.tools.custom.NestingBase Maven / Gradle / Ivy

/*
 * Copyright (c) 2007, Dennis M. Sosnoski All rights reserved.
 * 
 * Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
 * following conditions are met:
 * 
 * Redistributions of source code must retain the above copyright notice, this list of conditions and the following
 * disclaimer. 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. Neither the name of
 * JiBX nor the names of its contributors may be used to endorse or promote products derived from this software without
 * specific prior written permission.
 * 
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS 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 COPYRIGHT OWNER OR 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.
 */

package org.jibx.ws.wsdl.tools.custom;

import java.util.Collection;
import java.util.HashMap;
import java.util.Map;

import org.jibx.custom.classes.CustomBase;
import org.jibx.custom.classes.SharedNestingBase;
import org.jibx.runtime.IUnmarshallingContext;
import org.jibx.util.StringArray;

/**
 * Base class for nested WSDL customizations that can contain other customizations.
 * 
 * @author Dennis M. Sosnoski
 */
public abstract class NestingBase extends SharedNestingBase
{
    /** Enumeration of allowed attribute names */
    public static final StringArray s_allowedAttributes =
        new StringArray(new String[] { "service-base", "set-actions", "use-nillable", "wrapped" },
            SharedNestingBase.s_allowedAttributes);
    
    // values inherited through nesting
    private Boolean m_wrapped;
    
    private Boolean m_setActions;
    
    private Boolean m_useNillable;
    
    private String m_serviceBase;
    
    // set of unique names at level
    private final Map m_namedChildMap;
    
    // TODO: add WSDL namespace prefix, schema namespace prefix, WSDL structuring
    
    /**
     * Constructor.
     * 
     * @param parent
     */
    public NestingBase(SharedNestingBase parent) {
        super(parent);
        m_namedChildMap = new HashMap();
    }
    
    //
    // Getters for values inherited through nesting
    
    /**
     * Check wrapped flag.
     * 
     * @return wrapped flag
     */
    public boolean isWrapped() {
        if (m_wrapped == null) {
            if (this instanceof WsdlCustom || getParent() == null) {
                return true;
            } else {
                return ((NestingBase)getParent()).isWrapped();
            }
        } else {
            return m_wrapped.booleanValue();
        }
    }
    
    /**
     * Check if soapAction should be set.
     * 
     * @return soapAction flag
     */
    public boolean isSoapAction() {
        if (m_setActions == null) {
            if (this instanceof WsdlCustom || getParent() == null) {
                return true;
            } else {
                return ((NestingBase)getParent()).isSoapAction();
            }
        } else {
            return m_setActions.booleanValue();
        }
    }
    
    /**
     * Check if xsi:nillable should be used for optional values (rather than minOccurs='0').
     * 
     * @return xsi:nillable flag
     */
    public boolean isNillable() {
        if (m_useNillable == null) {
            if (this instanceof WsdlCustom || getParent() == null) {
                return false;
            } else {
                return ((NestingBase)getParent()).isNillable();
            }
        } else {
            return m_useNillable.booleanValue();
        }
    }
    
    /**
     * Get the service base address.
     * 
     * @return base address
     */
    public String getServiceBase() {
        if (m_serviceBase == null) {
            if (this instanceof WsdlCustom || getParent() == null) {
                return "http://localhost:8080/axis2/services";
            } else {
                return ((NestingBase)getParent()).getServiceBase();
            }
        } else {
            return m_serviceBase;
        }
    }
    
    /**
     * Get child by name.
     * 
     * @param name
     * @return named child, null if name not registered
     */
    public CustomBase getChild(String name) {
        return (CustomBase)m_namedChildMap.get(name);
    }
    
    /**
     * Register a child name. If the base name supplied has already been used by a different child, the name will be
     * modified by adding a numeric suffix to make it unique. Once a name has been registered for a child, calling this
     * method again with that name is guaranteed to just return that same name. Depending on the nesting level, the type
     * of child may take different forms. This doesn't care what the names represent, it just makes sure they're unique.
     * 
     * @param base proposed name
     * @param child named child
     * @return allowed name
     */
    public String registerName(String base, CustomBase child) {
        int index = 0;
        String name = base;
        Object value;
        while ((value = m_namedChildMap.get(name)) != null && value != child) {
            name = base + ++index;
        }
        m_namedChildMap.put(name, child);
        return name;
    }
    
    /**
     * Get WSDL definitions namespace.
     * 
     * @return WSDL namespace
     */
    public abstract String getWsdlNamespace();
    
    /**
     * Gets the parent element link from the unmarshalling stack. This method is for use by factories during
     * unmarshalling.
     * 
     * @param ictx unmarshalling context
     * @return containing class
     */
    protected static SharedNestingBase getContainingClass(IUnmarshallingContext ictx) {
        Object parent = ictx.getStackTop();
        int depth = 0;
        if (parent instanceof Collection) {
            parent = ictx.getStackObject(++depth);
        }
        return (SharedNestingBase)parent;
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy