Производя JPA2 метамодели из построение Gradle скрипт
Я пытаюсь настроить сценарий сборки Gradle для нового проекта. Этот проект будет использовать JPA 2 вместе с Querydsl.
на Следующая страница справочной документации Querydsl, они объясняют, как настроить их JPAAnnotationProcessor (apt) для Maven и Ant.
Я хотел бы сделать то же самое с Gradle, но я не знаю, как и мой возлюбленный друг не помог мне в этом. Мне нужно найти способ вызвать Javac (предпочтительно без каких-либо дополнительных зависимостей) с аргументами, чтобы указать процессор, который apt должен использовать (?)
7 ответов
Я не тестировал его, но это должно работать:
repositories {
mavenCentral()
}
apply plugin: 'java'
dependencies {
compile(group: 'com.mysema.querydsl', name: 'querydsl-apt', version: '1.8.4')
compile(group: 'com.mysema.querydsl', name: 'querydsl-jpa', version: '1.8.4')
compile(group: 'org.slf4j', name: 'slf4j-log4j12', version: '1.6.1')
}
compileJava {
doFirst {
Map otherArgs = [
includeAntRuntime: false,
destdir: destinationDir,
classpath: configurations.compile.asPath,
sourcepath: '',
target: targetCompatibility,
source: sourceCompatibility
]
options.compilerArgs = [
'-processor', 'com.mysema.query.apt.jpa.JPAAnnotationProcessor',
'-s', "${destinationDir.absolutePath}".toString()
]
Map antOptions = otherArgs + options.optionMap()
ant.javac(antOptions) {
source.addToAntBuilder(ant, 'src', FileCollection.AntType.MatchingTask)
options.compilerArgs.each {value ->
compilerarg(value: value)
}
}
}
}
надеюсь, что это помогает.
хотя у меня нет проблем с использованием gradle из Ant, я согласен с оригинальным плакатом, что это нежелательно в этом случае. Я нашел проект github Тома Андерсона здесь что описывает то, что я считаю лучшим подходом. Я изменил его на небольшое количество, чтобы соответствовать моим потребностям (вывод в src / main / generated), чтобы он выглядел так:
sourceSets {
generated
}
sourceSets.generated.java.srcDirs = ['src/main/generated']
configurations {
querydslapt
}
dependencies {
compile 'mine go here'
querydslapt 'com.mysema.querydsl:querydsl-apt:2.7.1'
}
task generateQueryDSL(type: Compile, group: 'build', description: 'Generates the QueryDSL query types') {
source = sourceSets.main.java
classpath = configurations.compile + configurations.querydslapt
options.compilerArgs = [
"-proc:only",
"-processor", "com.mysema.query.apt.jpa.JPAAnnotationProcessor"
]
destinationDir = sourceSets.generated.java.srcDirs.iterator().next()
}
compileJava.dependsOn generateQueryDSL
этот подход имеет гораздо больше смысла для меня, чем другой, если он делает для вас тоже, то у вас есть другой вариант для поколение querydsl.
суть этого парня сработала для меня:https://gist.github.com/EdwardBeckett/5377401
sourceSets {
generated {
java {
srcDirs = ['src/main/generated']
}
}
}
configurations {
querydslapt
}
dependencies {
compile 'org.hibernate.javax.persistence:hibernate-jpa-2.0-api:1.0.1.Final'
compile "com.mysema.querydsl:querydsl-jpa:$querydslVersion"
querydslapt "com.mysema.querydsl:querydsl-apt:$querydslVersion"
}
task generateQueryDSL(type: JavaCompile, group: 'build', description: 'Generates the QueryDSL query types') {
source = sourceSets.main.java
classpath = configurations.compile + configurations.querydslapt
options.compilerArgs = [
"-proc:only",
"-processor", "com.mysema.query.apt.jpa.JPAAnnotationProcessor"
]
destinationDir = sourceSets.generated.java.srcDirs.iterator().next()
}
compileJava {
dependsOn generateQueryDSL
source generateQueryDSL.destinationDir
}
compileGeneratedJava {
dependsOn generateQueryDSL
options.warnings = false
classpath += sourceSets.main.runtimeClasspath
}
clean {
delete sourceSets.generated.java.srcDirs
}
idea {
module {
sourceDirs += file('src/main/generated')
}
}
вот простая настройка, которая работает и интегрируется с netbeans. Javac будет в основном делать ВСЮ работу, необходимую без особого вмешательства. Остальные мелкие treaks, что сделает его работу с IDE как NetBeans.
apply plugin:'java'
dependencies {
// Compile-time dependencies should contain annotation processors
compile(group: 'com.mysema.querydsl', name: 'querydsl-apt', version: '1.8.4')
compile(group: 'com.mysema.querydsl', name: 'querydsl-jpa', version: '1.8.4')
compile(group: 'org.slf4j', name: 'slf4j-log4j12', version: '1.6.1')
}
ext {
generatedSourcesDir = file("${buildDir}/generated-sources/javac/main/java")
}
// This section is the key to IDE integration.
// IDE will look for source files in both in both
//
// * src/main/java
// * build/generated-sources/javac/main/java
//
sourceSets {
main {
java {
srcDir 'src/main/java'
srcDir generatedSourcesDir
}
}
}
// These are the only modifications to build process that are required.
compileJava {
doFirst {
// Directory should exists before compilation started.
generatedSourcesDir.mkdirs()
}
options.compilerArgs += ['-s', generatedSourcesDir]
}
и это все. Javac сделает остальную часть работы.
С Gradle 1.3 и новее (старые не протестированы) вы можете использовать Querydsl APT следующим образом:
configurations {
javacApt
}
dependencies {
javacApt 'com.mysema.querydsl:querydsl-apt:3.3.0'
}
compileJava {
options.compilerArgs <<
'-processorpath' << (configurations.compile + configurations.javacApt).asPath <<
'-processor' << 'com.mysema.query.apt.jpa.JPAAnnotationProcessor'
}
эти args компилятора передаются непосредственно javac.
использовать с Groovy compiler replace compileJava
С compileGroovy
.
чтобы использовать генератор метамодели JPA с Gradle, я успешно использую следующее в своей сборке.Gradle и он работает как шарм:
buildscript {
ext {}
repositories { // maven central & plugins.gradle.org/m2 }
dependencies {
// other dependencies, e.g. Spring
classpath('gradle.plugin.at.comm_unity.gradle.plugins:jpamodelgen-plugin:1.1.1')
}
apply plugin: 'at.comm_unity.gradle.plugins.jpamodelgen'
dependencies {
compile('org.hibernate:hibernate-jpamodelgen:5.1.0.Final')
}
jpaModelgen {
jpaModelgenSourcesDir = "src/main/java"
}
compileJava.options.compilerArgs += ["-proc:none"]
}
в задаче построения создаются статические классы метамодели с суффиксом'_'. После этого они находятся в том же каталоге, что и мои модели @Entity.
пример QueryDSL Ant должен работать почти так же, как когда вы берете весь XML. Таким образом, это заканчивается примерно так:
javac -sourcepath ${src} -cp ${cp} -proc:only -processor com.mysema.query.apt.jpa.JPAAnnotationProcessor -s ${generated}
src
, cp
и generated
вы, вероятно, сможете извлечь из Gradle.