ReplSet.java
package bjc.everge;
import java.io.*;
import java.util.*;
/**
* A set of ReplPairs, kept together for easy use
*
* @author Ben Culkin
*/
public class ReplSet {
// The list of pairs
private List<ReplPair> parList;
/**
* Create a new blank set of pairs.
*/
public ReplSet() {
parList = new ArrayList<>();
}
/**
* Create a new set of pairs using an existing list of pairs.
*
* Changes to the list of pairs will carry across to the ReplSet, so be careful
* about that.
*
* @param lst
* The list of pairs to use.
*/
public ReplSet(List<ReplPair> lst) {
parList = lst;
}
/**
* Load a ReplSet from a file.
*
* @param fName
* The file to load the ReplSet from.
* @return A ReplSet, loaded from the file.
* @throws IOException
* if something goes badly reading it.
*/
public static ReplSet fromFile(String fName) throws IOException {
ReplSet rs = new ReplSet();
try (FileInputStream fis = new FileInputStream(fName);
Scanner scn = new Scanner(fis)) {
rs.parList = ReplPair.readList(scn);
}
return rs;
}
/**
* Adds more pairs to the ReplSet.
*
* @param pars
* The pairs to add to the ReplSet.
*/
public void addPairs(List<ReplPair> pars) {
for (ReplPair par : pars) {
parList.add(par);
}
// Resort the pairs into priority order
parList.sort(null);
}
/**
* Adds more pairs to the ReplSet.
*
* @param pars
* The pairs to add to the ReplSet.
*/
public void addPairs(ReplPair... pars) {
for (ReplPair par : pars) {
parList.add(par);
}
// Resort the pairs into priority order
parList.sort(null);
}
/**
* Apply the ReplSet to a string.
*
* @param val
* The string to apply the ReplSet to.
*
* @return The result of applying the ReplSet.
*/
public String apply(String val) {
String ret = val;
for (ReplPair par : parList) {
System.err.printf("Applying pair '%s' to string '%s' (original was '%s')\n", par, ret, val);
String tmp = par.apply(ret);
ret = tmp;
}
return ret;
}
}