我最近开始学习java处理器,并尝试在gradle中使用它们,当我构建项目时,我可以看到注释处理器jars(其他模块)被打印出来(我在app gradle文件中添加了这一点,你可以在下面看到),但没有被执行。我不知道我做错了什么。
我有一个具有以下结构的多模块项目
ROOT
|
|-app # contains main classes
|-annotations
|-processorsprocessors项目gradle文件:
plugins {
id 'java'
}
group 'org.example'
version '1.0-beta'
repositories {
mavenCentral()
}
dependencies {
compileOnly project(":annotations")
implementation(project(":annotations"))
testImplementation 'org.junit.jupiter:junit-jupiter-api:5.7.0'
testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.7.0'
}
test {
useJUnitPlatform()
}app gradle文件
plugins {
id 'java'
}
group 'org.example'
version '1.0-SNAPSHOT'
repositories {
mavenCentral()
}
tasks.withType(JavaCompile) {
doFirst {
println "AnnotationProcessorPath for $name is ${options.getAnnotationProcessorPath().getFiles()}"
}
}
compileJava {
options.annotationProcessorPath = configurations.annotationProcessor
}
dependencies {
compileOnly project(":annotations")
implementation project(":annotations")
implementation project(":processors")
annotationProcessor project(":processors")
// annotationProcessor "org.example:processors:1.0-beta"
testImplementation 'org.junit.jupiter:junit-jupiter-api:5.7.0'
testRuntimeOnly 'org.junit.jupiter:junit-jupiter-engine:5.7.0'
}
test {
useJUnitPlatform()
}注释1是默认的注释
我有一个记录和创建文件的处理器
@Override
public boolean process(Set<? extends TypeElement> set, RoundEnvironment roundEnvironment) {
processingEnv.getMessager().printMessage(Diagnostic.Kind.ERROR,"Testa asdfasdf");
...在我的app模块中,我有一个带@Builder注解的anotated类,这个注解在注解模块中声明,所以处理器应该会被执行
app gradle文件的输出
7:59:42 PM: Executing task 'Car.main()'...
> Task :annotations:compileJava UP-TO-DATE
> Task :annotations:processResources NO-SOURCE
> Task :annotations:classes UP-TO-DATE
> Task :annotations:jar UP-TO-DATE
> Task :processors:compileJava UP-TO-DATE
> Task :processors:processResources UP-TO-DATE
> Task :processors:classes UP-TO-DATE
> Task :processors:jar UP-TO-DATE
> Task :app:compileJava
AnnotationProcessorPath for compileJava is [/annotations/processors/build/libs/processors-1.0-beta.jar, /annotations/annotations/build/libs/annotations-1.0-SNAPSHOT.jar]
> Task :app:processResources UP-TO-DATE
> Task :app:classes
> Task :app:Car.main()
BUILD SUCCESSFUL in 242ms
8 actionable tasks: 2 executed, 6 up-to-date
7:59:42 PM: Task execution finished 'Car.main()'.发布于 2021-09-20 16:10:29
几个小时后,它通过在processors模块下创建文件javax.annotation.processing.Processor来工作
ROOT
|
--app # contains main classes
--annotations
--processors
|--main
|--java
|--resources
|--META-INF
|--services
|--javax.annotation.processing.Processor
|--test将其内容设置为处理器路径,在我的示例中为com.example.processors.BuilderProcessor
https://stackoverflow.com/questions/69245927
复制相似问题