- java.lang.Object
-
- io.netty5.util.internal.StringUtil
-
public final class StringUtil extends Object
String utility class.
-
-
Field Summary
Fields Modifier and Type Field Description static charCARRIAGE_RETURNstatic charCOMMAstatic charDOUBLE_QUOTEstatic StringEMPTY_STRINGstatic charLINE_FEEDstatic StringNEWLINEstatic charSPACEstatic charTAB
-
Method Summary
All Methods Static Methods Concrete Methods Modifier and Type Method Description static StringbyteToHexString(int value)Converts the specified byte value into a hexadecimal integer.static <T extends Appendable>
TbyteToHexString(T buf, int value)Converts the specified byte value into a hexadecimal integer and appends it to the specified buffer.static StringbyteToHexStringPadded(int value)Converts the specified byte value into a 2-digit hexadecimal integer.static <T extends Appendable>
TbyteToHexStringPadded(T buf, int value)Converts the specified byte value into a 2-digit hexadecimal integer and appends it to the specified buffer.static booleancommonSuffixOfLength(String s, String p, int len)Checks if two strings have the same suffix of specified lengthstatic bytedecodeHexByte(CharSequence s, int pos)Decode a 2-digit hex byte from within a string.static byte[]decodeHexDump(CharSequence hexDump)Decodes a hex dumpstatic byte[]decodeHexDump(CharSequence hexDump, int fromIndex, int length)Decodes part of a string with hex dumpstatic intdecodeHexNibble(char c)Helper to decode half of a hexadecimal number from a string.static booleanendsWith(CharSequence s, char c)Determine if the stringsends with the charc.static CharSequenceescapeCsv(CharSequence value)Escapes the specified value, if necessary according to RFC-4180.static CharSequenceescapeCsv(CharSequence value, boolean trimWhiteSpace)Escapes the specified value, if necessary according to RFC-4180.static intindexOfNonWhiteSpace(CharSequence seq, int offset)Find the index of the first non-white space character insstarting atoffset.static intindexOfWhiteSpace(CharSequence seq, int offset)Find the index of the first white space character insstarting atoffset.static booleanisNullOrEmpty(String s)static booleanisSurrogate(char c)Determine ifclies within the range of values defined for Surrogate Code Point.static CharSequencejoin(CharSequence separator, Iterable<? extends CharSequence> elements)Returns a char sequence that contains allelementsjoined by a given separator.static intlength(String s)Get the length of a string,nullinput is considered0length.static StringsimpleClassName(Class<?> clazz)Generates a simplified name from aClass.static StringsimpleClassName(Object o)The shortcut tosimpleClassName(o.getClass()).static StringsubstringAfter(String value, char delim)Get the item after one char delim if the delim is found (else null).static StringBuilderthreadLocalStringBuilder()static StringtoHexString(byte[] src)Converts the specified byte array into a hexadecimal value.static StringtoHexString(byte[] src, int offset, int length)Converts the specified byte array into a hexadecimal value.static <T extends Appendable>
TtoHexString(T dst, byte[] src)Converts the specified byte array into a hexadecimal value and appends it to the specified buffer.static <T extends Appendable>
TtoHexString(T dst, byte[] src, int offset, int length)Converts the specified byte array into a hexadecimal value and appends it to the specified buffer.static StringtoHexStringPadded(byte[] src)Converts the specified byte array into a hexadecimal value.static StringtoHexStringPadded(byte[] src, int offset, int length)Converts the specified byte array into a hexadecimal value.static <T extends Appendable>
TtoHexStringPadded(T dst, byte[] src)Converts the specified byte array into a hexadecimal value and appends it to the specified buffer.static <T extends Appendable>
TtoHexStringPadded(T dst, byte[] src, int offset, int length)Converts the specified byte array into a hexadecimal value and appends it to the specified buffer.static CharSequencetrimOws(CharSequence value)Trim optional white-space characters from the specified value, according to RFC-7230.static CharSequenceunescapeCsv(CharSequence value)Unescapes the specified escaped CSV field, if necessary according to RFC-4180.static List<CharSequence>unescapeCsvFields(CharSequence value)Unescapes the specified escaped CSV fields according to RFC-4180.
-
-
-
Field Detail
-
EMPTY_STRING
public static final String EMPTY_STRING
- See Also:
- Constant Field Values
-
NEWLINE
public static final String NEWLINE
-
DOUBLE_QUOTE
public static final char DOUBLE_QUOTE
- See Also:
- Constant Field Values
-
COMMA
public static final char COMMA
- See Also:
- Constant Field Values
-
LINE_FEED
public static final char LINE_FEED
- See Also:
- Constant Field Values
-
CARRIAGE_RETURN
public static final char CARRIAGE_RETURN
- See Also:
- Constant Field Values
-
TAB
public static final char TAB
- See Also:
- Constant Field Values
-
SPACE
public static final char SPACE
- See Also:
- Constant Field Values
-
-
Method Detail
-
threadLocalStringBuilder
public static StringBuilder threadLocalStringBuilder()
-
substringAfter
public static String substringAfter(String value, char delim)
Get the item after one char delim if the delim is found (else null). This operation is a simplified and optimized version ofString.split(String, int).
-
commonSuffixOfLength
public static boolean commonSuffixOfLength(String s, String p, int len)
Checks if two strings have the same suffix of specified length- Parameters:
s- stringp- stringlen- length of the common suffix- Returns:
- true if both s and p are not null and both have the same suffix. Otherwise - false
-
byteToHexStringPadded
public static String byteToHexStringPadded(int value)
Converts the specified byte value into a 2-digit hexadecimal integer.
-
byteToHexStringPadded
public static <T extends Appendable> T byteToHexStringPadded(T buf, int value)
Converts the specified byte value into a 2-digit hexadecimal integer and appends it to the specified buffer.
-
toHexStringPadded
public static String toHexStringPadded(byte[] src)
Converts the specified byte array into a hexadecimal value.
-
toHexStringPadded
public static String toHexStringPadded(byte[] src, int offset, int length)
Converts the specified byte array into a hexadecimal value.
-
toHexStringPadded
public static <T extends Appendable> T toHexStringPadded(T dst, byte[] src)
Converts the specified byte array into a hexadecimal value and appends it to the specified buffer.
-
toHexStringPadded
public static <T extends Appendable> T toHexStringPadded(T dst, byte[] src, int offset, int length)
Converts the specified byte array into a hexadecimal value and appends it to the specified buffer.
-
byteToHexString
public static String byteToHexString(int value)
Converts the specified byte value into a hexadecimal integer.
-
byteToHexString
public static <T extends Appendable> T byteToHexString(T buf, int value)
Converts the specified byte value into a hexadecimal integer and appends it to the specified buffer.
-
toHexString
public static String toHexString(byte[] src)
Converts the specified byte array into a hexadecimal value.
-
toHexString
public static String toHexString(byte[] src, int offset, int length)
Converts the specified byte array into a hexadecimal value.
-
toHexString
public static <T extends Appendable> T toHexString(T dst, byte[] src)
Converts the specified byte array into a hexadecimal value and appends it to the specified buffer.
-
toHexString
public static <T extends Appendable> T toHexString(T dst, byte[] src, int offset, int length)
Converts the specified byte array into a hexadecimal value and appends it to the specified buffer.
-
decodeHexNibble
public static int decodeHexNibble(char c)
Helper to decode half of a hexadecimal number from a string.- Parameters:
c- The ASCII character of the hexadecimal number to decode. Must be in the range[0-9a-fA-F].- Returns:
- The hexadecimal value represented in the ASCII character
given, or
-1if the character is invalid.
-
decodeHexByte
public static byte decodeHexByte(CharSequence s, int pos)
Decode a 2-digit hex byte from within a string.
-
decodeHexDump
public static byte[] decodeHexDump(CharSequence hexDump, int fromIndex, int length)
Decodes part of a string with hex dump- Parameters:
hexDump- aCharSequencewhich contains the hex dumpfromIndex- start of hex dump inhexDumplength- hex string length
-
decodeHexDump
public static byte[] decodeHexDump(CharSequence hexDump)
Decodes a hex dump
-
simpleClassName
public static String simpleClassName(Object o)
The shortcut tosimpleClassName(o.getClass()).
-
simpleClassName
public static String simpleClassName(Class<?> clazz)
Generates a simplified name from aClass. Similar toClass.getSimpleName(), but it works fine with anonymous classes.
-
escapeCsv
public static CharSequence escapeCsv(CharSequence value)
Escapes the specified value, if necessary according to RFC-4180.- Parameters:
value- The value which will be escaped according to RFC-4180- Returns:
CharSequencethe escaped value if necessary, or the value unchanged
-
escapeCsv
public static CharSequence escapeCsv(CharSequence value, boolean trimWhiteSpace)
Escapes the specified value, if necessary according to RFC-4180.- Parameters:
value- The value which will be escaped according to RFC-4180trimWhiteSpace- The value will first be trimmed of its optional white-space characters, according to RFC-7230- Returns:
CharSequencethe escaped value if necessary, or the value unchanged
-
unescapeCsv
public static CharSequence unescapeCsv(CharSequence value)
Unescapes the specified escaped CSV field, if necessary according to RFC-4180.- Parameters:
value- The escaped CSV field which will be unescaped according to RFC-4180- Returns:
CharSequencethe unescaped value if necessary, or the value unchanged
-
unescapeCsvFields
public static List<CharSequence> unescapeCsvFields(CharSequence value)
Unescapes the specified escaped CSV fields according to RFC-4180.
-
length
public static int length(String s)
Get the length of a string,nullinput is considered0length.
-
isNullOrEmpty
public static boolean isNullOrEmpty(String s)
-
indexOfNonWhiteSpace
public static int indexOfNonWhiteSpace(CharSequence seq, int offset)
Find the index of the first non-white space character insstarting atoffset.- Parameters:
seq- The string to search.offset- The offset to start searching at.- Returns:
- the index of the first non-white space character or <
-1if none was found.
-
indexOfWhiteSpace
public static int indexOfWhiteSpace(CharSequence seq, int offset)
Find the index of the first white space character insstarting atoffset.- Parameters:
seq- The string to search.offset- The offset to start searching at.- Returns:
- the index of the first white space character or <
-1if none was found.
-
isSurrogate
public static boolean isSurrogate(char c)
Determine ifclies within the range of values defined for Surrogate Code Point.- Parameters:
c- the character to check.- Returns:
trueifclies within the range of values defined for Surrogate Code Point.falseotherwise.
-
endsWith
public static boolean endsWith(CharSequence s, char c)
Determine if the stringsends with the charc.- Parameters:
s- the string to testc- the tested char- Returns:
- true if
sends with the charc
-
trimOws
public static CharSequence trimOws(CharSequence value)
Trim optional white-space characters from the specified value, according to RFC-7230.- Parameters:
value- the value to trim- Returns:
CharSequencethe trimmed value if necessary, or the value unchanged
-
join
public static CharSequence join(CharSequence separator, Iterable<? extends CharSequence> elements)
Returns a char sequence that contains allelementsjoined by a given separator.- Parameters:
separator- for each elementelements- to join together- Returns:
- a char sequence joined by a given separator.
-
-