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

com.teamscale.commons.utils.ParameterFileUtils Maven / Gradle / Ivy

There is a newer version: 2025.1.0
Show newest version
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