
fj.function.Strings Maven / Gradle / Ivy
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 - 2025 Weber Informatics LLC | Privacy Policy