2009-11-02 16:38:49 -05:00
|
|
|
/*
|
|
|
|
* DavMail POP/IMAP/SMTP/CalDav/LDAP Exchange Gateway
|
|
|
|
* Copyright (C) 2009 Mickael Guessant
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
package davmail.util;
|
|
|
|
|
2009-12-24 10:33:26 -05:00
|
|
|
import java.util.Set;
|
|
|
|
|
2009-11-02 16:38:49 -05:00
|
|
|
/**
|
|
|
|
* Various string handling methods
|
|
|
|
*/
|
2009-11-17 16:54:10 -05:00
|
|
|
public final class StringUtil {
|
2009-11-02 16:38:49 -05:00
|
|
|
private StringUtil() {
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-12-20 05:51:02 -05:00
|
|
|
* Return the sub string between startDelimiter and endDelimiter or null.
|
2009-11-02 16:38:49 -05:00
|
|
|
*
|
|
|
|
* @param value String value
|
|
|
|
* @param startDelimiter start delimiter
|
|
|
|
* @param endDelimiter end delimiter
|
|
|
|
* @return token value
|
|
|
|
*/
|
|
|
|
public static String getToken(String value, String startDelimiter, String endDelimiter) {
|
|
|
|
String token = null;
|
|
|
|
if (value != null) {
|
|
|
|
int startIndex = value.indexOf(startDelimiter);
|
|
|
|
if (startIndex >= 0) {
|
|
|
|
startIndex += startDelimiter.length();
|
|
|
|
int endIndex = value.indexOf(endDelimiter, startIndex);
|
|
|
|
if (endIndex >= 0) {
|
|
|
|
token = value.substring(startIndex, endIndex);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return token;
|
|
|
|
}
|
2009-11-03 05:01:33 -05:00
|
|
|
|
|
|
|
/**
|
2009-12-20 05:51:02 -05:00
|
|
|
* Return the sub string between startDelimiter and endDelimiter or null,
|
2009-11-03 05:01:33 -05:00
|
|
|
* look for last token in string.
|
|
|
|
*
|
|
|
|
* @param value String value
|
|
|
|
* @param startDelimiter start delimiter
|
|
|
|
* @param endDelimiter end delimiter
|
|
|
|
* @return token value
|
|
|
|
*/
|
|
|
|
public static String getLastToken(String value, String startDelimiter, String endDelimiter) {
|
|
|
|
String token = null;
|
|
|
|
if (value != null) {
|
|
|
|
int startIndex = value.lastIndexOf(startDelimiter);
|
|
|
|
if (startIndex >= 0) {
|
|
|
|
startIndex += startDelimiter.length();
|
|
|
|
int endIndex = value.indexOf(endDelimiter, startIndex);
|
|
|
|
if (endIndex >= 0) {
|
|
|
|
token = value.substring(startIndex, endIndex);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return token;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-12-20 05:51:02 -05:00
|
|
|
* Return the sub string between startDelimiter and endDelimiter with newToken.
|
2009-11-03 05:01:33 -05:00
|
|
|
*
|
|
|
|
* @param value String value
|
|
|
|
* @param startDelimiter start delimiter
|
|
|
|
* @param endDelimiter end delimiter
|
|
|
|
* @param newToken new token value
|
|
|
|
* @return token value
|
|
|
|
*/
|
|
|
|
public static String replaceToken(String value, String startDelimiter, String endDelimiter, String newToken) {
|
|
|
|
String result = null;
|
|
|
|
if (value != null) {
|
|
|
|
int startIndex = value.indexOf(startDelimiter);
|
|
|
|
if (startIndex >= 0) {
|
|
|
|
startIndex += startDelimiter.length();
|
|
|
|
int endIndex = value.indexOf(endDelimiter, startIndex);
|
|
|
|
if (endIndex >= 0) {
|
|
|
|
result = value.substring(0, startIndex) + newToken + value.substring(endIndex);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return result;
|
|
|
|
}
|
2009-12-24 10:33:26 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Join values with given separator.
|
|
|
|
*
|
|
|
|
* @param values value set
|
|
|
|
* @param separator separator
|
|
|
|
* @return joined values
|
|
|
|
*/
|
|
|
|
public static String join(Set<String> values, String separator) {
|
|
|
|
if (values != null && !values.isEmpty()) {
|
|
|
|
StringBuilder result = new StringBuilder();
|
|
|
|
for (String value : values) {
|
|
|
|
if (result.length() > 0) {
|
|
|
|
result.append(separator);
|
|
|
|
}
|
|
|
|
result.append(value);
|
|
|
|
}
|
|
|
|
return result.toString();
|
|
|
|
} else {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
2009-11-02 16:38:49 -05:00
|
|
|
}
|