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

org.apache.openjpa.jdbc.identifier.Normalizer Maven / Gradle / Ivy

There is a newer version: 4.0.1
Show newest version
/*
 * Licensed to the Apache Software Foundation (ASF) under one
 * or more contributor license agreements.  See the NOTICE file
 * distributed with this work for additional information
 * regarding copyright ownership.  The ASF licenses this file
 * to you under the Apache License, Version 2.0 (the
 * "License"); you may not use this file except in compliance
 * with the License.  You may obtain a copy of the License at
 *
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing,
 * software distributed under the License is distributed on an
 * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 * KIND, either express or implied.  See the License for the
 * specific language governing permissions and limitations
 * under the License.
 */
package org.apache.openjpa.jdbc.identifier;

import java.util.Objects;

import org.apache.openjpa.lib.identifier.IdentifierConfiguration;
import org.apache.openjpa.lib.identifier.IdentifierRule;
import org.apache.openjpa.lib.identifier.IdentifierUtil;
import org.apache.openjpa.lib.util.StringUtil;

/**
 * Static utility class used for operating on string based identifiers.
 */
public class Normalizer {

    private static IdentifierUtil normalizer =
        new DBIdentifierUtilImpl(new DefaultIdentifierConfiguration());

    private static IdentifierRule defaultRule;

    static {
        defaultRule = normalizer.getIdentifierConfiguration().getDefaultIdentifierRule();
    }

    public static IdentifierConfiguration getNamingConfiguration() {
        return normalizer.getIdentifierConfiguration();
    }

    /**
     * Normalizes a multi-part name
     * @param name
     */
    public static String normalizeMulti(String name) {
        if (StringUtil.isEmpty(name)) {
            return name;
        }
        String[] names = normalizer.splitName(defaultRule, name);
        return normalizer.joinNames(defaultRule, names);
    }

    /**
     * Normalizes a single part name
     * @param name
     */
    public static String normalizeString(String name) {
        if (StringUtil.isEmpty(name)) {
            return name;
        }
        if (!normalizer.isDelimited(defaultRule, name)) {
            // If not delimited, delimit the string if necessary
            return normalizer.delimit(defaultRule, name);
        }
        return name;
    }

    /**
     * Returns true if the name is delimited with default delimiters
     * @param name
     */
    public static boolean isDelimited(String name) {
        if (StringUtil.isEmpty(name)) {
            return false;
        }
        return normalizer.isDelimited(defaultRule, name);
    }

    /**
     * Splits names into individual components and compares individually
     * for equality
     * @param name1
     * @param name2
     */
    public static boolean fullNamesEqual(String name1, String name2) {
        if (StringUtil.isEmpty(name1) && StringUtil.isEmpty(name2)) {
            return true;
        }
        // Split multi-part names into individual components and compare
        // each component.  If delimited, do case compare.
        String[] names1 = normalizer.splitName(defaultRule, name1);
        String[] names2 = normalizer.splitName(defaultRule, name2);
        if (names1.length != names2.length) {
            return false;
        }
        for (int i = 0; i < names1.length; i++) {
            if (normalizer.isDelimited(defaultRule, names1[i])) {
                if (!Objects.equals(names1[i],names2[i])) {
                    return false;
                }
            } else {
                if (!StringUtil.equalsIgnoreCase(names1[i],names2[i])) {
                    return false;
                }
            }
        }
        return true;
    }

    /**
     * Compares two string names for equality.  If delimited, does a
     * case comparison.  If not delimited, does a case insensitive
     * comparison.
     * @param name1
     * @param name2
     */
    public static boolean namesEqual(String name1, String name2) {
        if (StringUtil.isEmpty(name1) && StringUtil.isEmpty(name2)) {
            return true;
        }
        if (normalizer.isDelimited(defaultRule, name1)) {
            if (!Objects.equals(name1, name2)) {
                return false;
            }
        } else {
            if (!StringUtil.equalsIgnoreCase(name1, name2)) {
                return false;
            }
        }
        return true;
    }

    /**
     * Normalizes a name, if not delimited, converts to uppercase.
     * @param name
     */
    public static String normalizeUpper(String name) {
        String nName = normalizeString(name);
        // Do not convert delimited names to upper case.  They may have
        // been delimited to preserve case.
        if (!isDelimited(nName)) {
            nName = name.toUpperCase();
        }
        return nName;
    }

    /**
     * Splits a name into normalized components
     * @param name
     */
    public static String[] splitName(String name) {
        return normalizer.splitName(defaultRule, name);
    }


    /**
     * Splits a name into normalized components using the specified
     * name delimiter (ex. schema:table, delim = : --> { schema, table }
     * @param name
     */
    public static String[] splitName(String name, String delim) {
        return normalizer.splitName(defaultRule, name, delim);
    }

    /**
     * Joins multiple names using default identifier rules.
     * @param names
     */
    public static String joinNames(String[] names) {
        return normalizer.joinNames(defaultRule, names);
    }

    /**
     * Joins multiple names using the specified delimiter.
     * @param names
     */
    public static String joinNames(String[] names, String delimiter) {
        return normalizer.joinNames(defaultRule, names, delimiter);
    }

    /**
     * Joins two names using the default identifier rules.
     * @param names
     */
    public static String joinNames(String name1, String name2) {
        return joinNames(new String[] { name1, name2});
    }


    /**
     * Truncates a name to the specified length while maintaining
     * delimiters.
     * @param name
     * @param length
     */
    public static String truncate(String name, int length) {
        return normalizer.truncateName(defaultRule, name, length);
    }

    /**
     * Convert a normalized name to a name using the specified configuration and
     * naming rule.
     * Note: Currently only delimiters are converted.
     * @param config
     * @param rule
     * @param name
     */
    public static String convert(IdentifierConfiguration config, String rule, String name) {
        return normalizer.convert(config, rule, name);
    }

    /**
     * Combines two names using default identifier rules.
     * @param name1
     * @param name2
     */
    public static String combine(String name1, String name2) {
        return normalizer.combineNames(defaultRule, name1, name2);
    }

    /**
     * Combines multiple names using default identifier rules.
     * @param name1
     * @param name2
     */
    public static String combine(String...names) {
        return normalizer.combineNames(defaultRule, names);
    }


    /**
     * Appends one string to another using default identifier rules.
     * @param name1
     * @param name2
     */
    public static String append(String name1, String name2) {
        return normalizer.appendNames(defaultRule, name1, name2);
    }

    /**
     * Removes Hungarian notation from a string.
     * @param name1
     * @param name2
     */
    public static String removeHungarianNotation(String name) {
        return normalizer.removeHungarianNotation(defaultRule, name);
    }

    /**
     * Removes default delimiters from a string.
     */
    public static String removeDelimiters(String name) {
        return normalizer.removeDelimiters(defaultRule, name);
    }

    /**
     * Delimits a string if necessary, optionally forcing it to be
     * delimited.
     */
    public static String delimit(String name, boolean force) {
        return normalizer.delimit(defaultRule, name, force);
    }

    /**
     * Determines whether a name can be split into multiple components.
     */
    public static boolean canSplit(String name) {
        return normalizer.canSplit(defaultRule, name);
    }

    /**
     * Determines whether a name can be split into multiple components, taking
     * into account the specified delimiter.
     */
    public static boolean canSplit(String name, String delim) {
        return normalizer.canSplit(defaultRule, name, delim);
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy