org.greenrobot.essentials.StringUtils Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of virtdata-lib-realer Show documentation
Show all versions of virtdata-lib-realer Show documentation
With inspiration from other libraries
/*
* Copyright (C) 2014-2016 Markus Junginger, greenrobot (http://greenrobot.org)
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.greenrobot.essentials;
import java.io.UnsupportedEncodingException;
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
/**
* Utilities for working with strings like splitting, joining, url-encoding, hex, and digests.
* See also {@link org.greenrobot.essentials.Base64}.
*
* @author markus
*/
public class StringUtils {
private final static char[] HEX_CHARS = {
'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'
};
/**
* Splits a String based on a single character, which is usually faster than regex-based String.split().
* NOTE: split("AA;BB;;", ';') == ["AA", "BB", "", ""], this may be different from String.split()
* */
public static String[] split(String string, char delimiter) {
int delimeterCount = 0;
int start = 0;
int end;
while ((end = string.indexOf(delimiter, start)) != -1) {
delimeterCount++;
start = end + 1;
}
String[] result = new String[delimeterCount + 1];
start = 0;
for (int i = 0; i < delimeterCount; i++) {
end = string.indexOf(delimiter, start);
result[i] = string.substring(start, end);
start = end + 1;
}
result[delimeterCount] = string.substring(start, string.length());
return result;
}
/**
* URL-Encodes a given string using UTF-8 (some web pages have problems with UTF-8 and umlauts, consider
* {@link #encodeUrlIso(String)} also). No UnsupportedEncodingException to handle as it is dealt with in this
* method.
*/
public static String encodeUrl(String stringToEncode) {
try {
return URLEncoder.encode(stringToEncode, "UTF-8");
} catch (UnsupportedEncodingException e1) {
throw new RuntimeException(e1);
}
}
/**
* URL-encodes a given string using ISO-8859-1, which may work better with web pages and umlauts compared to UTF-8.
* No UnsupportedEncodingException to handle as it is dealt with in this method.
*/
public static String encodeUrlIso(String stringToEncode) {
try {
return URLEncoder.encode(stringToEncode, "ISO-8859-1");
} catch (UnsupportedEncodingException e1) {
throw new RuntimeException(e1);
}
}
/**
* URL-Decodes a given string using UTF-8. No UnsupportedEncodingException to handle as it is dealt with in this
* method.
*/
public static String decodeUrl(String stringToDecode) {
try {
return URLDecoder.decode(stringToDecode, "UTF-8");
} catch (UnsupportedEncodingException e1) {
throw new RuntimeException(e1);
}
}
/**
* URL-Decodes a given string using ISO-8859-1. No UnsupportedEncodingException to handle as it is dealt with in
* this method.
*/
public static String decodeUrlIso(String stringToDecode) {
try {
return URLDecoder.decode(stringToDecode, "ISO-8859-1");
} catch (UnsupportedEncodingException e1) {
throw new RuntimeException(e1);
}
}
/**
* Generates the MD5 digest (32 hex characters) for a given String based on UTF-8.
*/
public static String md5(String stringToEncode) {
return digest(stringToEncode, "MD5", "UTF-8");
}
/**
* Generates the SHA-1 digest (40 hex characters) for a given String based on UTF-8.
* The SHA-1 algorithm produces less collisions than MD5.
*
* @return SHA-1 digest .
*/
public static String sha1(String stringToEncode) {
return digest(stringToEncode, "SHA-1", "UTF-8");
}
/**
* Generates a digest (hex string) for the given string
*/
public static String digest(String string, String digestAlgo, String encoding) {
try {
MessageDigest digester = MessageDigest.getInstance(digestAlgo);
digester.update(string.getBytes(encoding));
return hex(digester.digest());
} catch (NoSuchAlgorithmException | UnsupportedEncodingException e) {
throw new RuntimeException(e);
}
}
public static String hex(byte[] bytes) {
char[] hexChars = new char[bytes.length * 2];
for (int i = 0; i < bytes.length; i++) {
int value = bytes[i] & 0xFF;
hexChars[i * 2] = HEX_CHARS[value >>> 4];
hexChars[i * 2 + 1] = HEX_CHARS[value & 0x0F];
}
return new String(hexChars);
}
/**
* @throws IllegalArgumentException if the given string is invalid hex
*/
public static byte[] parseHex(String hex) {
int length = hex.length();
if (length % 2 != 0) {
throw new IllegalArgumentException("Illegal string length: " + length);
}
int bytesLength = length / 2;
byte[] bytes = new byte[bytesLength];
int idxChar = 0;
for (int i = 0; i < bytesLength; i++) {
int value = parseHexDigit(hex.charAt(idxChar++)) << 4;
value |= parseHexDigit(hex.charAt(idxChar++));
bytes[i] = (byte) value;
}
return bytes;
}
/**
* @throws IllegalArgumentException if the given char is invalid hex
*/
public static int parseHexDigit(char c) {
if ('0' <= c && c <= '9') {
return c - '0';
} else if ('A' <= c && c <= 'F') {
return c - 'A' + 10;
} else if ('a' <= c && c <= 'f') {
return c - 'a' + 10;
}
throw new IllegalArgumentException("Illegal hex digit: " + c);
}
/**
* Simple HTML/XML entity resolving: Only supports unicode enitities and a very limited number text represented
* entities (apos, quot, gt, lt, and amp). There are many more: http://www.w3.org/TR/REC-html40/sgml/dtd.html
*
* @param entity The entity name without & and ; (null throws NPE)
* @return Resolved entity or the entity itself if it could not be resolved.
*/
public static String resolveEntity(String entity) {
if (entity.length() > 1 && entity.charAt(0) == '#') {
if (entity.charAt(1) == 'x') {
return String.valueOf((char) Integer.parseInt(entity.substring(2), 16));
} else {
return String.valueOf((char) Integer.parseInt(entity.substring(1)));
}
} else if (entity.equals("apos")) {
return "'";
} else if (entity.equals("quot")) {
return "\"";
} else if (entity.equals("gt")) {
return ">";
} else if (entity.equals("lt")) {
return "<";
} else if (entity.equals("amp")) {
return "&";
} else {
return entity;
}
}
/**
* Cuts the string at the end if it's longer than maxLength and appends "..." to it. The length of the resulting
* string including "..." is always less or equal to the given maxLength. It's valid to pass a null text; in this
* case null is returned.
*/
public static String ellipsize(String text, int maxLength) {
return ellipsize(text, maxLength, "...");
}
/**
* Cuts the string at the end if it's longer than maxLength and appends the given end string to it. The length of
* the resulting string is always less or equal to the given maxLength. It's valid to pass a null text; in this
* case null is returned.
*/
public static String ellipsize(String text, int maxLength, String end) {
if (text != null && text.length() > maxLength) {
return text.substring(0, maxLength - end.length()) + end;
}
return text;
}
public static String[] splitLines(String text, boolean skipEmptyLines) {
if (skipEmptyLines) {
return text.split("[\n\r]+");
} else {
return text.split("\\r?\\n");
}
}
public static List findLinesContaining(String text, String searchText) {
String[] splitLinesSkipEmpty = splitLines(text, true);
List matching = new ArrayList<>();
for (String line : splitLinesSkipEmpty) {
if (line.contains(searchText)) {
matching.add(line);
}
}
return matching;
}
/**
* Joins the given iterable objects using the given separator into a single string.
*
* @return the joined string or an empty string if iterable is null
*/
public static String join(Iterable> iterable, String separator) {
if (iterable != null) {
StringBuilder buf = new StringBuilder();
Iterator> it = iterable.iterator();
char singleChar = separator.length() == 1 ? separator.charAt(0) : 0;
while (it.hasNext()) {
buf.append(it.next());
if (it.hasNext()) {
if (singleChar != 0) {
// More efficient
buf.append(singleChar);
} else {
buf.append(separator);
}
}
}
return buf.toString();
} else {
return "";
}
}
/**
* Joins the given ints using the given separator into a single string.
*
* @return the joined string or an empty string if the int array is null
*/
public static String join(int[] array, String separator) {
if (array != null) {
StringBuilder buf = new StringBuilder(Math.max(16, (separator.length() + 1) * array.length));
char singleChar = separator.length() == 1 ? separator.charAt(0) : 0;
for (int i = 0; i < array.length; i++) {
if (i != 0) {
if (singleChar != 0) {
// More efficient
buf.append(singleChar);
} else {
buf.append(separator);
}
}
buf.append(array[i]);
}
return buf.toString();
} else {
return "";
}
}
/**
* Joins the given Strings using the given separator into a single string.
*
* @return the joined string or an empty string if the String array is null
*/
public static String join(String[] array, String separator) {
if (array != null) {
StringBuilder buf = new StringBuilder(Math.max(16, (separator.length() + 1) * array.length));
char singleChar = separator.length() == 1 ? separator.charAt(0) : 0;
for (int i = 0; i < array.length; i++) {
if (i != 0) {
if (singleChar != 0) {
// More efficient
buf.append(singleChar);
} else {
buf.append(separator);
}
}
buf.append(array[i]);
}
return buf.toString();
} else {
return "";
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy