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

org.finos.legend.pure.m4.tools.TextTools Maven / Gradle / Ivy

There is a newer version: 5.23.0
Show newest version
// Copyright 2024 Goldman Sachs
//
// 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.finos.legend.pure.m4.tools;

public class TextTools
{
    /**
     * Return the index of the first non-whitespace character found in the given text, or -1 if no non-whitespace
     * character is found.
     *
     * @param text text
     * @return index of first non-whitespace character or -1
     * @see #indexOfWhitespace(String)
     * @see #isBlank
     */
    public static int indexOfNonWhitespace(String text)
    {
        return indexOfNonWhitespace(text, 0);
    }

    /**
     * Return the index of the first non-whitespace character found in a region of text (starting from start), or -1 if
     * no non-whitespace character is found.
     *
     * @param text  text
     * @param start start of region (inclusive)
     * @return index of first non-whitespace character or -1
     * @see #indexOfWhitespace(String, int)
     * @see #isBlank
     */
    public static int indexOfNonWhitespace(String text, int start)
    {
        return indexOfNonWhitespace(text, start, text.length());
    }

    /**
     * Return the index of the first non-whitespace character found in a region of text, or -1 if no non-whitespace
     * character is found.
     *
     * @param text  text
     * @param start start of region (inclusive)
     * @param end   end of region (exclusive)
     * @return index of first non-whitespace character or -1
     * @see #indexOfWhitespace(String, int, int)
     * @see #isBlank
     */
    public static int indexOfNonWhitespace(String text, int start, int end)
    {
        checkRegionBounds(text, start, end);
        int codePoint;
        for (int i = start; i < end; i += Character.charCount(codePoint))
        {
            codePoint = text.codePointAt(i);
            if (!Character.isWhitespace(codePoint))
            {
                return i;
            }
        }
        return -1;
    }

    /**
     * Return the index of the first whitespace character found in the given text, or -1 if no whitespace character is
     * found.
     *
     * @param text text
     * @return index of first whitespace character or -1
     * @see #indexOfNonWhitespace(String)
     * @see #isBlank
     */
    public static int indexOfWhitespace(String text)
    {
        return indexOfWhitespace(text, 0);
    }

    /**
     * Return the index of the first whitespace character found in a region of text (starting from start), or -1 if no
     * whitespace character is found.
     *
     * @param text  text
     * @param start start of region (inclusive)
     * @return index of first whitespace character or -1
     * @see #indexOfNonWhitespace(String, int)
     * @see #isBlank
     */
    public static int indexOfWhitespace(String text, int start)
    {
        return indexOfWhitespace(text, start, text.length());
    }

    /**
     * Return the index of the first whitespace character found in a region of text, or -1 if no whitespace character is
     * found.
     *
     * @param text  text
     * @param start start of region (inclusive)
     * @param end   end of region (exclusive)
     * @return index of first whitespace character or -1
     * @see #indexOfNonWhitespace(String, int, int)
     * @see #isBlank
     */
    public static int indexOfWhitespace(String text, int start, int end)
    {
        checkRegionBounds(text, start, end);
        int codePoint;
        for (int i = start; i < end; i += Character.charCount(codePoint))
        {
            codePoint = text.codePointAt(i);
            if (Character.isWhitespace(codePoint))
            {
                return i;
            }
        }
        return -1;
    }

    /**
     * Return whether a region of text is blank, meaning it is empty or contains only whitespace.
     *
     * @param text  text
     * @param start start of region (inclusive)
     * @param end   end of region (exclusive)
     * @return whether the region of text is blank
     * @see #indexOfNonWhitespace(String, int, int)
     */
    public static boolean isBlank(String text, int start, int end)
    {
        checkRegionBounds(text, start, end);
        return indexOfNonWhitespace(text, start, end) == -1;
    }

    private static void checkRegionBounds(String text, int start, int end)
    {
        if ((start < 0) || (start > end) || (end > text.length()))
        {
            throw new StringIndexOutOfBoundsException("start " + start + ", end " + end + ", length " + text.length());
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy