diff options
author | zaaarf <zaaarf@proton.me> | 2023-02-24 19:58:39 +0100 |
---|---|---|
committer | zaaarf <zaaarf@proton.me> | 2023-02-24 19:58:39 +0100 |
commit | 211142cd59f2ae7bbd02edac20b88041a7fdb147 (patch) | |
tree | edbde7ed58c760555e5059f3fb4b6b4d2c131ab8 /src/main/java/ftbsc/lll/processor | |
parent | 64fa73a583cdac59f6fa0264746ca553e3deeeb9 (diff) |
doc: improved javadoc
Diffstat (limited to 'src/main/java/ftbsc/lll/processor')
-rw-r--r-- | src/main/java/ftbsc/lll/processor/LilleroProcessor.java | 30 |
1 files changed, 20 insertions, 10 deletions
diff --git a/src/main/java/ftbsc/lll/processor/LilleroProcessor.java b/src/main/java/ftbsc/lll/processor/LilleroProcessor.java index 851987f..4389488 100644 --- a/src/main/java/ftbsc/lll/processor/LilleroProcessor.java +++ b/src/main/java/ftbsc/lll/processor/LilleroProcessor.java @@ -5,6 +5,7 @@ import ftbsc.lll.IInjector; import ftbsc.lll.processor.annotations.Injector; import ftbsc.lll.processor.annotations.Patch; import ftbsc.lll.tools.DescriptorBuilder; +import ftbsc.lll.tools.SrgMapper; import org.objectweb.asm.tree.ClassNode; import org.objectweb.asm.tree.MethodNode; @@ -15,14 +16,14 @@ import javax.lang.model.element.Modifier; import javax.lang.model.element.TypeElement; import javax.lang.model.type.ExecutableType; import javax.lang.model.type.TypeMirror; -import javax.lang.model.util.Elements; -import javax.lang.model.util.Types; import javax.tools.Diagnostic; import javax.tools.JavaFileObject; import java.io.IOException; import java.io.PrintWriter; import java.lang.annotation.Annotation; import java.lang.annotation.Target; +import java.nio.file.Files; +import java.nio.file.Paths; import java.util.HashSet; import java.util.List; import java.util.Set; @@ -31,8 +32,17 @@ import java.util.Set; @SupportedSourceVersion(SourceVersion.RELEASE_8) public class LilleroProcessor extends AbstractProcessor { - Types types = processingEnv.getTypeUtils(); - Elements elements = processingEnv.getElementUtils(); + private SrgMapper mapper; + + @Override + public void init(ProcessingEnvironment processingEnv) { + try { + mapper = new SrgMapper(Files.lines(Paths.get("build/createMcpToSrg/output.tsrg"))); + } catch(IOException e) { + throw new RuntimeException(e); + } + super.init(processingEnv); + } @Override public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) { @@ -54,12 +64,12 @@ public class LilleroProcessor extends AbstractProcessor { return true; } - /** TODO: fancy class object ref in javadoc + /** * This checks whether a given class contains the requirements to be parsed into a Lillero injector. - * It must have at least one method annotated with @Target, and one method annotated with @Injector - * that must be public, static and take in a ClassNode and a MethodNode. + * It must have at least one method annotated with {@link Target}, and one method annotated with {@link Injector} + * that must be public, static and take in a {@link ClassNode} and a {@link MethodNode}. * @param elem the element to check. - * @return whether it can be converted into a valid IInjector. + * @return whether it can be converted into a valid {@link IInjector}. */ private boolean isValidInjector(TypeElement elem) { TypeMirror classNodeType = processingEnv.getElementUtils().getTypeElement("org.objectweb.asm.tree.ClassNode").asType(); @@ -99,7 +109,7 @@ public class LilleroProcessor extends AbstractProcessor { return sb.toString(); } - private String getSrgName(MethodSpec m) { + private String getSrgElementName(MethodSpec m) { return m.name; //TODO; } @@ -137,7 +147,7 @@ public class LilleroProcessor extends AbstractProcessor { MethodSpec methodName = MethodSpec.methodBuilder("methodName") .addModifiers(Modifier.PUBLIC) .returns(String.class) - .addStatement("return $S", getSrgName(targetMethod)) + .addStatement("return $S", getSrgElementName(targetMethod)) .build(); MethodSpec methodDesc = MethodSpec.methodBuilder("methodDesc") |