All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy