diff options
author | zaaarf <zaaarf@proton.me> | 2023-02-24 21:54:39 +0100 |
---|---|---|
committer | zaaarf <zaaarf@proton.me> | 2023-02-24 21:54:39 +0100 |
commit | aab3d58afb0001ced1e2dedfe8e98083a2d9c0fe (patch) | |
tree | 8bc3b9afadf86daf64cbf82e1dc087974f7f1e87 /src/main/java/ftbsc/lll/processor | |
parent | 211142cd59f2ae7bbd02edac20b88041a7fdb147 (diff) |
feat: implemented generation of service provider
Diffstat (limited to 'src/main/java/ftbsc/lll/processor')
-rw-r--r-- | src/main/java/ftbsc/lll/processor/LilleroProcessor.java | 22 |
1 files changed, 15 insertions, 7 deletions
diff --git a/src/main/java/ftbsc/lll/processor/LilleroProcessor.java b/src/main/java/ftbsc/lll/processor/LilleroProcessor.java index 4389488..b04c6c6 100644 --- a/src/main/java/ftbsc/lll/processor/LilleroProcessor.java +++ b/src/main/java/ftbsc/lll/processor/LilleroProcessor.java @@ -6,6 +6,7 @@ import ftbsc.lll.processor.annotations.Injector; import ftbsc.lll.processor.annotations.Patch; import ftbsc.lll.tools.DescriptorBuilder; import ftbsc.lll.tools.SrgMapper; +import org.gradle.internal.impldep.org.objectweb.asm.Type; import org.objectweb.asm.tree.ClassNode; import org.objectweb.asm.tree.MethodNode; @@ -17,7 +18,9 @@ import javax.lang.model.element.TypeElement; import javax.lang.model.type.ExecutableType; import javax.lang.model.type.TypeMirror; import javax.tools.Diagnostic; +import javax.tools.FileObject; import javax.tools.JavaFileObject; +import javax.tools.StandardLocation; import java.io.IOException; import java.io.PrintWriter; import java.lang.annotation.Annotation; @@ -109,7 +112,7 @@ public class LilleroProcessor extends AbstractProcessor { return sb.toString(); } - private String getSrgElementName(MethodSpec m) { + private String getSrgMethodName(MethodSpec m) { return m.name; //TODO; } @@ -141,13 +144,13 @@ public class LilleroProcessor extends AbstractProcessor { MethodSpec targetClass = MethodSpec.methodBuilder("targetClass") .addModifiers(Modifier.PUBLIC) .returns(String.class) - .addStatement("return $S", ann.value().getName()) + .addStatement("return $S", mapper.getMcpClass(Type.getInternalName(ann.value()))) .build(); MethodSpec methodName = MethodSpec.methodBuilder("methodName") .addModifiers(Modifier.PUBLIC) .returns(String.class) - .addStatement("return $S", getSrgElementName(targetMethod)) + .addStatement("return $S", getSrgMethodName(targetMethod)) .build(); MethodSpec methodDesc = MethodSpec.methodBuilder("methodDesc") @@ -176,15 +179,20 @@ public class LilleroProcessor extends AbstractProcessor { .build(); try { - JavaFileObject builderFile = processingEnv.getFiler().createSourceFile(injectorClassName); - PrintWriter out = new PrintWriter(builderFile.openWriter()); - + JavaFileObject injectorFile = processingEnv.getFiler().createSourceFile(injectorClassName); + PrintWriter out = new PrintWriter(injectorFile.openWriter()); JavaFile javaFile = JavaFile.builder(packageName, injectorClass).build(); javaFile.writeTo(out); + out.close(); } catch(IOException e) {} } private void generateServiceProvider(Set<TypeElement> inj) { - //todo generate the services file + try { + FileObject serviceProvider = processingEnv.getFiler().createResource(StandardLocation.SOURCE_OUTPUT, "", "ftbsc.lll.IInjector"); + PrintWriter out = new PrintWriter(serviceProvider.openWriter()); + inj.forEach(i -> out.println(i.getQualifiedName() + "Injector")); + out.close(); + } catch(IOException e) {} } }
\ No newline at end of file |