package tools.mapletools;
import java.io.IOException;
import java.io.PrintWriter;
import java.nio.file.Files;
import java.nio.file.Path;
import java.nio.file.StandardOpenOption;
import java.util.*;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
/**
* @author RonanLana
*
* This application objective is to read all scripts from the event folder
* and fill empty functions for every function name not yet present in the
* script.
*
* Estimated parse time: 10 seconds
*/
public class EventMethodFiller {
private static final Collection RELEVANT_FILE_EXTENSIONS = Set.of("sql", "js", "txt", "java");
private static boolean foundMatchingDataOnFile(String fileContent, Pattern pattern) {
Matcher matcher = pattern.matcher(fileContent);
return matcher.find();
}
private static void filterDirectorySearchMatchingData(String directoryPath, Map functions)
throws IOException {
Files.walk(Path.of(directoryPath))
.filter(EventMethodFiller::isRelevantFile)
.forEach(path -> fileSearchMatchingData(path, functions));
}
private static boolean isRelevantFile(Path path) {
String fileName = path.getFileName().toString();
return RELEVANT_FILE_EXTENSIONS.stream().anyMatch(fileName::endsWith);
}
private static void fileSearchMatchingData(Path file, Map functions) {
try {
String fileContent = Files.readString(file);
List fillFunctions = new LinkedList<>();
for (Map.Entry f : functions.entrySet()) {
if (!foundMatchingDataOnFile(fileContent, f.getKey())) {
fillFunctions.add(f.getValue());
}
}
if (!fillFunctions.isEmpty()) {
System.out.println("Filling out " + file.getFileName().toString() + "...");
try (PrintWriter printWriter = new PrintWriter(Files.newBufferedWriter(file, StandardOpenOption.APPEND))) {
printWriter.println();
printWriter.println();
printWriter.println("// ---------- FILLER FUNCTIONS ----------");
printWriter.println();
for (String s : fillFunctions) {
printWriter.println(s);
printWriter.println();
}
}
}
} catch (IOException e) {
e.printStackTrace();
}
}
private static Pattern compileJsFunctionPattern(String function) {
String jsFunction = "function(\\s)+";
return Pattern.compile(jsFunction + function);
}
private static Map getFunctions() {
Map functions = new HashMap<>();
functions.put(compileJsFunctionPattern("playerEntry"), "function playerEntry(eim, player) {}");
functions.put(compileJsFunctionPattern("playerExit"), "function playerExit(eim, player) {}");
functions.put(compileJsFunctionPattern("scheduledTimeout"), "function scheduledTimeout(eim) {}");
functions.put(compileJsFunctionPattern("playerUnregistered"), "function playerUnregistered(eim, player) {}");
functions.put(compileJsFunctionPattern("changedLeader"), "function changedLeader(eim, leader) {}");
functions.put(compileJsFunctionPattern("monsterKilled"), "function monsterKilled(mob, eim) {}");
functions.put(compileJsFunctionPattern("allMonstersDead"), "function allMonstersDead(eim) {}");
functions.put(compileJsFunctionPattern("playerDisconnected"), "function playerDisconnected(eim, player) {}");
functions.put(compileJsFunctionPattern("monsterValue"), "function monsterValue(eim, mobid) {return 0;}");
functions.put(compileJsFunctionPattern("dispose"), "function dispose() {}");
functions.put(compileJsFunctionPattern("leftParty"), "function leftParty(eim, player) {}");
functions.put(compileJsFunctionPattern("disbandParty"), "function disbandParty(eim, player) {}");
functions.put(compileJsFunctionPattern("clearPQ"), "function clearPQ(eim) {}");
functions.put(compileJsFunctionPattern("afterSetup"), "function afterSetup(eim) {}");
functions.put(compileJsFunctionPattern("cancelSchedule"), "function cancelSchedule() {}");
functions.put(compileJsFunctionPattern("setup"), "function setup(eim, leaderid) {}");
//put(compileJsFunctionPattern("getEligibleParty"), "function getEligibleParty(party) {}"); not really needed
return functions;
}
public static void main(String[] args) throws IOException {
filterDirectorySearchMatchingData(ToolConstants.SCRIPTS_PATH + "/event", getFunctions());
}
}