Patterns.java

// Generated by delombok at Mon Jan 06 07:19:11 UTC 2025
package de.larssh.utils.text;

import java.util.Optional;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * This class contains helper methods for {@link Pattern}.
 */
public final class Patterns {
	/**
	 * Pattern that matches every character to be escaped inside a pattern.
	 */
	private static final Pattern QUOTE_PATTERN = Pattern.compile("[\\\\\\[\\].^$?*+{}|()]");

	/**
	 * Attempts to find the first subsequence of the input sequence that matches the
	 * given pattern.
	 *
	 * <p>
	 * Use {@link Strings#find(CharSequence, Pattern)} if you do <b>not</b> need a
	 * matcher.
	 *
	 * @param pattern the pattern
	 * @param input   the input sequence to find the pattern in
	 * @return if the match succeeds then more information can be obtained via the
	 *         returned {@link Matcher} object or else {@link Optional#empty()} is
	 *         returned
	 */
	public static Optional<Matcher> find(final Pattern pattern, final CharSequence input) {
		final Matcher matcher = pattern.matcher(input);
		return matcher.find() ? Optional.of(matcher) : Optional.empty();
	}

	/**
	 * Attempts to match the entire region against the pattern.
	 *
	 * <p>
	 * Use {@link Strings#matches(CharSequence, Pattern)} if you do <b>not</b> need
	 * a matcher.
	 *
	 * @param pattern the pattern
	 * @param input   the input sequence to match against the pattern
	 * @return if the match succeeds then more information can be obtained via the
	 *         returned {@link Matcher} object or else {@link Optional#empty()} is
	 *         returned
	 */
	public static Optional<Matcher> matches(final Pattern pattern, final CharSequence input) {
		final Matcher matcher = pattern.matcher(input);
		return matcher.matches() ? Optional.of(matcher) : Optional.empty();
	}

	/**
	 * Returns a pattern string matching exactly {@code input}.
	 *
	 * <p>
	 * This method escapes character-wise, while the original
	 * {@link Pattern#quote(String)} uses escapes sequences using {@code \Q} and
	 * {@code \E}.
	 *
	 * <p>
	 * <b>Example:</b> {@code C:\test.txt} results in {@code C:\\test\.txt}.
	 *
	 * @param input the string to be literalized
	 * @return the literal string replacement
	 */
	public static String quote(final CharSequence input) {
		return Strings.replaceAll(input, QUOTE_PATTERN, "\\\\$0").replace("\t", "\\t").replace("\n", "\\n").replace("\r", "\\r").replace("\f", "\\f").replace("\007", "\\a").replace("\033", "\\e");
	}

	@java.lang.SuppressWarnings("all")
	@edu.umd.cs.findbugs.annotations.SuppressFBWarnings(justification = "generated code")
	@lombok.Generated
	private Patterns() {
		throw new java.lang.UnsupportedOperationException("This is a utility class and cannot be instantiated");
	}
}