com.teamscale.commons.utils.ParameterFileUtils Maven / Gradle / Ivy
package com.teamscale.commons.utils;
import java.util.Set;
import org.conqat.lib.commons.collections.Pair;
/**
* Utility methods concerning parameter files used for checks and metadata files for various
* languages. A parameter file defines on each line a parameter and its value, both separated by a
* colon.
*/
public class ParameterFileUtils {
private static final char COLON = ':';
/**
* Parses the given line from a parameters file and returns the parameter name and value. Throws an
* AssertionError if the parameter name does not match any name in the given optionNames set.
*
* This method works around the problem that colon (:) is the separator between option name and
* value, but colon is also allowed as part of the option names and as part of the option values.
*
* This method scans the colon signs from left to right and returns the first possible option name
* that occurs in the given set.
*
* For example, given the line "Empty blocks: allow empty constructors:true", this method returns
* new Pair("Empty blocks: allow empty constructors", "true")
.
*
* @param line
* the full line from a parameters file
* @param optionNames
* all potential option names
* @return parameter name and value
*/
public static Pair findParameterNameAndValue(String line, Set optionNames) {
int colonPosition = line.indexOf(COLON);
while (colonPosition != -1) {
String parameterName = line.substring(0, colonPosition).trim();
if (optionNames.contains(parameterName)) {
String parameterValue = line.substring(colonPosition + 1).trim().replace("\\n", "\n");
return new Pair<>(parameterName, parameterValue);
}
colonPosition = line.indexOf(COLON, colonPosition + 1);
}
return null;
}
}