io.fabric8.utils.ExecParseUtils Maven / Gradle / Ivy
/**
* Copyright 2005-2016 Red Hat, Inc.
*
* Red Hat licenses this file to you 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 io.fabric8.utils;
import java.util.ArrayList;
import java.util.List;
import java.util.StringTokenizer;
/**
* Utility class for parsing, used by the Camel Exec component.
* Note: the class should be dropped, when the the commons-exec library
* implements similar functionality.
*/
public final class ExecParseUtils {
public static final String WHITESPACE = " ";
public static final String QUOTE_CHAR = "\"";
private ExecParseUtils() {
}
/**
* Splits the input line string by {@link #WHITESPACE}. Supports quoting the
* white-spaces with a {@link #QUOTE_CHAR}. A quote itself can also be
* enclosed within #{@link #QUOTE_CHAR}#{@link #QUOTE_CHAR}. More than two
* double-quotes in a sequence is not allowed. Nested quotes are not
* allowed.
* E.g. The string
* "arg 1" arg2 will return the tokens arg 1
,
* arg2
* The string
* ""arg 1"" "arg2" arg 3 will return the tokens "arg 1"
* , arg2
,arg
and 3
*
* @param input the input to split.
* @return a not-null list of tokens
*/
public static List splitToWhiteSpaceSeparatedTokens(String input) {
if (input == null) {
return new ArrayList();
}
StringTokenizer tokenizer = new StringTokenizer(input.trim(), QUOTE_CHAR + WHITESPACE, true);
List tokens = new ArrayList();
StringBuilder quotedText = new StringBuilder();
while (tokenizer.hasMoreTokens()) {
String token = tokenizer.nextToken();
if (QUOTE_CHAR.equals(token)) {
// if we have a quote, add the next tokens to the quoted text
// until the quoting has finished
quotedText.append(QUOTE_CHAR);
String buffer = quotedText.toString();
if (isSingleQuoted(buffer) || isDoubleQuoted(buffer)) {
tokens.add(buffer.substring(1, buffer.length() - 1));
quotedText = new StringBuilder();
}
} else if (WHITESPACE.equals(token)) {
// a white space, if in quote, add the white space, otherwise
// skip it
if (quotedText.length() > 0) {
quotedText.append(WHITESPACE);
}
} else {
if (quotedText.length() > 0) {
quotedText.append(token);
} else {
tokens.add(token);
}
}
}
if (quotedText.length() > 0) {
throw new IllegalArgumentException("Invalid quoting found in args " + quotedText);
}
return tokens;
}
/**
* Tests if the input is enclosed within {@link #QUOTE_CHAR} characters
*
* @param input a not null String
* @return true if the regular expression is matched
*/
protected static boolean isSingleQuoted(String input) {
if (input == null || input.trim().length() == 0) {
return false;
}
return input.matches("(^" + QUOTE_CHAR + "{1}([^" + QUOTE_CHAR + "]+)" + QUOTE_CHAR + "{1})");
}
/**
* Tests if the input is enclosed within a double-{@link #QUOTE_CHAR} string
*
* @param input a not null String
* @return true if the regular expression is matched
*/
protected static boolean isDoubleQuoted(String input) {
if (input == null || input.trim().length() == 0) {
return false;
}
return input.matches("(^" + QUOTE_CHAR + "{2}([^" + QUOTE_CHAR + "]+)" + QUOTE_CHAR + "{2})");
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy