Class XChars
public final class XChars extends Object
-
Method Summary
Modifier and Type Method Description static VarStringaddSystemString(Object instance, VarString vs)static char[]append(char[] string, char c)static char[]append(char[] a, char[] b)static char[]append(char c, char[] string)static VarStringappendArraySeperated(VarString vc, char separator, Object... elements)static VarStringappendArraySeperated(VarString vs, String separator, Object... elements)static booleanapplies(CharSequence chars, int startIndex, _charPredicate predicate)static booleanapplies(CharSequence chars, _charPredicate predicate)static VarStringassembleCautiously(VarString vs, Object object)Assembles the passed instance "cautiously" in the sense that only types recognizable viaXTypes.isValueType(Object)get assembled using theirObject.toString()method, while all others are assembled usingsystemString(Object)(which behaves identical to the actual implementation ofObject.toString()).static VarStringassembleNewLinedTabbed(VarString vs, CharSequence... elements)static VarStringassembleSeparated(VarString vs, char separator, CharSequence... elements)static StringasString(char c)This method does intentionally not use the pseudo-constructor naming pattern since it does not create new instances ofString.static StringasString(char... chars)static intcommonPrefixLength(char[] a, char[] b)static intcommonSubstringLength(char[] a, char[] b)static intcommonSuffixLength(char[] a, char[] b)static char[]concat(char[]... arrays)static Stringconcat(char separator, Object... parts)static booleancontains(char[] data, char c)static booleancontains(char[] data, int dataOffset, int dataLength, char c)static booleancontains(char[] subject, int subjectOffset, int subjectLength, char[] sample, int sampleOffset, int sampleLength)static booleancontains(String[] strings, String subject)static booleancontains(String s, char c)static StringconvertUnderscoresToCamelCase(String parameterName)static VarStringconvertUnderscoresToCamelCase(VarString vs, String s)static intcount(char[] input, int startIndex, int boundIndex, char c)static intcount(char[] data, int dataOffset, int dataCount, char[] subject, int subjectOffset, int subjectCount)static intcountCharacter(String data, char c)static intcountCodePoint(String data, int codePoint)static StringcreateMedialCapitalsString(String... elements)static CharsetdefaultJvmCharset()Alias forCharset.defaultCharset(), which returns sometimes the one thing and sometimes another.static StringensureCharAtEnd(String s, char c)static booleanequals(char[] chars1, int offset1, char[] chars2, int offset2, int length)static booleanequals(String string, char[] chars, int offset)static StringescapeChar(char c)static VarStringescapeChar(VarString vc, char c)static booleanhasContent(CharSequence s)static booleanhasContent(String s)static inthashCode(char[] chars, int offset, int length)This method rebuilds theStringhashing algorithm as the JDK guys forgot as usual to make their stuff professionally modular.static booleanhasNoContent(CharSequence s)static booleanhasNoContent(String s)static intindexOf(char[] data, char c)static intindexOf(char[] data, int dataLength, char[] subject)static intindexOf(char[] source, int sourceCount, char[] target, int targetCount, int fromIndex)static intindexOf(char[] data, int offset, int length, char c)static intindexOf(char[] data, int dataOffset, int dataLength, char[] chars)static intindexOf(char[] source, int sourceOffset, int sourceCount, char[] target, int targetOffset, int targetCount, int fromIndex)static longinternalParse_longLiteral(char[] input, int offset, int length)Specialcase higher performance implementation of decimal integer literal parsing.static booleanintersects(char[] chars1, char[] chars2)Returnstrueif the two given character arrays have at least one character in common.static booleanisDigit(char c)static booleanisEmpty(CharSequence cs)static booleanisEqual(String s1, String s2)static booleanisEqualIgnoreCase(String s1, String s2)static booleanisNonWhitespace(char c)static booleanisWhitespace(char c)static voiditerate(char[] chars, int offset, int length, _charProcedure iterator)static voiditerate(char[] chars, _charProcedure iterator)static voiditerate(CharSequence chars, _charProcedure iterator)static voiditerate(String chars, _charProcedure iterator)static char[]longestCommonPrefix(char[] a, char[] b)static StringlongestCommonPrefix(String a, String b)static intlongestCommonPrefixLength(String a, String b)static char[]longestCommonSubstring(char[] a, char[] b)static StringlongestCommonSubstring(String a, String b)static intlongestCommonSubstringLength(String a, String b)static char[]longestCommonSuffix(char[] a, char[] b)static StringlongestCommonSuffix(String a, String b)static intlongestCommonSuffixLength(String a, String b)static StringlowerCaseFirstChar(String s)static StringmathRangeExcExc(double lowerBound, double upperBound)static StringmathRangeExcExc(long lowerBound, long upperBound)static StringmathRangeExcExc(String lowerBound, String upperBound)static StringmathRangeExcInc(double lowerBound, double maximum)static StringmathRangeExcInc(long lowerBound, long maximum)static StringmathRangeExcInc(String lowerBound, String maximum)static StringmathRangeIncExc(double minimum, double upperBound)static StringmathRangeIncExc(long minimum, long upperBound)static StringmathRangeIncExc(String minimum, String upperBound)static StringmathRangeIncInc(double minimum, double maximum)static StringmathRangeIncInc(long minimum, long maximum)static StringmathRangeIncInc(String minimum, String maximum)static intmaxCharCount_boolean()static intmaxCharCount_byte()static intmaxCharCount_char()static intmaxCharCount_double()static intmaxCharCount_float()static intmaxCharCount_int()static intmaxCharCount_long()static intmaxCharCount_short()static StringnonNullString(Object object)static <C extends CharSequence>
CnotEmpty(C charSequence)static StringpadLeft(String s, int totalLength)static StringpadLeft(String s, int totalLength, char paddingChar)static StringpadLeft0(String s, int totalLength)static StringpadRight(String s, int totalLength)static StringpadRight(String s, int totalLength, char paddingChar)static StringpadRight0(String s, int totalLength)static StringpadSpace(String s, int chars)static byteparse_byteDecimal(char[] input)static byteparse_byteDecimal(char[] input, int offset, int length)static doubleparse_double(char[] input, int offset, int length)static floatparse_float(char[] input, int offset, int length)static intparse_intLiteral(char[] input)static intparse_intLiteral(char[] input, int offset, int length)static longparse_longDecimal(char[] input)static longparse_longDecimal(char[] input, int offset, int length)static shortparse_shortDecimal(char[] input)static shortparse_shortDecimal(char[] input, int offset, int length)static charparseChar(String s)Parses the char escape sequence Strings "\n" etc.static int[]parseTo_intArray(String... intStrings)static Integer[]parseToIntegerArray(String... intStrings)static intput(boolean value, char[] target, int offset)static intput(byte value, char[] target, int offset)static intput(char[] value, char[] target, int offset)static intput(double value, char[] target, int offset)static intput(float value, char[] target, int offset)static intput(int value, char[] target, int offset)static intput(long value, char[] target, int offset)static intput(short value, char[] target, int offset)static intput(String s, char[] target, int offset)static intputFalse(char[] target, int offset)static intputHexDec(byte value, char[] target, int offset)static intputNull(char[] target, int offset)static intputTrue(char[] target, int offset)static charrandomReadable_char()static VarBytereadAllBytesFromInputStream(InputStream inputStream)static VarBytereadAllBytesFromInputStream(VarByte bytes, InputStream inputStream)static char[]readChars(String s)static StringreadStringFromInputStream(InputStream inputStream, Charset charset)static intreplaceFirst(char[] chars, int offset, int length, char sample, char replacement)static intshortStringLength()Arbitrary threshold of 1000 to discrimate "short" strings from "long" strings.
The rationale behind that is that "short" strings usually allow for simpler and faster algorithms, which become inefficient on larger strings.static <C extends Consumer<String>>
CsplitAndTrimToStrings(char[] input, char separator, C collector)High-performance implementation of the very common case to split a character sequence by a single character and trim all elements.static <C extends Consumer<String>>
CsplitAndTrimToStrings(String input, char separator, C collector)High-performance implementation of the very common case to split a string by a single character and trim all elements.static String[]splitSimple(String s, String separator)static <C extends Consumer<? super String>>
CsplitSimple(String s, String separator, C collector)static CharsetstandardCharset()ReturnsStandardCharsets.UTF_8, because any other one out there is nonsense as a standard.static StringString(boolean value)static StringString(byte value)static StringString(byte[] chars)static StringString(byte[] chars, int offset, int length)static StringString(byte[] chars, int offset, int length, Charset charset)static StringString(byte[] chars, Charset charset)static StringString(char value)static StringString(char[] chars)static StringString(char[] chars, int offset, int length)static StringString(double value)static StringString(float value)static StringString(int value)static StringString(long value)static StringString(short value)static StringString(ByteBuffer chars)static StringString(ByteBuffer chars, int offset, int length)static StringString(ByteBuffer chars, int offset, int length, Charset charset)static StringString(ByteBuffer chars, Charset charset)static StringBufferStringBuffer(VarString vs)static StringBufferStringBuffer(VarString vs, int offset, int length)static StringBuilderStringBuilder(VarString vs)static StringBuilderStringBuilder(VarString vs, int offset, int length)static char[]substring(char[] string, int offset, int bound)static StringsystemString(Object instance)Utility method that replicates the JVM's intrinsic system string as defined inObject.toString().static intto_int(char digit)static char[][]toArrays(XGettingSequence<String> strings)static char[]toCharArray(CharSequence c)static char[]toCharArray(StringBuffer asb)static char[]toCharArray(StringBuilder asb)static chartoHexadecimal(int b)static StringtoSingleLine(String multiLineString, String lineBreakReplacement)static Stringtrim(String s)CallsString.trim()on a non-null argument, returnsnullotherwise.static StringtrimEmptyToNull(String s)static StringtrimToString(char[] input, int lowerOffset, int length)Creates aStringinstance with trimmed content directly from a character sequence without unnecessary intermediate instances.static byteuncheckedParse_byteDecimal(char[] input, int offset, int length)static intuncheckedParse_intLiteral(char[] input, int offset, int length)static longuncheckedParse_longLiteral(char[] input, int offset, int length)static shortuncheckedParse_shortDecimal(char[] input, int offset, int length)static StringupperCaseFirstChar(String s)Ensures that the first character of the passedStringis in upper case.static Charsetutf8()It's UTF-8!static voidvalidateIndex(char[] chars, int index)static voidvalidateRange(char[] chars, int offset, int length)static StringvalueString(Object value)Returnsvalue.toString()if the passed value is not null, otherwise null.
-
Method Details
-
maxCharCount_byte
public static final int maxCharCount_byte() -
maxCharCount_boolean
public static final int maxCharCount_boolean() -
maxCharCount_short
public static final int maxCharCount_short() -
maxCharCount_char
public static final int maxCharCount_char() -
maxCharCount_int
public static final int maxCharCount_int() -
maxCharCount_float
public static final int maxCharCount_float() -
maxCharCount_long
public static final int maxCharCount_long() -
maxCharCount_double
public static final int maxCharCount_double() -
isWhitespace
public static final boolean isWhitespace(char c) -
isNonWhitespace
public static final boolean isNonWhitespace(char c) -
shortStringLength
public static final int shortStringLength()Arbitrary threshold of 1000 to discrimate "short" strings from "long" strings.
The rationale behind that is that "short" strings usually allow for simpler and faster algorithms, which become inefficient on larger strings. For example a two-pass processing of a splitting algorithm.- Returns:
- 1000
-
utf8
It's UTF-8!- Returns:
StandardCharsets.UTF_8
-
standardCharset
ReturnsStandardCharsets.UTF_8, because any other one out there is nonsense as a standard.- Returns:
java.nio.charset.Charset.forName("UTF-8").
-
defaultJvmCharset
Alias forCharset.defaultCharset(), which returns sometimes the one thing and sometimes another. It is strongly advised to use a reliableCharsetquerying method, like UTF-8, which also is the only reasonable choice for the standard charset.- Returns:
Charset.defaultCharset()
-
validateIndex
public static final void validateIndex(char[] chars, int index) -
validateRange
public static final void validateRange(char[] chars, int offset, int length) -
isEqual
-
equals
-
equals
public static final boolean equals(char[] chars1, int offset1, char[] chars2, int offset2, int length) -
isEqualIgnoreCase
-
toHexadecimal
- Throws:
IllegalArgumentException
-
indexOf
public static final int indexOf(char[] data, char c) -
indexOf
public static final int indexOf(char[] data, int offset, int length, char c) -
indexOf
public static final int indexOf(char[] source, int sourceOffset, int sourceCount, char[] target, int targetOffset, int targetCount, int fromIndex) -
readAllBytesFromInputStream
public static final VarByte readAllBytesFromInputStream(VarByte bytes, InputStream inputStream) throws IOException- Throws:
IOException
-
readAllBytesFromInputStream
public static final VarByte readAllBytesFromInputStream(InputStream inputStream) throws IOException- Throws:
IOException
-
readStringFromInputStream
public static final String readStringFromInputStream(InputStream inputStream, Charset charset) throws IOException- Throws:
IOException
-
indexOf
public static final int indexOf(char[] data, int dataLength, char[] subject) -
indexOf
public static final int indexOf(char[] data, int dataOffset, int dataLength, char[] chars) -
indexOf
public static final int indexOf(char[] source, int sourceCount, char[] target, int targetCount, int fromIndex) -
replaceFirst
public static final int replaceFirst(char[] chars, int offset, int length, char sample, char replacement) -
count
public static final int count(char[] input, int startIndex, int boundIndex, char c) -
count
public static final int count(char[] data, int dataOffset, int dataCount, char[] subject, int subjectOffset, int subjectCount) -
hasContent
-
hasNoContent
-
hasContent
-
hasNoContent
-
asString
This method does intentionally not use the pseudo-constructor naming pattern since it does not create new instances ofString. Instead, it returns a constant instance of an intrinsic look-up table. -
asString
-
upperCaseFirstChar
Ensures that the first character of the passedStringis in upper case.If the passed
Stringisnull, has a length of 0 or already has an upper case first character, it is returned. Otherwise, the first character of the passedStringis transformed to upper case and concatenated with the rest of the passedStringinto a newStringinstance.- Parameters:
s- theStringfor which the first character shall be ensured to be upper case.- Returns:
- a string equalling s with its first character being guaranteed to be upper case.
-
lowerCaseFirstChar
-
concat
public static final char[] concat(char[]... arrays) -
appendArraySeperated
-
appendArraySeperated
-
toCharArray
-
toCharArray
-
toCharArray
-
intersects
public static final boolean intersects(char[] chars1, char[] chars2)Returnstrueif the two given character arrays have at least one character in common.- Parameters:
chars1-chars2-- Returns:
trueif the two given character arrays intersect each other.
-
append
public static final char[] append(char c, char[] string) -
append
public static final char[] append(char[] string, char c) -
append
public static final char[] append(char[] a, char[] b) -
longestCommonSubstringLength
-
commonSubstringLength
public static final int commonSubstringLength(char[] a, char[] b) -
longestCommonSubstring
-
longestCommonSubstring
public static final char[] longestCommonSubstring(char[] a, char[] b) -
substring
public static final char[] substring(char[] string, int offset, int bound) -
convertUnderscoresToCamelCase
-
convertUnderscoresToCamelCase
-
longestCommonPrefixLength
-
longestCommonSuffixLength
-
longestCommonSuffix
-
longestCommonPrefix
-
commonPrefixLength
public static final int commonPrefixLength(char[] a, char[] b) -
commonSuffixLength
public static final int commonSuffixLength(char[] a, char[] b) -
longestCommonSuffix
public static final char[] longestCommonSuffix(char[] a, char[] b) -
longestCommonPrefix
public static final char[] longestCommonPrefix(char[] a, char[] b) -
padLeft
-
padRight
-
padLeft
-
padRight
-
padLeft0
-
padRight0
-
parseChar
Parses the char escape sequence Strings "\n" etc. (wihtout the "") to the singel char value represented by those strings.- Parameters:
s-
-
escapeChar
-
escapeChar
-
createMedialCapitalsString
-
ensureCharAtEnd
-
toSingleLine
-
padSpace
-
concat
-
notEmpty
-
isEmpty
-
iterate
-
iterate
-
iterate
-
iterate
-
put
public static final int put(byte value, char[] target, int offset) -
putHexDec
public static final int putHexDec(byte value, char[] target, int offset) -
put
public static final int put(boolean value, char[] target, int offset) -
put
public static final int put(short value, char[] target, int offset) -
put
public static final int put(int value, char[] target, int offset) -
put
public static final int put(float value, char[] target, int offset) -
put
public static final int put(long value, char[] target, int offset) -
put
public static final int put(double value, char[] target, int offset) -
put
-
put
public static final int put(char[] value, char[] target, int offset) -
putNull
public static final int putNull(char[] target, int offset) -
putTrue
public static final int putTrue(char[] target, int offset) -
putFalse
public static final int putFalse(char[] target, int offset) -
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
String
-
StringBuilder
-
StringBuilder
-
StringBuffer
-
StringBuffer
-
readChars
-
hashCode
public static final int hashCode(char[] chars, int offset, int length)This method rebuilds theStringhashing algorithm as the JDK guys forgot as usual to make their stuff professionally modular.Returns a hash code for the passed character range. The hash code is computed as
usings[0]*31^(n - 1) + s[1]*31^(n-2) + ... + s[n - 1]
intarithmetic, wheres[i]is the ith character counted from the given offset,nis the length and^indicates exponentiation. The hash value of an empty range is zero.- Returns:
- a hash code value for this object.
- See Also:
String.hashCode()
-
splitAndTrimToStrings
public static final <C extends Consumer<String>> C splitAndTrimToStrings(String input, char separator, C collector)High-performance implementation of the very common case to split a string by a single character and trim all elements.- Parameters:
input-separator-- See Also:
trimToString(char[], int, int)
-
splitAndTrimToStrings
public static final <C extends Consumer<String>> C splitAndTrimToStrings(char[] input, char separator, C collector)High-performance implementation of the very common case to split a character sequence by a single character and trim all elements.- Parameters:
input-separator-- See Also:
trimToString(char[], int, int)
-
splitSimple
-
splitSimple
-
trimToString
Creates aStringinstance with trimmed content directly from a character sequence without unnecessary intermediate instances.- Parameters:
input-lowerOffset-length-
-
trim
CallsString.trim()on a non-null argument, returnsnullotherwise. (this is nothing but a staticString.trim()) -
parseTo_intArray
-
parseToIntegerArray
-
assembleNewLinedTabbed
-
assembleSeparated
public static final VarString assembleSeparated(VarString vs, char separator, CharSequence... elements) -
parse_byteDecimal
public static final byte parse_byteDecimal(char[] input) -
parse_shortDecimal
public static final short parse_shortDecimal(char[] input) -
parse_intLiteral
public static final int parse_intLiteral(char[] input) -
parse_longDecimal
public static final long parse_longDecimal(char[] input) -
parse_byteDecimal
public static final byte parse_byteDecimal(char[] input, int offset, int length) -
parse_shortDecimal
public static final short parse_shortDecimal(char[] input, int offset, int length) -
parse_intLiteral
public static final int parse_intLiteral(char[] input, int offset, int length) -
parse_longDecimal
public static final long parse_longDecimal(char[] input, int offset, int length) -
parse_float
public static final float parse_float(char[] input, int offset, int length) -
parse_double
public static final double parse_double(char[] input, int offset, int length) -
uncheckedParse_byteDecimal
public static final byte uncheckedParse_byteDecimal(char[] input, int offset, int length) -
uncheckedParse_shortDecimal
public static final short uncheckedParse_shortDecimal(char[] input, int offset, int length) -
uncheckedParse_intLiteral
public static final int uncheckedParse_intLiteral(char[] input, int offset, int length) -
uncheckedParse_longLiteral
public static final long uncheckedParse_longLiteral(char[] input, int offset, int length) -
internalParse_longLiteral
public static final long internalParse_longLiteral(char[] input, int offset, int length)Specialcase higher performance implementation of decimal integer literal parsing. Because as usual, the JDK implementation strategies are not acceptable when dealing with non-trivial amounts of data. Properly executed performance tests (large loop sizes, averages, nanosecond precision, etc.) showed that this algorithms is more than twice as fast as the one used in JDK (average of ~33µs vs ~75µs for long literals on same machine with measuring overhead of ~1.5µs)- Parameters:
input-offset-length-
-
to_int
public static final int to_int(char digit) -
toArrays
-
contains
-
contains
-
contains
public static final boolean contains(char[] subject, int subjectOffset, int subjectLength, char[] sample, int sampleOffset, int sampleLength) -
contains
public static final boolean contains(char[] data, char c) -
contains
public static final boolean contains(char[] data, int dataOffset, int dataLength, char c) -
systemString
Utility method that replicates the JVM's intrinsic system string as defined inObject.toString(). (It's funny how much functionality is missing in the JDK API).- Parameters:
instance- the instance whose system string shall be generated.- Returns:
- the system string for the passed instance.
-
addSystemString
-
nonNullString
-
valueString
Returnsvalue.toString()if the passed value is not null, otherwise null.Note that this is a different behavior than
String.valueOf(Object)has, as the latter returns the string"null"for a passed null reference. The latter is merely an output helper method, albeit clumsily named and placed as if it were a general utility method. THIS method here is the far more useful general utility method.The behavior of this method is needed for example for converting values in a generic data structure (e.g. a Object[] array) to string values but have the actual values, including null (information about a missing value), maintained.
- Parameters:
value- the value to be projected to its string representation if not null.- Returns:
- a string representation of an actual passed value or a transient null.
- See Also:
Object.toString(),String.valueOf(Object)
-
trimEmptyToNull
-
assembleCautiously
Assembles the passed instance "cautiously" in the sense that only types recognizable viaXTypes.isValueType(Object)get assembled using theirObject.toString()method, while all others are assembled usingsystemString(Object)(which behaves identical to the actual implementation ofObject.toString()).- Parameters:
vs- theVarStringinstance to hold the assembled string.object- the instance to be assembled "cautiously" as described above.- Returns:
- the passed vs instance (method-chaining viable).
- See Also:
VarString.add(Object, java.util.function.BiConsumer),XTypes.isValueType(Object),Object.toString(),systemString(Object)
-
applies
-
applies
-
isDigit
public static boolean isDigit(char c) -
randomReadable_char
public static char randomReadable_char() -
countCharacter
-
countCodePoint
-
mathRangeIncInc
-
mathRangeIncExc
-
mathRangeExcInc
-
mathRangeExcExc
-
mathRangeIncInc
-
mathRangeIncExc
-
mathRangeExcInc
-
mathRangeExcExc
-
mathRangeIncInc
-
mathRangeIncExc
-
mathRangeExcInc
-
mathRangeExcExc
-