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

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

/*
 * Copyright (c) 2006-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.util.HashSet;

/**
 * Support methods for working with Java names.
 * 
 * @author Dennis M. Sosnoski
 */
public class NameUtils
{
    /** Reserved words for Java (keywords and literals). */
    private static final HashSet s_reservedWords = new HashSet();
    static {
        
        // keywords
        s_reservedWords.add("abstract");
        s_reservedWords.add("assert");
        s_reservedWords.add("boolean");
        s_reservedWords.add("break");
        s_reservedWords.add("byte");
        s_reservedWords.add("case");
        s_reservedWords.add("catch");
        s_reservedWords.add("char");
        s_reservedWords.add("class");
        s_reservedWords.add("const");
        s_reservedWords.add("continue");
        
        s_reservedWords.add("default");
        s_reservedWords.add("do");
        s_reservedWords.add("double");
        s_reservedWords.add("else");
        s_reservedWords.add("enum");
        s_reservedWords.add("extends");
        s_reservedWords.add("final");
        s_reservedWords.add("finally");
        s_reservedWords.add("float");
        s_reservedWords.add("for");
        s_reservedWords.add("goto");
        
        s_reservedWords.add("if");
        s_reservedWords.add("implements");
        s_reservedWords.add("import");
        s_reservedWords.add("instanceof");
        s_reservedWords.add("int");
        s_reservedWords.add("interface");
        s_reservedWords.add("long");
        s_reservedWords.add("native");
        s_reservedWords.add("new");
        s_reservedWords.add("package");
        
        s_reservedWords.add("private");
        s_reservedWords.add("protected");
        s_reservedWords.add("public");
        s_reservedWords.add("return");
        s_reservedWords.add("short");
        s_reservedWords.add("static");
        s_reservedWords.add("strictfp");
        s_reservedWords.add("super");
        s_reservedWords.add("switch");
        s_reservedWords.add("synchronized");
        
        s_reservedWords.add("this");
        s_reservedWords.add("throw");
        s_reservedWords.add("throws");
        s_reservedWords.add("transient");
        s_reservedWords.add("try");
        s_reservedWords.add("void");
        s_reservedWords.add("volatile");
        s_reservedWords.add("while");
        
        // literals
        s_reservedWords.add("true");
        s_reservedWords.add("false");
        s_reservedWords.add("null");
    }
    
    /** Java default import class names (not exhaustive, but anything that might represent generated code conflict). */
    private static final HashSet s_defaultImportClassNames = new HashSet();
    static {
        
        // interfaces
        s_defaultImportClassNames.add("Appendable");
        s_defaultImportClassNames.add("CharSequence");
        s_defaultImportClassNames.add("Cloneable");
        s_defaultImportClassNames.add("Comparable");
        s_defaultImportClassNames.add("Iterable");
        s_defaultImportClassNames.add("Readable");
        s_defaultImportClassNames.add("Runnable");
        
        // classes
        s_defaultImportClassNames.add("Boolean");
        s_defaultImportClassNames.add("Byte");
        s_defaultImportClassNames.add("Character");
        s_defaultImportClassNames.add("Class");
        s_defaultImportClassNames.add("ClassLoader");
        s_defaultImportClassNames.add("Double");
        s_defaultImportClassNames.add("Enum");
        s_defaultImportClassNames.add("Float");
        s_defaultImportClassNames.add("Integer");
        s_defaultImportClassNames.add("Long");
        s_defaultImportClassNames.add("Math");
        s_defaultImportClassNames.add("Number");
        s_defaultImportClassNames.add("Object");
        s_defaultImportClassNames.add("Package");
        s_defaultImportClassNames.add("Short");
        s_defaultImportClassNames.add("String");
        s_defaultImportClassNames.add("StringBuffer");
        s_defaultImportClassNames.add("StringBuilder");
        s_defaultImportClassNames.add("System");
        s_defaultImportClassNames.add("Thread");
        s_defaultImportClassNames.add("Throwable");
        s_defaultImportClassNames.add("Void");
        
        // exceptions/errors
        s_defaultImportClassNames.add("Exception");
        s_defaultImportClassNames.add("Error");
    }
    
    /**
     * Check if a name is reserved in Java.
     * 
     * @param name
     * @return is reserved
     */
    public static boolean isReserved(String name) {
        return s_reservedWords.contains(name);
    }
    
    /**
     * Convert name if it is reserved in Java.
     * 
     * @param name
     * @return non-reserved name
     */
    public static String convertReserved(String name) {
        if (isReserved(name)) {
            return "_" + name;
        } else {
            return name;
        }
    }
    
    /**
     * Check if a class name is a default import in Java.
     * 
     * @param name
     * @return is reserved
     */
    public static boolean isDefaultImport(String name) {
        return s_defaultImportClassNames.contains(name);
    }
    
    /**
     * Convert a raw package name to a legal Java package name. The raw package name must be in standard package name
     * form, with periods separating the individual directory components of the package name.
     * 
     * @param raw basic package name, which may include illegal characters
     * @return sanitized package name
     */
    public static String sanitizePackageName(String raw) {
        StringBuffer buff = new StringBuffer(raw.length());
        boolean first = true;
        for (int i = 0; i < raw.length();) {
            char chr = buff.charAt(i);
            if (first) {
                if (Character.isJavaIdentifierStart(chr)) {
                    first = false;
                    i++;
                } else {
                    buff.deleteCharAt(i);
                }
            } else if (chr == '.') {
                first = true;
                i++;
            } else if (!Character.isJavaIdentifierPart(chr)) {
                buff.deleteCharAt(i);
            } else {
                i++;
            }
        }
        return buff.toString();
    }
    
    /**
     * Convert a word to a name component. This is intended for use when composing names, as when generating access
     * method names for a property. If the supplied word starts with one or more underscores, this first strips the
     * the underscores. If the resulting text starts with a lower case letter this then converts that character to upper
     * case. Finally, if the result either begins with a digit or is the word "Class" this prepends a leading underscore
     * back on.
     *
     * @param word
     * @return word with uppercase initial letter
     */
    public static String toNameWord(String word) {
        char chr;
        while ((chr = word.charAt(0)) == '_' && word.length() > 1) {
            word = word.substring(1);
        }
        if (Character.isLowerCase(chr)) {
            StringBuffer buff = new StringBuffer(word);
            buff.setCharAt(0, Character.toUpperCase(chr));
            word = buff.toString();
        }
        if ("Class".equals(word)) {
            return "_Class";
        } else if (Character.isDigit(word.charAt(0))) {
            return "_" + word;
        } else {
            return word;
        }
    }
    
    /**
     * Convert a word to a leading name component. If the supplied word starts with an uppercase letter which is not
     * followed by another uppercase letter, this converts the initial uppercase to lowercase.
     *
     * @param word
     * @return word with lowercase initial letter
     */
    public static String toNameLead(String word) {
        char chr = word.charAt(0);
        if (Character.isUpperCase(chr) && (word.length() < 2 || Character.isLowerCase(word.charAt(1)))) {
            StringBuffer buff = new StringBuffer(word);
            buff.setCharAt(0, Character.toLowerCase(chr));
            return buff.toString();
        } else {
            return word;
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy