aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
author zaaarf <zaaarf@proton.me>2023-08-26 22:06:09 +0200
committer zaaarf <zaaarf@proton.me>2023-08-26 22:06:09 +0200
commitf4a6992f17e699b93dbd8696e7a19041a781d883 (patch)
tree38df4baebd220c378b58e444a501b30dfd4bc429
parentd618b5ff017c9a269778c98d93e501df9be178ad (diff)
feat: tinyv2
-rw-r--r--src/main/java/ftbsc/lll/mapper/impl/SRGMapper.java2
-rw-r--r--src/main/java/ftbsc/lll/mapper/impl/TinyV2Mapper.java79
2 files changed, 80 insertions, 1 deletions
diff --git a/src/main/java/ftbsc/lll/mapper/impl/SRGMapper.java b/src/main/java/ftbsc/lll/mapper/impl/SRGMapper.java
index 156e9d2..442c204 100644
--- a/src/main/java/ftbsc/lll/mapper/impl/SRGMapper.java
+++ b/src/main/java/ftbsc/lll/mapper/impl/SRGMapper.java
@@ -9,7 +9,7 @@ import ftbsc.lll.mapper.tools.data.ClassData;
import java.util.List;
/**
- * A {@link IMapper} capable of parsing SRG files.
+ * A {@link IMapper} capable of parsing SRG mappings.
*/
@AutoService(IMapper.class)
public class SRGMapper extends AbstractMapper {
diff --git a/src/main/java/ftbsc/lll/mapper/impl/TinyV2Mapper.java b/src/main/java/ftbsc/lll/mapper/impl/TinyV2Mapper.java
new file mode 100644
index 0000000..37c8f80
--- /dev/null
+++ b/src/main/java/ftbsc/lll/mapper/impl/TinyV2Mapper.java
@@ -0,0 +1,79 @@
+package ftbsc.lll.mapper.impl;
+
+import com.google.auto.service.AutoService;
+import ftbsc.lll.exceptions.MalformedMappingsException;
+import ftbsc.lll.mapper.AbstractMapper;
+import ftbsc.lll.mapper.IMapper;
+import ftbsc.lll.mapper.tools.data.ClassData;
+
+import java.util.List;
+import java.util.regex.Pattern;
+
+/**
+ * A {@link IMapper} capable of parsing TinyV2 mappings
+ */
+@AutoService(IMapper.class)
+public class TinyV2Mapper extends AbstractMapper {
+
+ /**
+ * Checks whether this mapper can process the given lines.
+ * @param lines the lines to read
+ * @return whether this type of mapper can process these lines
+ */
+ @Override
+ public boolean claim(List<String> lines) {
+ return Pattern.compile("tiny\t2\t[0-9]\t[a-zA-Z]*\t[a-zA-Z]*")
+ .matcher(lines.get(0)).matches();
+ }
+
+ /**
+ * Reads the given lines of text and attempts to interpret them as
+ * mappings of the given type.
+ * @param lines the lines to read
+ * @param ignoreErrors try to ignore errors and keep going
+ * @throws MalformedMappingsException if an error is encountered and ignoreErrors is false
+ */
+ @Override
+ protected void processLines(List<String> lines, boolean ignoreErrors) throws MalformedMappingsException {
+ String currentClass = "";
+ for(int i = 1; i < lines.size(); i++) {
+ String currentLine = lines.get(i);
+ String[] tokens = currentLine.trim().split("\t");
+ int tabCount = currentLine.indexOf(tokens[0]); //get number of leading tabs
+ switch(tabCount) {
+ case 0: //classes
+ if(tokens.length == 3) {
+ if(tokens[0].charAt(0) == 'c') {
+ this.mappings.put(tokens[1], new ClassData(tokens[1], tokens[2]));
+ currentClass = tokens[1];
+ } else if(!ignoreErrors)
+ throw new MalformedMappingsException(i, "root-level element must be class");
+ continue;
+ }
+ break;
+ case 1: //class members
+ if(currentClass.isEmpty()) {
+ if(ignoreErrors) continue;
+ else throw new MalformedMappingsException(i, "class member without parent class");
+ }
+ switch(tokens[0].charAt(0)) {
+ case 'm': //methods
+ if(tokens.length == 4)
+ break;
+ this.mappings.get(currentClass).addMethod(tokens[2], tokens[3], tokens[1]);
+ continue;
+ case 'f': //fields
+ if(tokens.length == 4)
+ break;
+ this.mappings.get(currentClass).addField(tokens[2], tokens[3]);
+ continue;
+ }
+ break;
+ case 2: //parameters, our mappers don't really support those
+ break;
+ }
+ if(!ignoreErrors)
+ throw new MalformedMappingsException(i, "wrong number of space-separated tokens");
+ }
+ }
+}