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

fj.function.Strings Maven / Gradle / Ivy

Go to download

Functional Java is an open source library that supports closures for the Java programming language

There is a newer version: 5.0
Show newest version
package fj.function;

import fj.F;
import fj.data.List;
import fj.data.Stream;

import java.util.regex.Pattern;

import static fj.Function.curry;
import static fj.function.Booleans.not;
import static fj.function.Characters.isWhitespace;

/**
 * Curried string functions.
 *
 * @version %build.number%
 */
public final class Strings {
  private Strings() {
    throw new UnsupportedOperationException();
  }

  private static final Pattern lineSeparatorPattern = Pattern.compile("\\r?\\n");

  public static final String lineSeparator = System.getProperty("line.separator");

    /**
     * This function checks if a given String is neither null nor empty.
     *
     * @see #isNullOrEmpty
     */
    public static final F isNotNullOrEmpty = a -> a != null && a.length() > 0;

    /**
     * This function checks if a given String is null or empty ({@link String#isEmpty()}).
     *
     * @see #isNotNullOrEmpty
     */
    public static final F isNullOrEmpty = a -> a == null || a.length() == 0;

    /**
   * This function checks if a given String contains any non-whitespace character
   * (according to {@link Character#isWhitespace(char)}) and if it's also not
   * null and not empty ("").
   * 
   * @see #isNullOrBlank
   * @see Character#isWhitespace(char)
   * @see Characters#isWhitespace
   */
  public static final F isNotNullOrBlank = a -> isNotNullOrEmpty.f(a) && Stream.fromString(a).find(not(isWhitespace)).isSome();
  /**
   * This function checks if a given String is whitespace (according to {@link Character#isWhitespace(char)}),
   * empty ("") or null.
   * 
   * @see #isNotNullOrBlank
   * @see Character#isWhitespace(char)
   * @see Characters#isWhitespace
   */
  public static final F isNullOrBlank = a -> isNullOrEmpty.f(a) || Stream.fromString(a).find(not(isWhitespace)).isNone();

  /**
   * A curried version of {@link String#isEmpty()}.
   */
  public static final F isEmpty = s -> s.length() == 0;

  /**
   * A curried version of {@link String#length()}.
   */
  public static final F length = String::length;

  /**
   * A curried version of {@link String#contains(CharSequence)}.
   * The function returns true if the second argument contains the first.
   */
  public static final F> contains = curry((s1, s2) -> s2.contains(s1));

  /**
   * A curried version of {@link String#matches(String)}.
   * The function returns true if the second argument matches the first.
   */
  public static final F> matches = curry((s1, s2) -> s2.matches(s1));

  public static List lines(String s) {
    return List.list(lineSeparatorPattern.split(s));
  }

  public static F> lines() {
    return Strings::lines;
  }

  public static String unlines(List list) {
    StringBuilder sb = new StringBuilder();
    list.intersperse(lineSeparator).foreachDoEffect(sb::append);
    return sb.toString();
  }

  public static F, String> unlines() {
    return Strings::unlines;
  }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy