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

org.jibx.custom.classes.SharedNestingBase 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.custom.classes;

import org.jibx.runtime.IUnmarshallingContext;
import org.jibx.util.StringArray;

/**
 * Base class for all binding customizations that can contain other customizations. This includes inherited values
 * shared with customization extensions (in particular, the WSDL extensions).
 * 
 * @author Dennis M. Sosnoski
 */
public abstract class SharedNestingBase extends CustomBase
{
    /** Enumeration of allowed attribute names */
    public static final StringArray s_allowedAttributes =
        new StringArray(new String[] { "javadoc-formatter", "name-style", "namespace", "namespace-style", "require",
        "use-javadocs" });
    
    // values inherited through nesting
    private String m_javadocFormatter;
    
    private String m_namespace;
    
    private Integer m_namespaceStyle;
    
    private Integer m_nameStyle;
    
    private Integer m_require;
    
    private Boolean m_useJavaDocs;
    
    // value set by subclasses
    private String m_actualNamespace;
    
    /**
     * Constructor.
     * 
     * @param parent
     */
    public SharedNestingBase(SharedNestingBase parent) {
        super(parent);
    }
    
    //
    // Access methods for values inherited through nesting
    
    /**
     * Get JavaDoc formatter class name.
     * 
     * @return namespace style
     */
    public String getFormatterClass() {
        if (m_javadocFormatter == null) {
            if (getParent() == null) {
                return IDocumentFormatter.DEFAULT_IMPLEMENTATION;
            } else {
                return getParent().getFormatterClass();
            }
        } else {
            return m_javadocFormatter;
        }
    }
    
    /**
     * Get namespace specified on this element. This method is only intended for use by subclasses - otherwise the
     * {@link #getNamespace()} method should instead be used.
     * 
     * @return namespace (null if none)
     */
    protected String getSpecifiedNamespace() {
        return m_namespace;
    }
    
    /**
     * Get namespace derivation style.
     * 
     * @return namespace style
     */
    public int getNamespaceStyle() {
        if (m_namespaceStyle == null) {
            if (getParent() == null) {
                return DERIVE_BY_PACKAGE;
            } else {
                return getParent().getNamespaceStyle();
            }
        } else {
            return m_namespaceStyle.intValue();
        }
    }
    
    /**
     * Set namespace derivation style.
     * 
     * @param style (null if none at this level)
     */
    public void setNamespaceStyle(Integer style) {
        m_namespaceStyle = style;
    }
    
    /**
     * Get name style.
     * 
     * @return name style
     */
    public int getNameStyle() {
        if (m_nameStyle == null) {
            if (getParent() == null) {
                return CAMEL_CASE_NAMES;
            } else {
                return getParent().getNameStyle();
            }
        } else {
            return m_nameStyle.intValue();
        }
    }
    
    /**
     * Set name style.
     * 
     * @param style (null if none at this level)
     */
    public void setNameStyle(Integer style) {
        m_nameStyle = style;
    }
    
    /**
     * Get the namespace for schema definitions. This value must be set by subclasses using the
     * {@link #setNamespace(String)} method.
     * 
     * @return schema namespace
     */
    public final String getNamespace() {
        return m_actualNamespace;
    }
    
    /**
     * Set the namespace to be used for schema definitions. This method is only intended for use by subclasses.
     * 
     * @param ns
     */
    protected void setNamespace(String ns) {
        m_actualNamespace = ns;
    }
    
    /**
     * Check if primitive value should be treated as required. If not set at any nesting level, the default is
     * true.
     * 
     * @param type primitive type
     * @return true if required value, false if not
     */
    public boolean isPrimitiveRequired(String type) {
        if (m_require == null) {
            if (getParent() == null) {
                return true;
            } else {
                return getParent().isPrimitiveRequired(type);
            }
        } else {
            return m_require.intValue() == REQUIRE_ALL || m_require.intValue() == REQUIRE_PRIMITIVES;
        }
    }
    
    /**
     * Check if object value should be treated as required. If not set at any nesting level, the default is
     * false.
     * 
     * @param type object type
     * @return true if required value, false if not
     */
    public boolean isObjectRequired(String type) {
        if (m_require == null) {
            if (getParent() == null) {
                return false;
            } else {
                return getParent().isObjectRequired(type);
            }
        } else {
            return m_require.intValue() == REQUIRE_ALL || m_require.intValue() == REQUIRE_OBJECTS;
        }
    }
    
    /**
     * Check if JavaDocs should be used for documentation. If not set at any nesting level, the default is
     * true.
     * 
     * @return force names flag
     */
    public boolean isUseJavaDocs() {
        if (m_useJavaDocs == null) {
            if (getParent() == null) {
                return true;
            } else {
                return getParent().isUseJavaDocs();
            }
        } else {
            return m_useJavaDocs.booleanValue();
        }
    }
    
    /**
     * Convert class or unprefixed field name to element or attribute name using current format.
     * 
     * @param base class or simple field name to be converted
     * @return element or attribute name
     */
    public String convertName(String base) {
        return convertName(base, getNameStyle());
    }
    
    /**
     * Name style set text method. This is intended for use during unmarshalling. TODO: add validation
     * 
     * @param text
     * @param ictx
     */
    private void setNameStyleText(String text, IUnmarshallingContext ictx) {
        if (text == null) {
            m_nameStyle = null;
        } else {
            m_nameStyle = new Integer(s_nameStyleEnum.getValue(text));
        }
    }
    
    /**
     * Name style get text method. This is intended for use during marshalling.
     * 
     * @return text
     */
    private String getNameStyleText() {
        if (m_nameStyle == null) {
            return null;
        } else {
            return s_nameStyleEnum.getName(m_nameStyle.intValue());
        }
    }
    
    /**
     * Namespace style set text method. This is intended for use during unmarshalling. TODO: add validation
     * 
     * @param text
     * @param ictx
     */
    private void setNamespaceStyleText(String text, IUnmarshallingContext ictx) {
        if (text == null) {
            m_namespaceStyle = null;
        } else {
            m_namespaceStyle = new Integer(s_namespaceStyleEnum.getValue(text));
        }
    }
    
    /**
     * Namespace style get text method. This is intended for use during marshalling.
     * 
     * @return text
     */
    private String getNamespaceStyleText() {
        if (m_namespaceStyle == null) {
            return null;
        } else {
            return s_namespaceStyleEnum.getName(m_namespaceStyle.intValue());
        }
    }
    
    /**
     * Required set text method. This is intended for use during unmarshalling. TODO: add validation
     * 
     * @param text
     * @param ictx
     */
    private void setRequireText(String text, IUnmarshallingContext ictx) {
        if (text == null) {
            m_require = null;
        } else {
            m_require = new Integer(s_requireEnum.getValue(text));
        }
    }
    
    /**
     * Required get text method. This is intended for use during marshalling.
     * 
     * @return text
     */
    private String getRequireText() {
        if (m_require == null) {
            return null;
        } else {
            return s_requireEnum.getName(m_require.intValue());
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy