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

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

/*
 * Copyright (c) 2007-2009, 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.List;

import org.apache.log4j.Logger;
import org.jibx.custom.classes.SharedValueBase;
import org.jibx.runtime.IUnmarshallingContext;
import org.jibx.runtime.JiBXException;
import org.jibx.runtime.impl.UnmarshallingContext;
import org.jibx.util.IClass;
import org.jibx.util.StringArray;

/**
 * Method parameter or return value customization information.
 * 
 * @author Dennis M. Sosnoski
 */
public class ValueCustom extends SharedValueBase
{
    /** Logger for class. */
    private static final Logger s_logger = Logger.getLogger(ValueCustom.class.getName());
    
    /** Style for elements used to wrap parameter values in request element. */
    private static final Integer ELEMENT_STYLE = new Integer(org.jibx.custom.classes.NestingBase.ELEMENT_VALUE_STYLE);
    
    /** Enumeration of allowed attribute names. */
    public static final StringArray s_allowedAttributes =
        new StringArray(new String[] { "element", "name" }, SharedValueBase.s_allowedAttributes);
    
    //
    // Internal instance data
    
    private String m_boundType; // internal use, not included in binding

    /** Documentation text (as org.w3.dom.Node components). */
    private List m_documentation;
    
    /**
     * Constructor.
     * 
     * @param parent
     * @param name
     */
    protected ValueCustom(NestingBase parent, String name) {
        super(parent, name);
    }
    
    /**
     * Get value type to be bound. This is the same as the plain value type for a simple (non-collection); for an array
     * value, it's just the array item type; and for a non-array collection it takes the same form as a generic type
     * declaration, with the actual item type enclosed in a less-than/greater-than sign pair following the base type.
     * 
     * @return parmaterized type
     */
    public String getBoundType() {
        return m_boundType;
    }
    
    /**
     * Get value documentation node list. This method should only be used after the
     * {@link #complete(IClass, List, Boolean, String)} method is called.
     * 
     * @return list of documentation nodes (null if none)
     */
    public List getDocumentation() {
        return m_documentation;
    }

    /**
     * Complete customization information based on supplied type. If the type information has not previously been set,
     * this will set it. It will also derive the appropriate XML name, if not previously set.
     * 
     * @param info value type information
     * @param docs default documentation text (null if none)
     * @param req required member flag (null if unspecified)
     * @param itype item type from signature (null if unknown)
     */
    /* package */void complete(IClass info, List docs, Boolean req, String itype) {
        if (s_logger.isDebugEnabled()) {
            StringBuffer buff = new StringBuffer();
            if (getBaseName() == null) {
                buff.append("Completing return value");
            } else {
                buff.append("Completing value ");
                buff.append(getBaseName());
            }
            s_logger.debug(buff.toString());
        }
        fillType(info, req, ELEMENT_STYLE);
        if (isCollection()) {
            
            // make sure the item type is set
            if (getItemType() == null) {
                String tname = getWorkingType();
                if (tname.endsWith("[]")) {
                    
                    // set item type directly from array type
                    setItemType(tname.substring(0, tname.length() - 2));
                    
                } else if (itype != null) {
                    
                    // set item type from signature
                    setItemType(itype);
                    
                } else {
                    setItemType("java.lang.Object");
                }
            }
            
            // derive the item name if not already set
            if (getItemName() == null) {
                setItemName(deriveItemName(getXmlName(), getItemType(), getParent().getNameStyle()));
            }
            
            // set type for binding definition
            String type = info.getName();
            if (itype == null) {
                if (type.endsWith("[]")) {
                    m_boundType = type.substring(0, type.length() - 2);
                } else {
                    m_boundType = type;
                }
            } else {
                m_boundType = type + '<' + itype + '>';
            }
            
        } else {
            m_boundType = info.getName();
        }
    }
    
    /**
     * Make sure all attributes are defined when unmarshalling (only used by binding).
     * 
     * @param uctx unmarshalling context
     */
    protected void preSet(IUnmarshallingContext uctx) {
        validateAttributes(uctx, s_allowedAttributes);
    }
    
    /**
     * Set element name method. This is intended for use during unmarshalling, so it needs to allow for being called
     * with a null value.
     * 
     * @param text (null if attribute not present)
     * @param ictx
     */
    private void setElement(String text, IUnmarshallingContext ictx) {
        if (text != null) {
            setXmlName(text);
            setElementForced();
            setStyle(new Integer(org.jibx.custom.classes.NestingBase.ELEMENT_VALUE_STYLE));
        }
    }
    
    /**
     * Parameter value unmarshalling factory. This gets the containing element and the name so that the standard
     * constructor can be used.
     * 
     * @param ictx
     * @return created instance
     * @throws JiBXException
     */
    private static ValueCustom parameterFactory(IUnmarshallingContext ictx) throws JiBXException {
        String name = ((UnmarshallingContext)ictx).attributeText(null, "name");
        s_logger.debug("Creating parameter instance with name " + name);
        return new ValueCustom((OperationCustom)getContainingObject(ictx), name);
    }
    
    /**
     * Return value unmarshalling factory. This gets the containing element so that the standard constructor can be
     * used.
     * 
     * @param ictx
     * @return created instance
     */
    private static ValueCustom returnFactory(IUnmarshallingContext ictx) {
        return new ValueCustom((OperationCustom)getContainingObject(ictx), "return");
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy