From f03bb3c932b035a94222cdd57b60ba1c77130585 Mon Sep 17 00:00:00 2001 From: zaaarf Date: Sat, 26 Aug 2023 18:25:31 +0200 Subject: feat: added error handling and generally tweaked tsrg parsing --- .../lll/exceptions/MalformedMappingsException.java | 14 ++++++++-- .../java/ftbsc/lll/mapper/impl/TSRGMapper.java | 32 ++++++++++------------ 2 files changed, 27 insertions(+), 19 deletions(-) diff --git a/src/main/java/ftbsc/lll/exceptions/MalformedMappingsException.java b/src/main/java/ftbsc/lll/exceptions/MalformedMappingsException.java index 1352855..17bb3b5 100644 --- a/src/main/java/ftbsc/lll/exceptions/MalformedMappingsException.java +++ b/src/main/java/ftbsc/lll/exceptions/MalformedMappingsException.java @@ -1,7 +1,17 @@ package ftbsc.lll.exceptions; +/** + * Thrown when something goes wrong while parsing a mappings file. + */ public class MalformedMappingsException extends Exception { - public MalformedMappingsException(String mapping, String type) { - super(String.format("Unexpected token at line %s for mapper type %s!", mapping, type)); + + /** + * Constructs a new {@link MalformedMappingsException} given the line number + * and an error message. + * @param lineNumber the line the error occurred at + * @param error the error message + */ + public MalformedMappingsException(int lineNumber, String error) { + super(String.format("Unexpected token at line %d: %s!", lineNumber, error)); } } diff --git a/src/main/java/ftbsc/lll/mapper/impl/TSRGMapper.java b/src/main/java/ftbsc/lll/mapper/impl/TSRGMapper.java index 2bd4d28..ad4c65e 100644 --- a/src/main/java/ftbsc/lll/mapper/impl/TSRGMapper.java +++ b/src/main/java/ftbsc/lll/mapper/impl/TSRGMapper.java @@ -6,7 +6,6 @@ import ftbsc.lll.mapper.AbstractMapper; import ftbsc.lll.mapper.IMapper; import ftbsc.lll.mapper.tools.data.ClassData; -import java.util.ArrayList; import java.util.List; /** @@ -36,24 +35,23 @@ public class TSRGMapper extends AbstractMapper { */ @Override protected void processLines(List lines, boolean ignoreErrors) throws MalformedMappingsException { - //skip the first line ("tsrg2 left right") - lines = new ArrayList<>(lines); - lines.remove(0); - String currentClass = ""; - for(String l : lines) { - if(l == null) continue; - if(l.startsWith("\t") || l.startsWith(" ")) { - String[] split = l.trim().split(" "); - if(split.length == 2) //field - this.mappings.get(currentClass).addField(split[0], split[1]); - else if (split.length == 3)//method - this.mappings.get(currentClass).addMethod(split[0], split[2], split[1]); //add child + for(int i = 1; i < lines.size(); i++) { //start from 1 to skip header + String currentLine = lines.get(i); + boolean isMember = currentLine.startsWith("\t") || currentLine.startsWith(" "); + String[] tokens = currentLine.trim().split(" "); + if(isMember) { + if(tokens.length == 2) //field + this.mappings.get(currentClass).addField(tokens[0], tokens[1]); + else if(tokens.length == 3)//method + this.mappings.get(currentClass).addMethod(tokens[0], tokens[2], tokens[1]); //add child + else if(!ignoreErrors) throw new MalformedMappingsException(i, "wrong number of space-separated tokens"); } else { - String[] sp = l.split(" "); - ClassData s = new ClassData(sp[0], sp[1]); - currentClass = s.name; - this.mappings.put(s.name, s); + if(tokens.length == 2) { + ClassData s = new ClassData(tokens[0], tokens[1]); + currentClass = s.name; + this.mappings.put(s.name, s); + } else if(!ignoreErrors) throw new MalformedMappingsException(i, "wrong number of space-separated tokens"); } } } -- cgit v1.2.3-56-ga3b1