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

com.datastax.driver.mapping.NamingConventions Maven / Gradle / Ivy

There is a newer version: 3.11.5
Show newest version
/*
 * Copyright DataStax, Inc.
 *
 * Licensed 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 com.datastax.driver.mapping;

import java.util.Arrays;
import java.util.Comparator;
import java.util.LinkedList;
import java.util.List;
import java.util.regex.Pattern;

/**
 * Implementations of industry common naming conventions.
 */
public class NamingConventions {

    /**
     * Represents a naming convention where all letters are lower cased,
     * and words are not separated by any special character. E.g. "myxmlparser".
     */
    public static final NamingConvention LOWER_CASE = new SingleWordNamingConvention(false);

    /**
     * Represents a naming convention where all letters are upper cased,
     * and words are not separated by any special character. E.g. "MYXMLPARSER".
     */
    public static final NamingConvention UPPER_CASE = new SingleWordNamingConvention(true);

    /**
     * Represents snake case naming convention, meaning all letters are lower cased,
     * and words are separated by an underscore ("_"). E.g. "my_xml_parser".
     */
    public static final NamingConvention LOWER_SNAKE_CASE = new CharDelimitedNamingConvention("_", false);

    /**
     * Represents snake case naming convention, meaning all letters are upper cased,
     * and words are separated by an underscore ("_"). E.g. "MY_XML_PARSER".
     */
    public static final NamingConvention UPPER_SNAKE_CASE = new CharDelimitedNamingConvention("_", true);

    /**
     * Represents Lisp case naming convention,
     * meaning all letters are lower cased,
     * and words are separated by a dash sign ("-"). E.g. "my-xml-parser"
     */
    public static final NamingConvention LOWER_LISP_CASE = new CharDelimitedNamingConvention("-", false);

    /**
     * Represents Lisp case naming convention,
     * meaning all letters are upper cased,
     * and words are separated by a dash sign ("-"). E.g. "MY-XML-PARSER".
     */
    public static final NamingConvention UPPER_LISP_CASE = new CharDelimitedNamingConvention("-", true);

    /**
     * Represents the default Camel case naming convention,
     * with a lower cased first letter.
     *
     * @see LowerCamelCase
     */
    public static final NamingConvention LOWER_CAMEL_CASE = new LowerCamelCase();

    /**
     * Represents the default Camel case naming convention,
     * with an upper cased first letter.
     *
     * @see UpperCamelCase
     */
    public static final NamingConvention UPPER_CAMEL_CASE = new UpperCamelCase();

    /**
     * Represents Camel case
     * naming convention with a lower cased first letter.
     * 

* E.g. "myXmlParser" and "myXMLParser". Note that both examples are valid * lower camel case forms. The first one takes abbreviations as any other * words where the first letter is upper case, and the rest are lower case * (hence - "Xml"), while the latter upper cases all letters of an abbreviation * (hence - "XML"). *

* Additionally, many different Java naming conventions introduce prefixes * for field naming, some examples: *

* Those prefixes can be supported. For example, if this convention is * configured with {@code ignorablePrefixes} set to "_" then a field * named "_myXmlParser" will be split in 3 words only: "my", "Xml", "Parser". */ public static class LowerCamelCase extends CamelCase { private final boolean upperCaseAbbreviations; /** * @param upperCaseAbbreviations {@code true} to uppercase all abbreviations, * {@code false} to treat abbreviations as any other word * @param ignorablePrefixes string prefixes to trim if constant field name prefixes are used */ public LowerCamelCase(boolean upperCaseAbbreviations, String... ignorablePrefixes) { super(ignorablePrefixes); this.upperCaseAbbreviations = upperCaseAbbreviations; } /** * @param ignorablePrefixes string prefixes to trim if constant field name prefixes are used */ public LowerCamelCase(String... ignorablePrefixes) { this(false, ignorablePrefixes); } /** * @param upperCaseAbbreviations {@code true} to uppercase all abbreviations, * {@code false} to treat abbreviations as any other word */ public LowerCamelCase(boolean upperCaseAbbreviations) { this(upperCaseAbbreviations, new String[0]); } @Override public String join(List input) { StringBuilder builder = new StringBuilder(); for (int i = 0; i < input.size(); i++) { Word word = input.get(i); String value; if (i == 0) { value = word.getValue().toLowerCase(); } else if (upperCaseAbbreviations && word.isAbbreviation()) { value = word.getValue().toUpperCase(); } else { value = word.getValue().substring(0, 1).toUpperCase() + word.getValue().substring(1).toLowerCase(); } builder.append(value); } return builder.toString(); } } /** * Represents Camel case * naming convention with an upper cased first letter. *

* E.g. "MyXmlParser" and "MyXMLParser". Note that both examples are valid * upper camel case forms. The first one takes abbreviations as any other * words where the first letter is upper case, and the rest are lower case * (hence - "Xml"), while the latter upper cases all letters of an abbreviation * (hence - "XML"). *

* Additionally, many different Java naming conventions introduce prefixes * for field naming, some examples: *

* Those prefixes can be supported. For example, if this convention is * configured with {@code ignorablePrefixes} set to "_" then a field * named "_MyXmlParser" will be split in 3 words only: "My", "Xml", "Parser". */ public static class UpperCamelCase extends CamelCase { private final boolean upperCaseAbbreviations; /** * @param upperCaseAbbreviations {@code true} to uppercase all abbreviations, * {@code false} to treat abbreviations as any other word * @param ignorablePrefixes string prefixes to trim if constant field name prefixes are used */ public UpperCamelCase(boolean upperCaseAbbreviations, String... ignorablePrefixes) { super(ignorablePrefixes); this.upperCaseAbbreviations = upperCaseAbbreviations; } /** * @param ignorablePrefixes string prefixes to trim if constant field name prefixes are used */ public UpperCamelCase(String... ignorablePrefixes) { this(false, ignorablePrefixes); } /** * @param upperCaseAbbreviations {@code true} to uppercase all abbreviations, * {@code false} to treat abbreviations as any other word */ public UpperCamelCase(boolean upperCaseAbbreviations) { this(upperCaseAbbreviations, new String[0]); } @Override public String join(List input) { StringBuilder builder = new StringBuilder(); for (Word word : input) { String value; if (upperCaseAbbreviations && word.isAbbreviation()) { value = word.getValue().toUpperCase(); } else { value = word.getValue().substring(0, 1).toUpperCase() + word.getValue().substring(1).toLowerCase(); } builder.append(value); } return builder.toString(); } } public abstract static class CamelCase implements NamingConvention { private static final Pattern SPLIT_PATTERN = Pattern.compile(String.format("%s|%s|%s", "(?<=[A-Z])(?=[A-Z][a-z])", "(?<=[^A-Z])(?=[A-Z])", "(?<=[A-Za-z])(?=[^A-Za-z])" )); private static final Pattern ALL_UPPERCASE_PATTERN = Pattern.compile("([A-Z])*"); private static final Comparator STRING_LENGTH_COMPARATOR = new Comparator() { @Override public int compare(String o1, String o2) { return o2.length() - o1.length(); } }; private final Pattern ignorablePrefixPattern; protected CamelCase(String... ignorablePrefixes) { Arrays.sort(ignorablePrefixes, STRING_LENGTH_COMPARATOR); StringBuilder builder = new StringBuilder(); for (int i = 0; i < ignorablePrefixes.length; i++) { if (i > 0) { builder.append("|"); } builder.append("^"); builder.append(ignorablePrefixes[i]); } ignorablePrefixPattern = Pattern.compile(builder.toString()); } @Override public List split(String input) { List result = new LinkedList(); // slice all ignorable prefixes, then split for (String value : SPLIT_PATTERN.split(ignorablePrefixPattern.matcher(input).replaceAll(""))) { // if all uppercase, mark as abbreviation (e.g. MyXMLParser) boolean isAbbreviation = ALL_UPPERCASE_PATTERN.matcher(value).matches(); Word word = new Word(value, isAbbreviation); result.add(word); } return result; } } public static class CharDelimitedNamingConvention implements NamingConvention { private final String delimiter; private final boolean isUpperCase; protected CharDelimitedNamingConvention(String delimiter, boolean isUpperCase) { this.delimiter = delimiter; this.isUpperCase = isUpperCase; } @Override public List split(String input) { List result = new LinkedList(); for (String value : input.split(delimiter)) { result.add(new Word(value)); } return result; } @Override public String join(List input) { StringBuilder builder = new StringBuilder(); for (int i = 0; i < input.size(); i++) { if (i > 0) { builder.append(delimiter); } builder.append(input.get(i).getValue()); } String result = builder.toString(); return isUpperCase ? result.toUpperCase() : result.toLowerCase(); } } public static class SingleWordNamingConvention implements NamingConvention { private final boolean isUpperCase; protected SingleWordNamingConvention(boolean isUpperCase) { this.isUpperCase = isUpperCase; } @Override public List split(String input) { List result = new LinkedList(); result.add(new Word(input)); return result; } @Override public String join(List input) { StringBuilder builder = new StringBuilder(); for (Word word : input) { builder.append(word.getValue()); } String result = builder.toString(); return isUpperCase ? result.toUpperCase() : result.toLowerCase(); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy