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

org.dbflute.util.Srl Maven / Gradle / Ivy

There is a newer version: 1.2.8
Show newest version
/*
 * Copyright 2014-2021 the original author or authors.
 *
 * 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 org.dbflute.util;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;
import java.util.function.Function;

/**
 * String Utility for Internal Programming of DBFlute.
 * @author jflute
 */
public class Srl {

    // ===================================================================================
    //                                                                          Definition
    //                                                                          ==========
    protected static final String HARF_LOWER_ALPHABET = "abcdefghijklmnopqrstuvwxyz";
    protected static final String HARF_NUMBER = "0123456789";
    protected static final Set _alphabetHarfCharSet;
    static {
        final Set setupSet = new HashSet();
        final StringBuilder sb = new StringBuilder();
        sb.append(HARF_LOWER_ALPHABET);
        sb.append(sb.toString().toUpperCase());
        char[] chAry = sb.toString().toCharArray();
        for (char ch : chAry) {
            setupSet.add(ch);
        }
        _alphabetHarfCharSet = Collections.unmodifiableSet(setupSet);
    }
    protected static final Set _alphabetHarfLowerCharSet;
    static {
        final Set setupSet = new HashSet();
        final StringBuilder sb = new StringBuilder();
        sb.append(HARF_LOWER_ALPHABET);
        char[] chAry = sb.toString().toCharArray();
        for (char ch : chAry) {
            setupSet.add(ch);
        }
        _alphabetHarfLowerCharSet = Collections.unmodifiableSet(setupSet);
    }
    protected static final Set _alphabetHarfUpperCharSet;
    static {
        final Set setupSet = new HashSet();
        final StringBuilder sb = new StringBuilder();
        sb.append(HARF_LOWER_ALPHABET.toUpperCase());
        char[] chAry = sb.toString().toCharArray();
        for (char ch : chAry) {
            setupSet.add(ch);
        }
        _alphabetHarfUpperCharSet = Collections.unmodifiableSet(setupSet);
    }
    protected static final Set _numberHarfCharSet;
    static {
        final Set setupSet = new HashSet();
        final String chStr = HARF_NUMBER;
        char[] chAry = chStr.toCharArray();
        for (char ch : chAry) {
            setupSet.add(ch);
        }
        _numberHarfCharSet = Collections.unmodifiableSet(setupSet);
    }
    protected static final Set _alphabetHarfNumberHarfCharSet;
    static {
        final Set setupSet = new HashSet();
        setupSet.addAll(_alphabetHarfCharSet);
        setupSet.addAll(_numberHarfCharSet);
        _alphabetHarfNumberHarfCharSet = Collections.unmodifiableSet(setupSet);
    }
    protected static final Set _alphabetNumberHarfLowerCharSet;
    static {
        final Set setupSet = new HashSet();
        setupSet.addAll(_alphabetHarfLowerCharSet);
        setupSet.addAll(_numberHarfCharSet);
        _alphabetNumberHarfLowerCharSet = Collections.unmodifiableSet(setupSet);
    }
    protected static final Set _alphabetNumberHarfUpperCharSet;
    static {
        final Set setupSet = new HashSet();
        setupSet.addAll(_alphabetHarfUpperCharSet);
        setupSet.addAll(_numberHarfCharSet);
        _alphabetNumberHarfUpperCharSet = Collections.unmodifiableSet(setupSet);
    }

    // ===================================================================================
    //                                                                        Null & Empty
    //                                                                        ============
    /**
     * Is the string null or empty string?
     * @param str A judged string. (NullAllowed)
     * @return The determination.
     */
    public static boolean is_Null_or_Empty(final String str) {
        return str == null || str.length() == 0;
    }

    /**
     * Is the string null or trimmed-empty string?
     * @param str A judged string. (NullAllowed)
     * @return The determination.
     */
    public static boolean is_Null_or_TrimmedEmpty(final String str) {
        return str == null || str.trim().length() == 0;
    }

    /**
     * Is the string not null and not empty string?
     * @param str A judged string. (NullAllowed)
     * @return The determination.
     */
    public static boolean is_NotNull_and_NotEmpty(final String str) {
        return !is_Null_or_Empty(str);
    }

    /**
     * Is the string not null and not trimmed-empty string?
     * @param str A judged string. (NullAllowed)
     * @return The determination.
     */
    public static boolean is_NotNull_and_NotTrimmedEmpty(final String str) {
        return !is_Null_or_TrimmedEmpty(str);
    }

    /**
     * Is the string empty string?
     * @param str A judged string. (NullAllowed)
     * @return The determination.
     */
    public static boolean isEmpty(final String str) {
        return str != null && str.length() == 0;
    }

    /**
     * Is the string trimmed-empty string?
     * @param str A judged string. (NullAllowed)
     * @return The determination.
     */
    public static boolean isTrimmedEmpty(final String str) {
        return str != null && str.trim().length() == 0;
    }

    // ===================================================================================
    //                                                                              Length
    //                                                                              ======
    public static int length(final String str) {
        assertStringNotNull(str);
        return str.length();
    }

    public static String cut(final String str, int length) {
        assertStringNotNull(str);
        return cut(str, length, null);
    }

    public static String cut(final String str, int length, String suffix) {
        assertStringNotNull(str);
        return str.length() > length ? (str.substring(0, length) + (suffix != null ? suffix : "")) : str;
    }

    // ===================================================================================
    //                                                                                Case
    //                                                                                ====
    public static String toLowerCase(final String str) {
        assertStringNotNull(str);
        return str.toLowerCase();
    }

    public static String toUpperCase(final String str) {
        assertStringNotNull(str);
        return str.toUpperCase();
    }

    // ===================================================================================
    //                                                                                Trim
    //                                                                                ====
    public static String trim(final String str) {
        return doTrim(str, null);
    }

    public static String trim(final String str, final String trimStr) {
        return doTrim(str, trimStr);
    }

    public static String ltrim(final String str) {
        return doLTrim(str, null);
    }

    public static String ltrim(final String str, final String trimStr) {
        return doLTrim(str, trimStr);
    }

    public static String rtrim(final String str) {
        return doRTrim(str, null);
    }

    public static String rtrim(final String str, final String trimStr) {
        return doRTrim(str, trimStr);
    }

    protected static String doTrim(final String str, final String trimStr) {
        return doRTrim(doLTrim(str, trimStr), trimStr);
    }

    protected static String doLTrim(final String str, final String trimStr) {
        assertStringNotNull(str);

        // for trim target same as String.trim()
        if (trimStr == null) {
            final String notTrimmedString = "a";
            final String trimmed = (str + notTrimmedString).trim();
            return trimmed.substring(0, trimmed.length() - notTrimmedString.length());
        }

        // for original trim target
        String trimmed = str;
        for (; trimmed.startsWith(trimStr);) {
            trimmed = substringFirstRear(trimmed, trimStr);
        }
        return trimmed;
    }

    protected static String doRTrim(final String str, final String trimStr) {
        assertStringNotNull(str);

        // for trim target same as String.trim()
        if (trimStr == null) {
            final String notTrimmedString = "a";
            return (notTrimmedString + str).trim().substring(notTrimmedString.length());
        }

        // for original trim target
        String trimmed = str;
        for (; trimmed.endsWith(trimStr);) {
            trimmed = substringLastFront(trimmed, trimStr);
        }
        return trimmed;
    }

    // ===================================================================================
    //                                                                             Replace
    //                                                                             =======
    public static String replace(String str, String fromStr, String toStr) {
        assertStringNotNull(str);
        assertFromStringNotNull(fromStr);
        assertToStringNotNull(toStr);
        StringBuilder sb = null; // lazy load
        int pos = 0;
        int pos2 = 0;
        do {
            pos = str.indexOf(fromStr, pos2);
            if (pos2 == 0 && pos < 0) { // first loop and not found
                return str; // without creating StringBuilder 
            }
            if (sb == null) {
                sb = new StringBuilder();
            }
            if (pos == 0) {
                sb.append(toStr);
                pos2 = fromStr.length();
            } else if (pos > 0) {
                sb.append(str.substring(pos2, pos));
                sb.append(toStr);
                pos2 = pos + fromStr.length();
            } else { // (pos < 0) second or after loop only
                sb.append(str.substring(pos2));
                return sb.toString();
            }
        } while (true);
    }

    public static String replaceBy(String str, Map fromToMap) {
        assertStringNotNull(str);
        assertFromToMapNotNull(fromToMap);
        final Set> entrySet = fromToMap.entrySet();
        for (Entry entry : entrySet) {
            str = replace(str, entry.getKey(), entry.getValue());
        }
        return str;
    }

    public static String replaceScopeContent(String str, String fromStr, String toStr, String beginMark, String endMark) {
        final List scopeList = extractScopeList(str, beginMark, endMark);
        if (scopeList.isEmpty()) {
            return str;
        }
        return scopeList.get(0).replaceContentOnBaseString(fromStr, toStr);
    }

    public static String replaceScopeInterspace(String str, String fromStr, String toStr, String beginMark, String endMark) {
        final List scopeList = extractScopeList(str, beginMark, endMark);
        if (scopeList.isEmpty()) {
            return str;
        }
        return scopeList.get(0).replaceInterspaceOnBaseString(fromStr, toStr);
    }

    // ===================================================================================
    //                                                                               Split
    //                                                                               =====
    /**
     * Split the string to list by delimiter.
     * 
     * e.g. delimiter is slash
     *  o "aaa/bbb/ccc" to ["aaa", "bbb", "ccc"]
     *  o "aaa//bbb/ccc" to ["aaa", "", "bbb", "ccc"]
     *  o "/aaa/bbb/ccc/" to ["", "aaa", "bbb", "ccc", ""]
     *  o "aaa" to ["aaa"]
     * 
* @param str The split target string. (NotNull) * @param delimiter The delimiter for split. (NotNull) * @return The split list. (NotNull) */ public static List splitList(final String str, final String delimiter) { return doSplitList(str, delimiter, false); } /** * Split the string to list by delimiter, trimming elements. *
     * e.g. delimiter is slash
     *  o " aaa/ bbb/ ccc " to ["aaa", "bbb", "ccc"]
     * 
* @param str The split target string. (NotNull) * @param delimiter The delimiter for split. (NotNull) * @return The split list that their elements is trimmed. (NotNull) */ public static List splitListTrimmed(final String str, final String delimiter) { return doSplitList(str, delimiter, true); } protected static List doSplitList(final String str, final String delimiter, boolean trim) { assertStringNotNull(str); assertDelimiterNotNull(delimiter); final List list = new ArrayList(); int elementIndex = 0; int delimiterIndex = str.indexOf(delimiter); while (delimiterIndex >= 0) { final String element = str.substring(elementIndex, delimiterIndex); list.add(trim ? element.trim() : element); elementIndex = delimiterIndex + delimiter.length(); delimiterIndex = str.indexOf(delimiter, elementIndex); } final String element = str.substring(elementIndex); list.add(trim ? element.trim() : element); return list; } // =================================================================================== // IndexOf // ======= /** * Get the index of the first-found delimiter. *
     * indexOfFirst("foo.bar/baz.qux", ".", "/")
     * returns the index of ".bar"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The information of index. (NullAllowed: if delimiter not found) */ public static IndexOfInfo indexOfFirst(final String str, final String... delimiters) { return doIndexOfFirst(false, str, delimiters); } /** * Get the index of the first-found delimiter ignoring case. *
     * indexOfFirst("foo.bar/baz.qux", "A", "U")
     * returns the index of "ar/baz..."
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The information of index. (NullAllowed: if delimiter not found) */ public static IndexOfInfo indexOfFirstIgnoreCase(final String str, final String... delimiters) { return doIndexOfFirst(true, str, delimiters); } protected static IndexOfInfo doIndexOfFirst(final boolean ignoreCase, final String str, final String... delimiters) { return doIndexOf(ignoreCase, false, str, delimiters); } /** * Get the index of the last-found delimiter. *
     * indexOfLast("foo.bar/baz.qux", ".", "/")
     * returns the index of ".qux"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The information of index. (NullAllowed: if delimiter not found) */ public static IndexOfInfo indexOfLast(final String str, final String... delimiters) { return doIndexOfLast(false, str, delimiters); } /** * Get the index of the last-found delimiter ignoring case. *
     * indexOfLast("foo.bar/baz.qux", "A", "U")
     * returns the index of "ux"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The information of index. (NullAllowed: if delimiter not found) */ public static IndexOfInfo indexOfLastIgnoreCase(final String str, final String... delimiters) { return doIndexOfLast(true, str, delimiters); } protected static IndexOfInfo doIndexOfLast(final boolean ignoreCase, final String str, final String... delimiters) { return doIndexOf(ignoreCase, true, str, delimiters); } protected static IndexOfInfo doIndexOf(final boolean ignoreCase, final boolean last, final String str, final String... delimiters) { final String filteredStr; if (ignoreCase) { filteredStr = str.toLowerCase(); } else { filteredStr = str; } int targetIndex = -1; String targetDelimiter = null; for (String delimiter : delimiters) { final String filteredDelimiter; if (ignoreCase) { filteredDelimiter = delimiter.toLowerCase(); } else { filteredDelimiter = delimiter; } final int index; if (last) { index = filteredStr.lastIndexOf(filteredDelimiter); } else { index = filteredStr.indexOf(filteredDelimiter); } if (index < 0) { continue; } if (targetIndex < 0 || (last ? targetIndex < index : targetIndex > index)) { targetIndex = index; targetDelimiter = delimiter; } } if (targetIndex < 0) { return null; } final IndexOfInfo info = new IndexOfInfo(); info.setBaseString(str); info.setIndex(targetIndex); info.setDelimiter(targetDelimiter); return info; } public static class IndexOfInfo { protected String _baseString; protected int _index; protected String _delimiter; public String substringFront() { return _baseString.substring(0, getIndex()); } public String substringFrontTrimmed() { return substringFront().trim(); } public String substringRear() { return _baseString.substring(getRearIndex()); } public String substringRearTrimmed() { return substringRear().trim(); } public int getRearIndex() { return _index + _delimiter.length(); } public String getBaseString() { return _baseString; } public void setBaseString(String baseStr) { _baseString = baseStr; } public int getIndex() { return _index; } public void setIndex(int index) { _index = index; } public String getDelimiter() { return _delimiter; } public void setDelimiter(String delimiter) { _delimiter = delimiter; } } // =================================================================================== // SubString // ========= /** * Extract sub-string by begin index. (skip front string) *
     * substring("flute", 2)
     * returns "ute"
     * 
* @param str The target string. (NotNull) * @param beginIndex The from-index. * @return The part of string. (NotNull) */ public static String substring(final String str, final int beginIndex) { assertStringNotNull(str); if (str.length() < beginIndex) { String msg = "The length of the string was smaller than the begin index:"; msg = msg + " str=" + str + ", beginIndex=" + beginIndex; throw new StringIndexOutOfBoundsException(msg); } return str.substring(beginIndex); } /** * Extract sub-string by begin and end index. (get scope string) *
     * substring("flute", 1, 3)
     * returns "lu"
     * 
* @param str The target string. (NotNull) * @param beginIndex The from-index. * @param endIndex The to-index. * @return The part of string. (NotNull) */ public static String substring(final String str, final int beginIndex, final int endIndex) { assertStringNotNull(str); if (str.length() < beginIndex) { String msg = "The length of the string was smaller than the begin index:"; msg = msg + " str=" + str + " beginIndex=" + beginIndex + " endIndex=" + endIndex; throw new StringIndexOutOfBoundsException(msg); } if (str.length() < endIndex) { String msg = "The length of the string was smaller than the end index:"; msg = msg + " str=" + str + " beginIndex=" + beginIndex + " endIndex=" + endIndex; throw new StringIndexOutOfBoundsException(msg); } if (beginIndex > endIndex) { String msg = "The begin index was larger than the end index:"; msg = msg + " str=" + str + " beginIndex=" + beginIndex + " endIndex=" + endIndex; throw new StringIndexOutOfBoundsException(msg); } return str.substring(beginIndex, endIndex); } /** * Extract front sub-string by index. *
     * rearstring("flute", 2)
     * returns "fl"
     * 
* @param str The target string. (NotNull) * @param index The index from rear. * @return The rear string. (NotNull) */ public static String frontstring(final String str, final int index) { assertStringNotNull(str); if (str.length() < index) { String msg = "The length of the string was smaller than the index:"; msg = msg + " str=" + str + " index=" + index; throw new StringIndexOutOfBoundsException(msg); } return str.substring(0, index); } /** * Extract rear sub-string by reverse index. *
     * rearstring("flute", 2)
     * returns "te"
     * 
* @param str The target string. (NotNull) * @param reverseIndex The index from rear. * @return The rear string. (NotNull) */ public static String rearstring(final String str, final int reverseIndex) { assertStringNotNull(str); if (str.length() < reverseIndex) { String msg = "The length of the string was smaller than the index:"; msg = msg + " str=" + str + " reverseIndex=" + reverseIndex; throw new StringIndexOutOfBoundsException(msg); } return str.substring(str.length() - reverseIndex); } /** * Extract front sub-string from first-found delimiter. *
     * substringFirstFront("foo.bar/baz.qux", ".", "/")
     * returns "foo"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The part of string. (NotNull: if delimiter not found, returns argument-plain string) */ public static String substringFirstFront(final String str, final String... delimiters) { assertStringNotNull(str); return doSubstringFirstRear(false, false, false, str, delimiters); } /** * Extract front sub-string from first-found delimiter ignoring case. *
     * substringFirstFront("foo.bar/baz.qux", "A", "U")
     * returns "foo.b"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The part of string. (NotNull: if delimiter not found, returns argument-plain string) */ public static String substringFirstFrontIgnoreCase(final String str, final String... delimiters) { assertStringNotNull(str); return doSubstringFirstRear(false, false, true, str, delimiters); } /** * Extract rear sub-string from first-found delimiter. *
     * substringFirstRear("foo.bar/baz.qux", ".", "/")
     * returns "bar/baz.qux"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The part of string. (NotNull: if delimiter not found, returns argument-plain string) */ public static String substringFirstRear(String str, String... delimiters) { assertStringNotNull(str); return doSubstringFirstRear(false, true, false, str, delimiters); } /** * Extract rear sub-string from first-found delimiter ignoring case. *
     * substringFirstRear("foo.bar/baz.qux", "A", "U")
     * returns "ar/baz.qux"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The part of string. (NotNull: if delimiter not found, returns argument-plain string) */ public static String substringFirstRearIgnoreCase(String str, String... delimiters) { assertStringNotNull(str); return doSubstringFirstRear(false, true, true, str, delimiters); } /** * Extract front sub-string from last-found delimiter. *
     * substringLastFront("foo.bar/baz.qux", ".", "/")
     * returns "foo.bar/baz"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The part of string. (NotNull: if delimiter not found, returns argument-plain string) */ public static String substringLastFront(String str, String... delimiters) { assertStringNotNull(str); return doSubstringFirstRear(true, false, false, str, delimiters); } /** * Extract front sub-string from last-found delimiter ignoring case. *
     * substringLastFront("foo.bar/baz.qux", "A", "U")
     * returns "foo.bar/baz.q"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The part of string. (NotNull: if delimiter not found, returns argument-plain string) */ public static String substringLastFrontIgnoreCase(String str, String... delimiters) { assertStringNotNull(str); return doSubstringFirstRear(true, false, true, str, delimiters); } /** * Extract rear sub-string from last-found delimiter. *
     * substringLastRear("foo.bar/baz.qux", ".", "/")
     * returns "qux"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The part of string. (NotNull: if delimiter not found, returns argument-plain string) */ public static String substringLastRear(String str, String... delimiters) { assertStringNotNull(str); return doSubstringFirstRear(true, true, false, str, delimiters); } /** * Extract rear sub-string from last-found delimiter ignoring case. *
     * substringLastRear("foo.bar/baz.qux", "A", "U")
     * returns "x"
     * 
* @param str The target string. (NotNull) * @param delimiters The array of delimiters. (NotNull) * @return The part of string. (NotNull: if delimiter not found, returns argument-plain string) */ public static String substringLastRearIgnoreCase(String str, String... delimiters) { assertStringNotNull(str); return doSubstringFirstRear(true, true, true, str, delimiters); } protected static final String doSubstringFirstRear(final boolean last, final boolean rear, final boolean ignoreCase, final String str, String... delimiters) { assertStringNotNull(str); final IndexOfInfo info; if (ignoreCase) { if (last) { info = indexOfLastIgnoreCase(str, delimiters); } else { info = indexOfFirstIgnoreCase(str, delimiters); } } else { if (last) { info = indexOfLast(str, delimiters); } else { info = indexOfFirst(str, delimiters); } } if (info == null) { return str; } if (rear) { return str.substring(info.getIndex() + info.getDelimiter().length()); } else { return str.substring(0, info.getIndex()); } } // =================================================================================== // Contains // ======== public static boolean contains(String str, String keyword) { return containsAll(str, keyword); } public static boolean containsIgnoreCase(String str, String keyword) { return containsAllIgnoreCase(str, keyword); } public static boolean containsAll(String str, String... keywords) { return doContainsAll(false, str, keywords); } public static boolean containsAllIgnoreCase(String str, String... keywords) { return doContainsAll(true, str, keywords); } protected static boolean doContainsAll(boolean ignoreCase, String str, String... keywords) { assertStringNotNull(str); if (keywords == null || keywords.length == 0) { return false; } final String filtered = ignoreCase ? str.toLowerCase() : str; for (String keyword : keywords) { if (ignoreCase) { keyword = keyword != null ? keyword.toLowerCase() : null; } if (keyword == null || !filtered.contains(keyword)) { return false; } } return true; } public static boolean containsAny(String str, String... keywords) { return doContainsAny(false, str, keywords); } public static boolean containsAnyIgnoreCase(String str, String... keywords) { return doContainsAny(true, str, keywords); } protected static boolean doContainsAny(boolean ignoreCase, String str, String... keywords) { assertStringNotNull(str); if (keywords == null || keywords.length == 0) { return false; } final String filtered = ignoreCase ? str.toLowerCase() : str; for (String keyword : keywords) { if (ignoreCase) { keyword = keyword != null ? keyword.toLowerCase() : null; } if (keyword != null && filtered.contains(keyword)) { return true; } } return false; } public static boolean containsOrderedAll(String str, String... keywords) { return doContainsOrderedAll(false, str, keywords); } public static boolean containsOrderedAllIgnoreCase(String str, String... keywords) { return doContainsOrderedAll(true, str, keywords); } protected static boolean doContainsOrderedAll(boolean ignoreCase, String str, String... keywords) { assertStringNotNull(str); if (keywords == null || keywords.length == 0) { return false; } String current = ignoreCase ? str.toLowerCase() : str; for (String keyword : keywords) { if (ignoreCase) { keyword = keyword != null ? keyword.toLowerCase() : null; } if (keyword != null && current.contains(keyword)) { current = substringFirstRear(current, keyword); } else { return false; } } return true; } // ----------------------------------------------------- // List Element // ------------ public static boolean containsElement(Collection strList, String element) { return containsElementAll(strList, element); } public static boolean containsElementIgnoreCase(Collection strList, String element) { return containsElementAllIgnoreCase(strList, element); } public static boolean containsElementAll(Collection strList, String... elements) { return doContainsElementAll(false, strList, elements); } public static boolean containsElementAllIgnoreCase(Collection strList, String... elements) { return doContainsElementAll(true, strList, elements); } protected static boolean doContainsElementAll(boolean ignoreCase, Collection strList, String... elements) { assertStringListNotNull(strList); assertElementVaryingNotNull(elements); return doContainsElement(true, ignoreCase, ListElementContainsType.EQUAL, strList, elements); } public static boolean containsElementAny(Collection strList, String... elements) { return doContainsElementAny(false, strList, elements); } public static boolean containsElementAnyIgnoreCase(Collection strList, String... elements) { return doContainsElementAny(true, strList, elements); } protected static boolean doContainsElementAny(boolean ignoreCase, Collection strList, String... elements) { assertStringListNotNull(strList); assertElementVaryingNotNull(elements); return doContainsElement(false, ignoreCase, ListElementContainsType.EQUAL, strList, elements); } protected static boolean doContainsElement(boolean all, boolean ignoreCase, ListElementContainsType type, Collection strList, String... elements) { assertStringListNotNull(strList); assertElementVaryingNotNull(elements); if (elements.length == 0) { return false; } for (String element : elements) { boolean exists = false; for (String current : strList) { final boolean result; if (ignoreCase) { if (ListElementContainsType.PREFIX.equals(type)) { result = current != null ? startsWithIgnoreCase(current, element) : false; } else if (ListElementContainsType.SUFFIX.equals(type)) { result = current != null ? endsWithIgnoreCase(current, element) : false; } else if (ListElementContainsType.KEYWORD.equals(type)) { result = current != null ? containsIgnoreCase(current, element) : false; } else { result = equalsIgnoreCase(current, element); } } else { if (ListElementContainsType.PREFIX.equals(type)) { result = current != null ? startsWith(current, element) : false; } else if (ListElementContainsType.SUFFIX.equals(type)) { result = current != null ? endsWith(current, element) : false; } else if (ListElementContainsType.KEYWORD.equals(type)) { result = current != null ? contains(current, element) : false; } else { result = equalsPlain(current, element); } } if (result) { exists = true; } } if (all) { if (!exists) { return false; } } else { if (exists) { return true; } } } return all; } protected enum ListElementContainsType { EQUAL, KEYWORD, PREFIX, SUFFIX } // ----------------------------------------------------- // List Keyword // ------------ public static boolean containsKeyword(Collection strList, String keyword) { return containsKeywordAll(strList, keyword); } public static boolean containsKeywordIgnoreCase(Collection strList, String keyword) { return containsKeywordAllIgnoreCase(strList, keyword); } public static boolean containsKeywordAll(Collection strList, String... keywords) { return doContainsKeywordAll(false, strList, keywords); } public static boolean containsKeywordAllIgnoreCase(Collection strList, String... keywords) { return doContainsKeywordAll(true, strList, keywords); } protected static boolean doContainsKeywordAll(boolean ignoreCase, Collection strList, String... keywords) { assertStringListNotNull(strList); assertKeywordVaryingNotNull(keywords); return doContainsElement(true, ignoreCase, ListElementContainsType.KEYWORD, strList, keywords); } public static boolean containsKeywordAny(Collection strList, String... keywords) { return doContainsKeywordAny(false, strList, keywords); } public static boolean containsKeywordAnyIgnoreCase(Collection strList, String... keywords) { return doContainsKeywordAny(true, strList, keywords); } protected static boolean doContainsKeywordAny(boolean ignoreCase, Collection strList, String... keywords) { assertStringListNotNull(strList); assertKeywordVaryingNotNull(keywords); return doContainsElement(false, ignoreCase, ListElementContainsType.KEYWORD, strList, keywords); } // ----------------------------------------------------- // List Prefix // ----------- public static boolean containsPrefix(Collection strList, String prefix) { return containsPrefixAll(strList, prefix); } public static boolean containsPrefixIgnoreCase(Collection strList, String prefix) { return containsPrefixAllIgnoreCase(strList, prefix); } public static boolean containsPrefixAll(Collection strList, String... prefixes) { return doContainsPrefixAll(false, strList, prefixes); } public static boolean containsPrefixAllIgnoreCase(Collection strList, String... prefixes) { return doContainsPrefixAll(true, strList, prefixes); } protected static boolean doContainsPrefixAll(boolean ignoreCase, Collection strList, String... prefixes) { assertStringListNotNull(strList); return doContainsElement(true, ignoreCase, ListElementContainsType.PREFIX, strList, prefixes); } public static boolean containsPrefixAny(Collection strList, String... prefixes) { return doContainsPrefixAny(false, strList, prefixes); } public static boolean containsPrefixAnyIgnoreCase(Collection strList, String... prefixes) { return doContainsPrefixAny(true, strList, prefixes); } protected static boolean doContainsPrefixAny(boolean ignoreCase, Collection strList, String... prefixes) { assertStringListNotNull(strList); return doContainsElement(false, ignoreCase, ListElementContainsType.PREFIX, strList, prefixes); } // ----------------------------------------------------- // List Suffix // ----------- public static boolean containsSuffix(Collection strList, String suffix) { return containsSuffixAll(strList, suffix); } public static boolean containsSuffixIgnoreCase(Collection strList, String suffix) { return containsSuffixAllIgnoreCase(strList, suffix); } public static boolean containsSuffixAll(Collection strList, String... suffixes) { return doContainsSuffixAll(false, strList, suffixes); } public static boolean containsSuffixAllIgnoreCase(Collection strList, String... suffixes) { return doContainsSuffixAll(true, strList, suffixes); } protected static boolean doContainsSuffixAll(boolean ignoreCase, Collection strList, String... suffixes) { assertStringListNotNull(strList); return doContainsElement(true, ignoreCase, ListElementContainsType.SUFFIX, strList, suffixes); } public static boolean containsSuffixAny(Collection strList, String... suffixes) { return doContainsSuffixAny(false, strList, suffixes); } public static boolean containsSuffixAnyIgnoreCase(Collection strList, String... suffixes) { return doContainsSuffixAny(true, strList, suffixes); } protected static boolean doContainsSuffixAny(boolean ignoreCase, Collection strList, String... suffixes) { assertStringListNotNull(strList); return doContainsElement(false, ignoreCase, ListElementContainsType.SUFFIX, strList, suffixes); } // =================================================================================== // StartsWith // ========== public static final boolean startsWith(final String str, final String... prefixes) { return doStartsWith(false, str, prefixes); } public static final boolean startsWithIgnoreCase(final String str, final String... prefixes) { return doStartsWith(true, str, prefixes); } protected static final boolean doStartsWith(boolean ignoreCase, String str, final String... prefixes) { assertStringNotNull(str); if (prefixes == null || prefixes.length == 0) { return false; } final String filtered = ignoreCase ? str.toLowerCase() : str; for (String prefix : prefixes) { if (prefix != null && filtered.startsWith(ignoreCase ? prefix.toLowerCase() : prefix)) { return true; } } return false; } // =================================================================================== // EndsWith // ======== public static final boolean endsWith(final String str, final String... suffixes) { return doEndsWith(false, str, suffixes); } public static final boolean endsWithIgnoreCase(final String str, final String... suffixes) { return doEndsWith(true, str, suffixes); } protected static final boolean doEndsWith(boolean ignoreCase, String str, final String... suffixes) { assertStringNotNull(str); if (suffixes == null || suffixes.length == 0) { return false; } final String filtered = ignoreCase ? str.toLowerCase() : str; for (String suffix : suffixes) { if (suffix != null && filtered.endsWith(ignoreCase ? suffix.toLowerCase() : suffix)) { return true; } } return false; } // =================================================================================== // HasKeyword // ========== public static final boolean hasKeywordAll(final String keyword, final String... strs) { return doHasKeywordAll(false, keyword, strs); } public static final boolean hasKeywordAllIgnoreCase(final String keyword, final String... strs) { return doHasKeywordAll(true, keyword, strs); } protected static final boolean doHasKeywordAll(boolean ignoreCase, String keyword, final String... strs) { assertKeywordNotNull(keyword); return doHasKeyword(true, ignoreCase, KeywordType.CONTAIN, keyword, strs); } public static final boolean hasKeywordAny(final String keyword, final String... strs) { return doHasKeywordAny(false, keyword, strs); } public static final boolean hasKeywordAnyIgnoreCase(final String keyword, final String... strs) { return doHasKeywordAny(true, keyword, strs); } protected static final boolean doHasKeywordAny(boolean ignoreCase, String keyword, final String... strs) { assertKeywordNotNull(keyword); return doHasKeyword(false, ignoreCase, KeywordType.CONTAIN, keyword, strs); } protected static final boolean doHasKeyword(boolean all, boolean ignoreCase, KeywordType type, String keyword, final String... strs) { assertKeywordNotNull(keyword); if (strs == null || strs.length == 0) { return false; } for (String str : strs) { final boolean result; if (ignoreCase) { if (KeywordType.PREFIX.equals(type)) { result = str != null ? startsWithIgnoreCase(str, keyword) : false; } else if (KeywordType.SUFFIX.equals(type)) { result = str != null ? endsWithIgnoreCase(str, keyword) : false; } else { result = str != null ? containsIgnoreCase(str, keyword) : false; } } else { if (KeywordType.PREFIX.equals(type)) { result = str != null ? startsWith(str, keyword) : false; } else if (KeywordType.SUFFIX.equals(type)) { result = str != null ? endsWith(str, keyword) : false; } else { result = str != null ? contains(str, keyword) : false; } } if (all) { if (!result) { return false; } } else { if (result) { return true; } } } return all; } protected enum KeywordType { CONTAIN, PREFIX, SUFFIX } public static final boolean hasPrefixAll(final String prefix, final String... strs) { return doHasPrefixAll(false, prefix, strs); } public static final boolean hasPrefixAllIgnoreCase(final String prefix, final String... strs) { return doHasPrefixAll(true, prefix, strs); } protected static final boolean doHasPrefixAll(boolean ignoreCase, String prefix, final String... strs) { assertPrefixNotNull(prefix); return doHasKeyword(true, ignoreCase, KeywordType.PREFIX, prefix, strs); } public static final boolean hasPrefixAny(final String prefix, final String... strs) { return doHasPrefixAny(false, prefix, strs); } public static final boolean hasPrefixAnyIgnoreCase(final String prefix, final String... strs) { return doHasPrefixAny(true, prefix, strs); } protected static final boolean doHasPrefixAny(boolean ignoreCase, String prefix, final String... strs) { assertPrefixNotNull(prefix); return doHasKeyword(false, ignoreCase, KeywordType.PREFIX, prefix, strs); } public static final boolean hasSuffixAll(final String suffix, final String... strs) { return doHasSuffixAll(false, suffix, strs); } public static final boolean hasSuffixAllIgnoreCase(final String suffix, final String... strs) { return doHasSuffixAll(true, suffix, strs); } protected static final boolean doHasSuffixAll(boolean ignoreCase, String suffix, final String... strs) { assertSuffixNotNull(suffix); return doHasKeyword(true, ignoreCase, KeywordType.SUFFIX, suffix, strs); } public static final boolean hasSuffixAny(final String suffix, final String... strs) { return doHasSuffixAny(false, suffix, strs); } public static final boolean hasSuffixAnyIgnoreCase(final String suffix, final String... strs) { return doHasSuffixAny(true, suffix, strs); } protected static final boolean doHasSuffixAny(boolean ignoreCase, String suffix, final String... strs) { assertSuffixNotNull(suffix); return doHasKeyword(false, ignoreCase, KeywordType.SUFFIX, suffix, strs); } // =================================================================================== // Count // ===== public static int count(String str, String element) { return doCount(str, element, false); } public static int countIgnoreCase(String str, String element) { return doCount(str, element, true); } protected static int doCount(String str, String element, boolean ignoreCase) { assertStringNotNull(str); assertElementNotNull(element); final String filteredStr = ignoreCase ? str.toLowerCase() : str; final String filteredElement = ignoreCase ? element.toLowerCase() : element; int count = 0; int baseIndex = 0; while (true) { final int index = filteredStr.indexOf(filteredElement, baseIndex); if (index < 0) { break; } baseIndex = index + filteredElement.length(); ++count; } return count; } // =================================================================================== // Equals // ====== public static boolean equalsIgnoreCase(String str1, String... strs) { if (strs != null) { for (String element : strs) { if ((str1 != null && str1.equalsIgnoreCase(element)) || (str1 == null && element == null)) { return true; // found } } return false; } else { return str1 == null; // if both are null, it means equal } } public static boolean equalsFlexible(String str1, String... strs) { if (strs != null) { str1 = str1 != null ? replace(str1, "_", "") : null; for (String element : strs) { element = element != null ? replace(element, "_", "") : null; if ((str1 != null && str1.equalsIgnoreCase(element)) || (str1 == null && element == null)) { return true; // found } } return false; } else { return str1 == null; // if both are null, it means equal } } public static boolean equalsFlexibleTrimmed(String str1, String... strs) { str1 = str1 != null ? str1.trim() : null; if (strs != null) { String[] trimmedStrs = new String[strs.length]; for (int i = 0; i < strs.length; i++) { final String element = strs[i]; trimmedStrs[i] = element != null ? element.trim() : null; } return equalsFlexible(str1, trimmedStrs); } else { return equalsFlexible(str1, (String[]) null); } } public static boolean equalsPlain(String str1, String... strs) { if (strs != null) { for (String element : strs) { if ((str1 != null && str1.equals(element)) || (str1 == null && element == null)) { return true; // found } } return false; } else { return str1 == null; // if both are null, it means equal } } // =================================================================================== // Connect & Remove // ================ public static String connectByDelimiter(Collection strList, String delimiter) { assertStringListNotNull(strList); return doConnectByDelimiter(strList, delimiter, null); } public static String connectByDelimiterQuoted(Collection strList, String delimiter, String quotation) { assertStringListNotNull(strList); assertQuotationNotNull(quotation); return doConnectByDelimiter(strList, delimiter, quotation); } protected static String doConnectByDelimiter(Collection strList, String delimiter, String quotation) { assertStringListNotNull(strList); final StringBuilder sb = new StringBuilder(); for (String str : strList) { if (sb.length() > 0) { sb.append(delimiter); } sb.append(quotation != null ? quoteAnything(str != null ? str : "null", quotation) : str); } return sb.toString(); } public static String connectPrefix(String str, String prefix, String delimiter) { assertStringNotNull(str); return is_NotNull_and_NotTrimmedEmpty(prefix) ? prefix + delimiter + str : str; } public static String connectSuffix(String str, String suffix, String delimiter) { assertStringNotNull(str); return is_NotNull_and_NotTrimmedEmpty(suffix) ? str + delimiter + suffix : str; } public static String removePrefix(String str, String prefix) { assertStringNotNull(str); return startsWith(str, prefix) ? substringFirstRear(str, prefix) : str; } public static String removePrefixIgnoreCase(String str, String prefix) { assertStringNotNull(str); return startsWithIgnoreCase(str, prefix) ? substringFirstRearIgnoreCase(str, prefix) : str; } public static String removeSuffix(String str, String suffix) { assertStringNotNull(str); return endsWith(str, suffix) ? substringLastFront(str, suffix) : str; } public static String removeSuffixIgnoreCase(String str, String suffix) { assertStringNotNull(str); return endsWithIgnoreCase(str, suffix) ? substringLastFrontIgnoreCase(str, suffix) : str; } // =================================================================================== // Fill // ==== public static String rfill(String str, int size) { return doFill(str, size, false, ' '); } public static String rfill(String str, int size, Character addedChar) { return doFill(str, size, false, addedChar); } public static String lfill(String str, int size) { return doFill(str, size, true, ' '); } public static String lfill(String str, int size, Character addedChar) { return doFill(str, size, true, addedChar); } protected static String doFill(String str, int size, boolean left, Character addedChar) { assertStringNotNull(str); if (str.length() >= size) { return str; } final int addSize = size - str.length(); final StringBuilder sb = new StringBuilder(); for (int i = 0; i < addSize; i++) { sb.append(addedChar); } if (left) { return sb + str; } else { return str + sb; } } // =================================================================================== // Quotation Handling // ================== public static boolean isQuotedAnything(String str, String quotation) { assertStringNotNull(str); assertQuotationNotNull(quotation); return isQuotedAnything(str, quotation, quotation); } public static boolean isQuotedAnything(String str, String beginMark, String endMark) { assertStringNotNull(str); assertBeginMarkNotNull(beginMark); assertEndMarkNotNull(endMark); return str.length() > 1 && str.startsWith(beginMark) && str.endsWith(endMark); } public static boolean isQuotedDouble(String str) { assertStringNotNull(str); return isQuotedAnything(str, "\""); } public static boolean isQuotedSingle(String str) { assertStringNotNull(str); return isQuotedAnything(str, "'"); } public static String quoteAnything(String str, String quotation) { assertStringNotNull(str); assertQuotationNotNull(quotation); return quoteAnything(str, quotation, quotation); } public static String quoteAnything(String str, String beginMark, String endMark) { assertStringNotNull(str); assertBeginMarkNotNull(beginMark); assertEndMarkNotNull(endMark); return beginMark + str + endMark; } public static String quoteDouble(String str) { assertStringNotNull(str); return quoteAnything(str, "\""); } public static String quoteSingle(String str) { assertStringNotNull(str); return quoteAnything(str, "'"); } public static String unquoteAnything(String str, String quotation) { assertStringNotNull(str); assertQuotationNotNull(quotation); return unquoteAnything(str, quotation, quotation); } public static String unquoteAnything(String str, String beginMark, String endMark) { assertStringNotNull(str); assertBeginMarkNotNull(beginMark); assertEndMarkNotNull(endMark); if (!isQuotedAnything(str, beginMark, endMark)) { return str; } str = substring(str, beginMark.length()); str = substring(str, 0, str.length() - endMark.length()); return str; } public static String unquoteDouble(String str) { assertStringNotNull(str); return unquoteAnything(str, "\""); } public static String unquoteSingle(String str) { assertStringNotNull(str); return unquoteAnything(str, "'"); } // =================================================================================== // Delimiter Handling // ================== /** * Extract list of delimiter information objects.
* e.g. sea--land--piari--bonvo, it returns three objects. * @param str The target string that may have delimiters. (NotNull) * @param delimiter The string of delimiter to split the string. (NotNull) * @return The mutable list of delimiter information objects. (NotNull) */ public static final List extractDelimiterList(final String str, final String delimiter) { assertStringNotNull(str); assertDelimiterNotNull(delimiter); final List delimiterList = new ArrayList(); DelimiterInfo previous = null; String rear = str; while (true) { final int beginIndex = rear.indexOf(delimiter); if (beginIndex < 0) { break; } final DelimiterInfo info = new DelimiterInfo(); info.setBaseString(str); info.setDelimiter(delimiter); final int absoluteIndex = (previous != null ? previous.getEndIndex() : 0) + beginIndex; info.setBeginIndex(absoluteIndex); info.setEndIndex(absoluteIndex + delimiter.length()); if (previous != null) { info.setPrevious(previous); previous.setNext(info); } delimiterList.add(info); previous = info; rear = str.substring(info.getEndIndex()); continue; } return delimiterList; } /** * @author jflute */ public static class DelimiterInfo { protected String _baseString; // e.g. sea--land--piari--bonvo protected int _beginIndex; // e.g. 3 protected int _endIndex; // e.g. 5 protected String _delimiter; // e.g. -- protected DelimiterInfo _previous; // null if first protected DelimiterInfo _next; // null if last /** * Cut string of previous interspace. *
         * e.g. base-string: "sea--land--piari--bonvo"
         *  if first scope, returns "sea"
         *  if second scope, returns "land"
         * 
* @return The cut substring. (NotNull, EmptyAllowed: no previous string) */ public String substringInterspaceToPrevious() { int previousIndex = -1; if (_previous != null) { previousIndex = _previous.getBeginIndex(); } if (previousIndex >= 0) { return _baseString.substring(previousIndex + _previous.getDelimiter().length(), _beginIndex); } else { return _baseString.substring(0, _beginIndex); } } /** * Cut string of next interspace. *
         * e.g. base-string: "sea--land--piari--bonvo"
         *  if first scope, returns "land"
         *  if second scope, returns "piari"
         * 
* @return The cut substring. (NotNull, EmptyAllowed: no next string) */ public String substringInterspaceToNext() { int nextIndex = -1; if (_next != null) { nextIndex = _next.getBeginIndex(); } if (nextIndex >= 0) { return _baseString.substring(_endIndex, nextIndex); } else { return _baseString.substring(_endIndex); } } @Override public String toString() { return _delimiter + ":(" + _beginIndex + ", " + _endIndex + ")"; } public String getBaseString() { return _baseString; } public void setBaseString(String baseStr) { this._baseString = baseStr; } public int getBeginIndex() { return _beginIndex; } public void setBeginIndex(int beginIndex) { this._beginIndex = beginIndex; } public int getEndIndex() { return _endIndex; } public void setEndIndex(int endIndex) { this._endIndex = endIndex; } public String getDelimiter() { return _delimiter; } public void setDelimiter(String delimiter) { this._delimiter = delimiter; } public DelimiterInfo getPrevious() { return _previous; } public void setPrevious(DelimiterInfo previous) { this._previous = previous; } public DelimiterInfo getNext() { return _next; } public void setNext(DelimiterInfo next) { this._next = next; } } public static String delimit(Collection list, Function oneArgInLambda, String delimiter) { final StringBuilder sb = new StringBuilder(); int index = 0; for (ELEMENT element : list) { if (index > 0) { sb.append(delimiter); } sb.append(oneArgInLambda.apply(element)); ++index; } return sb.toString(); } // =================================================================================== // Scope Handling // ============== // ----------------------------------------------------- // Basic Scope // ----------- /** * Extract first scope object by the begin/end mark from the string. *
     * e.g. sea:(hangar)mystic, land:(showbase)oneman
     *  first: content=hangar, scope=(hangar), without next
     *  second: none
     * 
* @param str The target string that may have scopes. (NotNull) * @param beginMark The mark string for beginning. (NotNull) * @param endMark The mark string for ending. (NotNull) * @return The information object of first scope without next scopes. (NullAllowed: scope not found) */ public static final ScopeInfo extractScopeFirst(final String str, final String beginMark, final String endMark) { final List scopeList = doExtractScopeList(str, beginMark, endMark, true); if (scopeList == null || scopeList.isEmpty()) { return null; } if (scopeList.size() > 1) { String msg = "This method should extract only one scope: " + scopeList; throw new IllegalStateException(msg); } return scopeList.get(0); } /** * Extract last scope object by the begin/end mark from the string. *
     * e.g. sea:(hangar)mystic, land:(showbase)oneman
     *  last: content=showbase, scope=(showbase), has previous
     * 
* @param str The target string that may have scopes. (NotNull) * @param beginMark The mark string for beginning. (NotNull) * @param endMark The mark string for ending. (NotNull) * @return The information object of last scope with previous scopes. (NullAllowed: scope not found) */ public static final ScopeInfo extractScopeLast(final String str, final String beginMark, final String endMark) { final List scopeList = doExtractScopeList(str, beginMark, endMark, false); if (scopeList == null || scopeList.isEmpty()) { return null; } // originally should be last only but related to previous scopes... too late return scopeList.get(scopeList.size() - 1); } /** * Extract list of scope object by the begin/end mark from the string. *
     * e.g. "sea:(hangar)mystic, land:(showbase)oneman"
     *  first: content=hangar, scope=(hangar)
     *  second: content=showbase, scope=(showbase)
     * 
     * e.g. "sea(hangar)mystic):land(showbase)oneman)"
     *  first: content=hangar, scope=(hangar)
     *  second: content=showbase, scope=(showbase)
     * 
     * e.g. "sea(hangar(mystic)stage):land(showbase(oneman)stage)"
     *  first: content=hangar(mystic, scope=(hangar(mystic)
     *  second: content=showbase(oneman, scope=(showbase(oneman)
     *  *cannot nested handling
     * 
* @param str The target string that may have scopes. (NotNull) * @param beginMark The mark string for beginning. (NotNull) * @param endMark The mark string for ending. (NotNull) * @return The mutable list of found scopes. (NotNull, EmptyAllowed: not found) */ public static final List extractScopeList(final String str, final String beginMark, final String endMark) { final List scopeList = doExtractScopeList(str, beginMark, endMark, false); return scopeList != null ? scopeList : new ArrayList(); } protected static final List doExtractScopeList(final String str, final String beginMark, final String endMark, final boolean firstOnly) { assertStringNotNull(str); assertBeginMarkNotNull(beginMark); assertEndMarkNotNull(endMark); List resultList = null; ScopeInfo previous = null; String rear = str; while (true) { final int beginIndex = rear.indexOf(beginMark); if (beginIndex < 0) { break; } rear = rear.substring(beginIndex); // scope begins if (rear.length() <= beginMark.length()) { break; } rear = rear.substring(beginMark.length()); // skip begin-mark final int endIndex = rear.indexOf(endMark); if (endIndex < 0) { break; } final String scope = beginMark + rear.substring(0, endIndex + endMark.length()); final ScopeInfo info = new ScopeInfo(); info.setBaseString(str); final int absoluteIndex = (previous != null ? previous.getEndIndex() : 0) + beginIndex; info.setBeginIndex(absoluteIndex); info.setEndIndex(absoluteIndex + scope.length()); info.setBeginMark(beginMark); info.setEndMark(endMark); info.setContent(rtrim(ltrim(scope, beginMark), endMark)); info.setScope(scope); if (previous != null) { info.setPrevious(previous); previous.setNext(info); } if (resultList == null) { resultList = new ArrayList(); // lazy load } resultList.add(info); if (previous == null && firstOnly) { break; } previous = info; rear = str.substring(info.getEndIndex()); } return resultList; // nullable if not found to suppress unneeded ArrayList creation } // ----------------------------------------------------- // Scope Wide // ---------- /** * Extract wide scope by the begin/end mark from the string.
*
     * e.g. if "sea(hangar(mystic)choucho):land", content="hangar(mystic)choucho"
     * 
* @param str The target string that may have scopes. (NotNull) * @param beginMark The mark string for beginning. (NotNull) * @param endMark The mark string for ending. (NotNull) * @return The single object for wide scope (without previous/next). (NotNull, NullAllowed: not found) */ public static final ScopeInfo extractScopeWide(final String str, final String beginMark, final String endMark) { assertStringNotNull(str); assertBeginMarkNotNull(beginMark); assertEndMarkNotNull(endMark); final IndexOfInfo first = indexOfFirst(str, beginMark); if (first == null) { return null; } final IndexOfInfo last = indexOfLast(str, endMark); if (last == null) { return null; } final String content = str.substring(first.getIndex() + first.getDelimiter().length(), last.getIndex()); final ScopeInfo info = new ScopeInfo(); info.setBaseString(str); info.setBeginIndex(first.getIndex()); info.setEndIndex(last.getIndex() + endMark.length()); info.setBeginMark(beginMark); info.setEndMark(endMark); info.setContent(content); info.setScope(beginMark + content + endMark); return info; } // ----------------------------------------------------- // Scope Info // ---------- /** * @author jflute */ public static class ScopeInfo { protected String _baseString; // e.g. "sea:(hangar)mystic, land:(showbase)oneman" protected int _beginIndex; // e.g. 4 protected int _endIndex; // e.g. 12 protected String beginMark; // ( protected String endMark; // ) protected String _content; // e.g. hangar protected String _scope; // e.g. (hangar) protected ScopeInfo _previous; // null if first protected ScopeInfo _next; // null if last /** * @param index The index to be determined, 0 origin. * @return Is the specified index before begin index? */ public boolean isBeforeScope(int index) { return index < _beginIndex; } /** * @param index The index to be determined, 0 origin. * @return Is the specified index between begin index and end index? */ public boolean isInScope(int index) { return index >= _beginIndex && index <= _endIndex; } /** * Replace all contents with the replacement on base string. *
         * e.g. base-string: "sea:(hangar)mystic, land:(showbase)oneman"
         *  if "stage", returns "sea:(stage)mystic, land:(stage)oneman"
         * 
* @param toStr The string as replacement. (NotNull) * @return The whole string replaced with the replacement. (NotNull) */ public String replaceContentOnBaseString(String toStr) { final List scopeList = takeScopeList(); final StringBuilder sb = new StringBuilder(); for (ScopeInfo scope : scopeList) { sb.append(scope.substringInterspaceToPrevious()); sb.append(scope.getBeginMark()); sb.append(toStr); sb.append(scope.getEndMark()); if (scope.getNext() == null) { // last sb.append(scope.substringInterspaceToNext()); } } return sb.toString(); } /** * Replace keywords in contents with the replacement on base string. *
         * e.g. base-string: "sea:(hangar)mystic, land:(showbase)oneman"
         *  if "a", "b", returns "sea:(hbngbr)mystic, land:(showbbse)oneman"
         * 
* @param fromStr The string replaced keyword. (NotNull) * @param toStr The string as replacement. (NotNull) * @return The whole string replaced with the replacement. (NotNull) */ public String replaceContentOnBaseString(String fromStr, String toStr) { final List scopeList = takeScopeList(); final StringBuilder sb = new StringBuilder(); for (ScopeInfo scope : scopeList) { sb.append(scope.substringInterspaceToPrevious()); sb.append(scope.getBeginMark()); sb.append(replace(scope.getContent(), fromStr, toStr)); sb.append(scope.getEndMark()); if (scope.getNext() == null) { // last sb.append(scope.substringInterspaceToNext()); } } return sb.toString(); } /** * Replace keywords in interspaces with the replacement on base string. *
         * e.g. base-string: "sea:(hangar)mystic, land:(showbase)oneman"
         *  if "a", "b", returns "seb:(hangar)mystic, lbnd:(showbase)onembn"
         * 
* @param fromStr The string replaced keyword. (NotNull) * @param toStr The string as replacement. (NotNull) * @return The whole string replaced with the replacement. (NotNull) */ public String replaceInterspaceOnBaseString(String fromStr, String toStr) { final List scopeList = takeScopeList(); final StringBuilder sb = new StringBuilder(); for (ScopeInfo scope : scopeList) { sb.append(replace(scope.substringInterspaceToPrevious(), fromStr, toStr)); sb.append(scope.getScope()); if (scope.getNext() == null) { // last sb.append(replace(scope.substringInterspaceToNext(), fromStr, toStr)); } } return sb.toString(); } protected List takeScopeList() { ScopeInfo scope = this; while (true) { final ScopeInfo previous = scope.getPrevious(); if (previous == null) { break; } scope = previous; } final List scopeList = new ArrayList(); scopeList.add(scope); while (true) { final ScopeInfo next = scope.getNext(); if (next == null) { break; } scope = next; scopeList.add(next); } return scopeList; } /** * Cut string of previous interspace. *
         * e.g. base-string: "sea:(hangar)mystic, land:(showbase)oneman"
         *  if first scope, returns "sea"
         *  if second scope, returns "mystic, land:"
         * 
* @return The cut substring. (NotNull, EmptyAllowed: no previous interspace) */ public String substringInterspaceToPrevious() { int previousEndIndex = -1; if (_previous != null) { previousEndIndex = _previous.getEndIndex(); } if (previousEndIndex >= 0) { return _baseString.substring(previousEndIndex, _beginIndex); } else { return _baseString.substring(0, _beginIndex); } } /** * Cut string of next interspace. *
         * e.g. base-string: "sea:(hangar)mystic, land:(showbase)oneman"
         *  if first scope, returns "mystic, land:"
         *  if second scope, returns "oneman"
         * 
* @return The cut substring. (NotNull, EmptyAllowed: no next interspace) */ public String substringInterspaceToNext() { int nextBeginIndex = -1; if (_next != null) { nextBeginIndex = _next.getBeginIndex(); } if (nextBeginIndex >= 0) { return _baseString.substring(_endIndex, nextBeginIndex); } else { return _baseString.substring(_endIndex); } } /** * Cut string of previous interspace with scope. *
         * e.g. base-string: "sea:(hangar)mystic, land:(showbase)oneman"
         *  if first scope, returns "sea:(hangar)"
         *  if second scope, returns "(hangar)mystic, land:(showbase)"
         * 
* @return The cut substring. (NotNull, NotEmpty: at least scope exists) */ public String substringScopeToPrevious() { int previousBeginIndex = -1; if (_previous != null) { previousBeginIndex = _previous.getBeginIndex(); } if (previousBeginIndex >= 0) { return _baseString.substring(previousBeginIndex, _endIndex); } else { return _baseString.substring(0, _endIndex); } } /** * Cut string of next interspace with scope. *
         * e.g. base-string: "sea:(hangar)mystic, land:(showbase)oneman"
         *  if first scope, returns "(hangar)mystic, land:(showbase)"
         *  if second scope, returns "(showbase)oneman"
         * 
* @return The cut substring. (NotNull, NotEmpty: at least scope exists) */ public String substringScopeToNext() { int nextEndIndex = -1; if (_next != null) { nextEndIndex = _next.getEndIndex(); } if (nextEndIndex >= 0) { return _baseString.substring(_beginIndex, nextEndIndex); } else { return _baseString.substring(_beginIndex); } } @Override public String toString() { return _scope + ":(" + _beginIndex + ", " + _endIndex + ")"; } public String getBaseString() { return _baseString; } public void setBaseString(String baseString) { this._baseString = baseString; } public int getBeginIndex() { return _beginIndex; } public void setBeginIndex(int beginIndex) { this._beginIndex = beginIndex; } public int getEndIndex() { return _endIndex; } public void setEndIndex(int endIndex) { this._endIndex = endIndex; } public String getBeginMark() { return beginMark; } public void setBeginMark(String beginMark) { this.beginMark = beginMark; } public String getEndMark() { return endMark; } public void setEndMark(String endMark) { this.endMark = endMark; } public String getContent() { return _content; } public void setContent(String content) { this._content = content; } public String getScope() { return _scope; } public void setScope(String scope) { this._scope = scope; } public ScopeInfo getPrevious() { return _previous; } public void setPrevious(ScopeInfo previous) { this._previous = previous; } public ScopeInfo getNext() { return _next; } public void setNext(ScopeInfo next) { this._next = next; } } public static String removeScope(final String str, final String beginMark, final String endMark) { assertStringNotNull(str); final StringBuilder sb = new StringBuilder(); String rear = str; while (true) { final int beginIndex = rear.indexOf(beginMark); if (beginIndex < 0) { sb.append(rear); break; } final int endIndex = rear.indexOf(endMark); if (endIndex < 0) { sb.append(rear); break; } if (beginIndex > endIndex) { final int borderIndex = endIndex + endMark.length(); sb.append(rear.substring(0, borderIndex)); rear = rear.substring(borderIndex); continue; } sb.append(rear.substring(0, beginIndex)); rear = rear.substring(endIndex + endMark.length()); } return sb.toString(); } // =================================================================================== // Initial Handling // ================ public static String initCap(String str) { assertStringNotNull(str); if (is_Null_or_Empty(str)) { return str; } if (str.length() == 1) { return str.toUpperCase(); } if (Character.isUpperCase(str.charAt(0))) { return str; } final char[] chars = str.toCharArray(); chars[0] = Character.toUpperCase(chars[0]); return new String(chars); } public static String initCapTrimmed(String str) { assertStringNotNull(str); return initCap(str.trim()); } public static String initUncap(String str) { assertStringNotNull(str); if (is_Null_or_Empty(str)) { return str; } if (str.length() == 1) { return str.toLowerCase(); } if (Character.isLowerCase(str.charAt(0))) { return str; } final char[] chars = str.toCharArray(); chars[0] = Character.toLowerCase(chars[0]); return new String(chars); } public static String initUncapTrimmed(String str) { assertStringNotNull(str); return initUncap(str.trim()); } /** * Adjust initial character(s) as beans property.
* Basically same as initUncap() method except only when * it starts with two upper case character, for example, 'EMecha' * @param capitalizedName The capitalized name for beans property. (NotNull) * @return The name as beans property that initial is adjusted. (NotNull) */ public static String initBeansProp(String capitalizedName) { // according to Java Beans rule assertObjectNotNull("capitalizedName", capitalizedName); if (is_Null_or_TrimmedEmpty(capitalizedName)) { return capitalizedName; } if (isInitTwoUpperCase(capitalizedName)) { // for example, 'EMecha' return capitalizedName; } return initUncap(capitalizedName); } public static boolean isInitLowerCase(String str) { assertStringNotNull(str); if (is_Null_or_Empty(str)) { return false; } return isLowerCase(str.charAt(0)); } public static boolean isInitTwoLowerCase(String str) { assertStringNotNull(str); if (str.length() < 2) { return false; } return isLowerCase(str.charAt(0), str.charAt(1)); } public static boolean isInitUpperCase(String str) { assertStringNotNull(str); if (is_Null_or_Empty(str)) { return false; } return isUpperCase(str.charAt(0)); } public static boolean isInitTwoUpperCase(String str) { assertStringNotNull(str); if (str.length() < 2) { return false; } return isUpperCase(str.charAt(0), str.charAt(1)); } // =================================================================================== // Name Handling // ============= /** * Camelize the decamel name using underscore '_'. *
     * e.g.
     *  o FOO_NAME to FooName
     *  o foo_name to FooName
     *  o f to F
     *  o foo to Foo
     *  o foo_nameBar to FooNameBar
     *  o foo_a_bar to FooABar
     *  o foo_aBar to FooABar
     *  o f_foo_name to FFooName
     *  o FFOO_NAME to FfooName
     * 
* @param decamelName The name decamelized by underscore '_'. (NotNull) * @return The name camelized as upper first character. (NotNull) */ public static String camelize(String decamelName) { assertDecamelNameNotNull(decamelName); return doCamelize(decamelName, "_"); } /** * Camelize the decamel name using specified delimiter(s).
* See the java-doc of default-delimiter method for the detail. * @param decamelName The name decamelized by underscore '_'. (NotNull) * @param delimiters The your own delimiter(s) to camelize. (NotNull, EmptyAllowed: then ono change) * @return The name camelized as upper first character. (NotNull) */ public static String camelize(String decamelName, String... delimiters) { assertDecamelNameNotNull(decamelName); String name = decamelName; for (String delimiter : delimiters) { name = doCamelize(name, delimiter); } return name; } protected static String doCamelize(String decamelName, String delimiter) { assertDecamelNameNotNull(decamelName); assertDelimiterNotNull(delimiter); if (is_Null_or_TrimmedEmpty(decamelName)) { return decamelName; } final StringBuilder sb = new StringBuilder(); final List partList = splitListTrimmed(decamelName, delimiter); for (String part : partList) { boolean allUpperCase = true; for (int i = 1; i < part.length(); ++i) { if (isLowerCase(part.charAt(i))) { allUpperCase = false; } } if (allUpperCase) { part = part.toLowerCase(); } sb.append(initCap(part)); } return sb.toString(); } // *DBFlute doesn't decamelize a table and column name // (allowed to convert decamel name to a camel name in this world) // // *While LastaFlute uses this to derive action URL and for RESTful logic // so very important method after all /** * Decamelize the camel name by underscore '_' as UPPER case: *
     * e.g.
     *  o FooName to FOO_NAME
     *  o FooBarName to FOO_BAR_NAME
     *  o f to F
     *  o Foo to FOO
     *  o FFooName to F_FOO_NAME
     *  o FFFooName to F_F_FOO_NAME
     *  o fooDName to FOO_D_NAME
     *  o FOO_NAME to FOO_NAME
     *  o foo_name to FOO_NAME
     *  o FOO_NameBar to FOO_NAME_BAR
     * 
* *

Returning as upper case is traditional rule for database naming. * So already it cannot change it. Call toLowerCase() later if you need.

* * @param camelName The camelized name. (NotNull) * @return The name decamelized by underscore '_' as UPPER case. (NotNull) */ public static String decamelize(String camelName) { assertCamelNameNotNull(camelName); return doDecamelize(camelName, "_"); } /** * Decamelize the camel name by specified delimiter as UPPER case.
* See the java-doc of default-delimiter method for the detail. * @param camelName The camelized name. (NotNull) * @param delimiter The your own delimiter to decamelize. (NotNull) * @return The name decamelized by specified delimiter as UPPER case. (NotNull) */ public static String decamelize(String camelName, String delimiter) { assertCamelNameNotNull(camelName); assertDelimiterNotNull(delimiter); return doDecamelize(camelName, delimiter); } protected static String doDecamelize(String camelName, String delimiter) { assertCamelNameNotNull(camelName); assertDelimiterNotNull(delimiter); final StringBuilder sb = new StringBuilder(); final List splitList = splitList(camelName, delimiter); // one element if no delimiter for (String element : splitList) { // to separate e.g. FOO_NameBar (to FOO_NAME_BAR) if (sb.length() > 0) { sb.append(delimiter); } sb.append(actuallyDecamelize(element, delimiter)); } final String generated = sb.toString(); return replace(generated, delimiter + delimiter, delimiter); // final adjustment } protected static String actuallyDecamelize(String camelName, String delimiter) { if (is_Null_or_TrimmedEmpty(camelName)) { return camelName; } if (camelName.length() == 1) { // e.g. f return camelName.toUpperCase(); // e.g. F } if (isAlphabetNumberHarfUpperAll(camelName)) { // to avoid e.g. FOO to F_O_O return camelName; // e.g. FOO } final StringBuilder sb = new StringBuilder(); int pos = 0; for (int i = 1; i < camelName.length(); i++) { final char currentChar = camelName.charAt(i); if (isUpperCase(currentChar)) { if (sb.length() > 0) { sb.append(delimiter); } sb.append(camelName.substring(pos, i).toUpperCase()); pos = i; } } if (sb.length() > 0) { sb.append(delimiter); } sb.append(camelName.substring(pos, camelName.length()).toUpperCase()); return sb.toString(); } // =================================================================================== // SQL Handling // ============ /** * Remove empty lines.
* And CR is removed. * @param str The target string. (NotNull) * @return The filtered string. (NotNull) */ public static String removeEmptyLine(String str) { assertStringNotNull(str); final StringBuilder sb = new StringBuilder(); final List lineList = splitList(str, "\n"); for (String line : lineList) { if (is_Null_or_TrimmedEmpty(line)) { continue; // skip } sb.append(removeCR(line)).append("\n"); } final String filtered = sb.toString(); return filtered.substring(0, filtered.length() - "\n".length()); } /** * Remove block comments. * @param sql The string of SQL. (NotNull) * @return The filtered string. (NotNull) */ public static String removeBlockComment(String sql) { assertSqlNotNull(sql); return removeScope(sql, "/*", "*/"); } /** * Remove line comments.
* And CR is removed. * @param sql The string of SQL. (NotNull) * @return The filtered string. (NotNull) */ public static String removeLineComment(String sql) { // with removing CR! assertSqlNotNull(sql); final StringBuilder sb = new StringBuilder(); final List lineList = splitList(sql, "\n"); for (String line : lineList) { if (line == null) { continue; } line = removeCR(line); // remove CR! if (line.trim().startsWith("--")) { continue; } final List delimiterList = extractDelimiterList(line, "--"); int realIndex = -1; indexLoop: for (DelimiterInfo delimiter : delimiterList) { final List scopeList = extractScopeList(line, "/*", "*/"); final int delimiterIndex = delimiter.getBeginIndex(); for (ScopeInfo scope : scopeList) { if (scope.isBeforeScope(delimiterIndex)) { break; } if (scope.isInScope(delimiterIndex)) { continue indexLoop; } } // found realIndex = delimiterIndex; } if (realIndex >= 0) { line = line.substring(0, realIndex); } sb.append(line).append("\n"); } final String filtered = sb.toString(); return filtered.substring(0, filtered.length() - "\n".length()); } protected static String removeCR(String str) { if (str == null) { return null; } return str.replaceAll("\r", ""); } // =================================================================================== // Indent Handling // =============== public static String indent(int size) { final StringBuilder sb = new StringBuilder(); for (int i = 0; i < size; i++) { sb.append(" "); } return sb.toString(); } public static String indent(int size, String str) { final List lineList = splitList(removeCR(str), "\n"); final StringBuilder sb = new StringBuilder(); int index = 0; for (String element : lineList) { if (index > 0) { sb.append("\n"); } sb.append(indent(size)).append(element); ++index; } return sb.toString(); } // =================================================================================== // Character Handling // ================== public static boolean isAlphabetHarfAll(String str) { return isAnyCharAll(str, _alphabetHarfCharSet); } public static boolean isAlphabetHarfLowerAll(String str) { return isAnyCharAll(str, _alphabetHarfLowerCharSet); } public static boolean isAlphabetHarfUpperAll(String str) { return isAnyCharAll(str, _alphabetHarfUpperCharSet); } public static boolean isNumberHarfAll(String str) { return isAnyCharAll(str, _numberHarfCharSet); } public static boolean isAlphabetNumberHarfAll(String str) { return isAnyCharAll(str, _alphabetHarfNumberHarfCharSet); } public static boolean isAlphabetNumberHarfAllOr(String str, Character... addedChars) { final Set charSet = new HashSet(_alphabetHarfNumberHarfCharSet); for (Character ch : addedChars) { charSet.add(ch); } return isAnyCharAll(str, charSet); } public static boolean isAlphabetNumberHarfLowerAll(String str) { return isAnyCharAll(str, _alphabetNumberHarfLowerCharSet); } public static boolean isAlphabetNumberHarfUpperAll(String str) { return isAnyCharAll(str, _alphabetNumberHarfUpperCharSet); } protected static boolean isAnyCharAll(String str, Set charSet) { if (is_Null_or_Empty(str)) { return false; } final char[] chAry = str.toCharArray(); for (int i = 0; i < chAry.length; i++) { final char ch = chAry[i]; if (!charSet.contains(ch)) { return false; } } return true; } // ----------------------------------------------------- // Lower Case // ---------- protected static boolean isLowerCase(char ch) { return Character.isLowerCase(ch); } protected static boolean isLowerCase(char ch1, char ch2) { return isLowerCase(ch1) && isLowerCase(ch2); } public static boolean isLowerCaseAll(String str) { assertStringNotNull(str); final int length = str.length(); if (length == 0) { return false; } for (int i = 0; i < length; ++i) { if (!isLowerCase(str.charAt(i))) { return false; } } return true; } public static boolean isLowerCaseAny(String str) { assertStringNotNull(str); final int length = str.length(); if (length == 0) { return false; } for (int i = 0; i < length; ++i) { if (isLowerCase(str.charAt(i))) { return true; } } return false; } // ----------------------------------------------------- // Upper Case // ---------- protected static boolean isUpperCase(char ch) { return Character.isUpperCase(ch); } protected static boolean isUpperCase(char ch1, char ch2) { return isUpperCase(ch1) && isUpperCase(ch2); } public static boolean isUpperCaseAll(String str) { assertStringNotNull(str); final int length = str.length(); if (length == 0) { return false; } for (int i = 0; i < length; ++i) { if (!isUpperCase(str.charAt(i))) { return false; } } return true; } public static boolean isUpperCaseAny(String str) { assertStringNotNull(str); final int length = str.length(); if (length == 0) { return false; } for (int i = 0; i < length; ++i) { if (isUpperCase(str.charAt(i))) { return true; } } return false; } // =================================================================================== // Assert Helper // ============= protected static void assertStringNotNull(String str) { assertObjectNotNull("str", str); } protected static void assertStringListNotNull(Collection strList) { assertObjectNotNull("strList", strList); } protected static void assertElementNotNull(String element) { assertObjectNotNull("element", element); } protected static void assertElementVaryingNotNull(String[] elements) { assertObjectNotNull("elements", elements); } protected static void assertKeywordNotNull(String keyword) { assertObjectNotNull("keyword", keyword); } protected static void assertKeywordVaryingNotNull(String[] keywords) { assertObjectNotNull("keywords", keywords); } protected static void assertPrefixNotNull(String prefix) { assertObjectNotNull("prefix", prefix); } protected static void assertSuffixNotNull(String suffix) { assertObjectNotNull("suffix", suffix); } protected static void assertFromToMapNotNull(Map fromToMap) { assertObjectNotNull("fromToMap", fromToMap); } protected static void assertDelimiterNotNull(String delimiter) { assertObjectNotNull("delimiter", delimiter); } protected static void assertFromStringNotNull(String fromStr) { assertObjectNotNull("fromStr", fromStr); } protected static void assertToStringNotNull(String toStr) { assertObjectNotNull("toStr", toStr); } protected static void assertQuotationNotNull(String quotation) { assertObjectNotNull("quotation", quotation); } protected static void assertBeginMarkNotNull(String beginMark) { assertObjectNotNull("beginMark", beginMark); } protected static void assertEndMarkNotNull(String endMark) { assertObjectNotNull("endMark", endMark); } protected static void assertDecamelNameNotNull(String decamelName) { assertObjectNotNull("decamelName", decamelName); } protected static void assertCamelNameNotNull(String camelName) { assertObjectNotNull("camelName", camelName); } protected static void assertSqlNotNull(String sql) { assertObjectNotNull("sql", sql); } /** * Assert that the object is not null. * @param variableName The check name of variable for message. (NotNull) * @param value The checked value. (NotNull) * @throws IllegalArgumentException When the argument is null. */ protected static void assertObjectNotNull(String variableName, Object value) { if (variableName == null) { String msg = "The value should not be null: variableName=null value=" + value; throw new IllegalArgumentException(msg); } if (value == null) { String msg = "The value should not be null: variableName=" + variableName; throw new IllegalArgumentException(msg); } } /** * Assert that the entity is not null and not trimmed empty. * @param variableName The check name of variable for message. (NotNull) * @param value The checked value. (NotNull) */ protected static void assertStringNotNullAndNotTrimmedEmpty(String variableName, String value) { assertObjectNotNull("variableName", variableName); assertObjectNotNull("value", value); if (value.trim().length() == 0) { String msg = "The value should not be empty: variableName=" + variableName + " value=" + value; throw new IllegalArgumentException(msg); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy