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

org.jibx.schema.codegen.CodeGenCommandLine Maven / Gradle / Ivy

/*
 * Copyright (c) 2007-2010, 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.schema.codegen;

import java.io.File;
import java.io.IOException;
import java.net.MalformedURLException;
import java.net.URL;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;

import org.apache.log4j.Logger;
import org.jibx.custom.CustomizationCommandLineBase;
import org.jibx.runtime.JiBXException;
import org.jibx.schema.codegen.custom.SchemasetCustom;
import org.jibx.schema.validation.ProblemConsoleLister;
import org.jibx.schema.validation.ProblemLogLister;
import org.jibx.schema.validation.ProblemMultiHandler;
import org.jibx.util.ReflectionUtilities;

/**
 * Command line processing specifically for the {@link CodeGen} class.
 * 
 * @author Dennis M. Sosnoski
 */
public class CodeGenCommandLine extends CustomizationCommandLineBase
{
    /** Logger for class. */
    private static final Logger s_logger = Logger.getLogger(CodeGenCommandLine.class.getName());
    
    /** Ordered array of extra usage lines. */
    private static final String[] EXTRA_USAGE_LINES = new String[] {
        " -b name      generated root binding name",
        " -d file      data model class structure for difference comparison",
        " -i path,...  include existing bindings (one or more), and use for matching\n" +
        "              schema global definitions",
        " -m file      file for dumping the generated data model class structure",
        " -n pack      default package for no-namespace schema definitions",
        " -p pack      default package for all schema definitions",
        " -s path      schema root directory path",
        " -u uri       namespace applied for code generation when no-namespaced schemas\n" +
        "              are found"};
    
    /** Default package for no-namespace schemas. */
    private String m_nonamespacePackage;
    
    /** Default package for all schemas. */
    private String m_defaultPackage;
    
    /** Schema root path. */
    private String m_rootPath;
    
    /** Name used for root binding. */
    private String m_bindingName;
    
    /** Namespace to be used for no-namespace schemas generated directly. */
    private String m_usingNamespace;
    
    /** Root URL for schemas. */
    private URL m_schemaRoot;
    
    /** Root directory for schemas (null if not a file system root). */
    private File m_schemaDir;
    
    /** File for dumping the generated class structure (null if none). */
    private File m_modelFile;
    
    /** File for checking differences in generated class structure (null if none). */
    private File m_differenceFile;
    
    /** Customizations model root. */
    private SchemasetCustom m_customRoot;
    
    /** List of existing bindings to be included and used for matching schema definitions. */
    private List m_includePaths;
    
    /**
     * Constructor.
     */
    public CodeGenCommandLine() {
        super(EXTRA_USAGE_LINES);
        m_includePaths = new ArrayList();
    }
    
    /**
     * Get root URL for schemas.
     *
     * @return directory
     */
    public URL getSchemaRoot() {
        return m_schemaRoot;
    }
    
    /**
     * Get root directory for schemas.
     *
     * @return directory (null if root is not a directory)
     */
    public File getSchemaDir() {
        return m_schemaDir;
    }
    
    /**
     * Get binding name.
     * 
     * @return name (null if not set)
     */
    public String getBindingName() {
        return m_bindingName;
    }
    
    /**
     * Get namespace to be used when no schemas with namespaces are being generated.
     * 
     * @return namespace URI (null if unspecified)
     */
    public String getUsingNamespace() {
        return m_usingNamespace;
    }
    
    /**
     * Get customizations model root.
     * 
     * @return customizations
     */
    public SchemasetCustom getCustomRoot() {
        return m_customRoot;
    }
    
    /**
     * Get default package for no-namespace schemas.
     *
     * @return package (null if not set)
     */
    public String getNonamespacePackage() {
        return m_nonamespacePackage;
    }
    
    /**
     * Get file to be used for dumping generated data model.
     *
     * @return dump file (null if none)
     */
    public File getModelFile() {
        return m_modelFile;
    }
    
    /**
     * Get file to be used for finding differences in generated data model.
     *
     * @return difference file (null if none)
     */
    public File getDifferenceFile() {
        return m_differenceFile;
    }
    
    /**
     * Get the list of paths for bindings to be used for matching schema definitions.
     *
     * @return paths (empty if no paths specified)
     */
    public List getIncludePaths() {
        return m_includePaths;
    }
    
    /*
     * (non-Javadoc)
     * 
     * @see org.jibx.binding.generator.CustomizationCommandLineBase#checkParameter(org.jibx.binding.generator.CustomizationCommandLineBase.ArgList)
     */
    protected boolean checkParameter(ArgList alist) {
        boolean match = true;
        String arg = alist.current();
        if ("-b".equalsIgnoreCase(arg)) {
            m_bindingName = alist.next();
        } else if ("-d".equalsIgnoreCase(arg)) {
            m_differenceFile = new File(alist.next());
        } else if ("-i".equalsIgnoreCase(arg)) {
            String text = alist.next();
            int split;
            int base = 0;
            while ((split = text.indexOf(',', base)) >= 0) {
                m_includePaths.add(text.substring(base, split));
                base = split + 1;
            }
            m_includePaths.add(text.substring(base));
        } else if ("-m".equalsIgnoreCase(arg)) {
            m_modelFile = new File(alist.next());
        } else if ("-n".equalsIgnoreCase(arg)) {
            m_nonamespacePackage = alist.next();
        } else if ("-p".equalsIgnoreCase(arg)) {
            m_defaultPackage = alist.next();
        } else if ("-s".equalsIgnoreCase(arg)) {
            m_rootPath = alist.next();
        } else if ("-u".equalsIgnoreCase(arg)) {
            m_usingNamespace = alist.next();
        } else {
            match = super.checkParameter(alist);
        }
        return match;
    }

    /**
     * Finish processing of command line parameters. This just sets up the schema directory.
     * 
     * @param alist 
     */
    protected void finishParameters(ArgList alist) {
        super.finishParameters(alist);
        try {
            if (m_rootPath == null) {
                m_schemaDir = new File(".").getCanonicalFile();
                m_schemaRoot = m_schemaDir.toURI().toURL();
            } else {
                String path = m_rootPath;
                File pathfile = new File(path).getCanonicalFile();
                if (pathfile.exists()) {
                    if (pathfile.isDirectory()) {
                        m_schemaDir = pathfile;
                        m_schemaRoot = pathfile.toURI().toURL();
                    } else {
                        System.out.println("Schema root path '" + m_rootPath + "' must be a directory");
                        alist.setValid(false);
                    }
                } else {
	                if (!path.endsWith("/")) {
	                    path += '/';
	                }
                    m_schemaRoot = new URL(path);
	                if (m_schemaRoot.getProtocol().equals("file")) {
	                    m_schemaDir = new File(m_schemaRoot.getPath()).getCanonicalFile();
	                }
                }
            }
        } catch (MalformedURLException e) {
            System.out.println("Root path '" + m_rootPath + "' not found as file and not recognized as URL");
            alist.setValid(false);
        } catch (IOException e) {
            System.out.println("Error processing root path '" + m_rootPath + '\'');
            alist.setValid(false);
        }
    }
    
    /**
     * Load the customizations file. This method must load the specified customizations file, or create a default
     * customizations instance, of the appropriate type.
     *
     * @param path customization file path
     * @return true if successful, false if an error
     * @throws JiBXException 
     * @throws IOException 
     */
    protected boolean loadCustomizations(String path) throws JiBXException, IOException {
        
        // load customizations and check for errors
        ProblemMultiHandler handler = new ProblemMultiHandler();
        handler.addHandler(new ProblemConsoleLister());
        handler.addHandler(new ProblemLogLister(s_logger));
        m_customRoot = SchemasetCustom.loadCustomizations(path, handler);
        
        // set specified default package on root customization element
        if (m_defaultPackage != null) {
            m_customRoot.setPackage(m_defaultPackage);
        }
        return true;
    }
    
    /*
     * (non-Javadoc)
     * 
     * @see org.jibx.binding.generator.CustomizationCommandLineBase#applyOverrides(Map)
     */
    protected Map applyOverrides(Map overmap) {
        return ReflectionUtilities.applyKeyValueMap(overmap, m_customRoot);
    }
    
    /*
     * (non-Javadoc)
     * 
     * @see org.jibx.binding.generator.CustomizationCommandLineBase#printUsage()
     */
    public void printUsage() {
        System.out.println("\nUsage: java org.jibx.schema.codegen.CodeGen "
            + "[options] schema1 schema2 ...\nwhere options are:");
        String[] usages = getUsageLines();
        for (int i = 0; i < usages.length; i++) {
            System.out.println(usages[i]);
        }
        System.out.println("The schema# files are different schemas to be included in "
            + "the generation\n(references from these schemas will also be included).\n");
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy