这个想法很简单,我想直接在我的构建脚本中访问项目类。
我第一次尝试:
apply plugin: 'java'
tasks.create(name: 'randomTask', type: SourceTask) {
source.each {
println it
}
}
遗憾地得到零文件。
然后我决定试试compileJava:
apply plugin: 'java'
compileJava {
source.each {
println it
}
}
虽然我确实得到了一个将被编译的文件列表,但它并不是我真正需要的。我想获取文件的Class对象。
例如,如果我有com.example.SomeClass
,我希望得到Class<com.example.SomeClass>
,以便我可以对这些类使用反射。
这是我不喜欢的一个非工作的例子:
apply plugin: 'java'
tasks.create(name: 'randomTask', type: SomeMagicalType) {
UMLBuilder builder = UMLBuilder.builder()
classes.each { clazz ->
clazz.methods.each { method ->
builder.addMethod(method)
}
}
builder.build().writeToFile(file('out/application.uml'))
}
P.S。:我正在使用Gradle 2.5和Java 8
答案 0 :(得分:3)
我试图在项目中获取类并实例化它们。这是我设法得到的,它并不漂亮,但它完成了获取Class对象的原始工作
task allMethods(dependsOn: classes) << {
def ncl = new GroovyClassLoader()
ncl.addClasspath("${sourceSets.main.output.classesDir}")
configurations.compile.each { ncl.addClasspath(it.path) }
def cTree = fileTree(dir: sourceSets.main.output.classesDir)
def cFiles = cTree.matching {
include '**/*.class'
exclude '**/*$*.class'
}
cFiles.each { f ->
def c = f.path - (sourceSets.main.output.classesDir.path + "/")
def cname = c.replaceAll('/', '\\.') - ".class"
def cz = Class.forName(cname, false, ncl)
cz.methods.each { println it }
}
}
它创建一个新的类加载器,添加默认输出类dir和compile
配置中的所有依赖类,然后从classesDir构建文件列表,将它们从路径转换为格式的字符串&#39; abYourClass&#39;,然后将其加载并转储出类上的方法。
您可以为所需方法添加自己的逻辑,但这应该可以帮助您。