Schedule compileJava after the internal task if it affects source files (#13282)

This commit is contained in:
Dawid Weiss 2024-04-09 07:44:07 +02:00 committed by GitHub
parent df0384c34f
commit afe982b3ef
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
10 changed files with 98 additions and 48 deletions

View File

@ -82,7 +82,10 @@ configure(project(":lucene:expressions")) {
} }
def generateAntlr = wrapWithPersistentChecksums( def generateAntlr = wrapWithPersistentChecksums(
generateAntlrInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) generateAntlrInternal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
regenerate.dependsOn generateAntlr regenerate.dependsOn generateAntlr
} }

View File

@ -39,7 +39,10 @@ configure(project(":lucene:core")) {
} }
} }
regenerate.dependsOn wrapWithPersistentChecksums(generateForUtilInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) regenerate.dependsOn wrapWithPersistentChecksums(generateForUtilInternal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
} }
configure(project(":lucene:backward-codecs")) { configure(project(":lucene:backward-codecs")) {
@ -64,7 +67,10 @@ configure(project(":lucene:backward-codecs")) {
} }
} }
regenerate.dependsOn wrapWithPersistentChecksums(generateForUtil84Internal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) regenerate.dependsOn wrapWithPersistentChecksums(generateForUtil84Internal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
task generateForUtil90Internal() { task generateForUtil90Internal() {
description "Regenerate gen_ForUtil.py" description "Regenerate gen_ForUtil.py"
@ -86,6 +92,9 @@ configure(project(":lucene:backward-codecs")) {
} }
} }
regenerate.dependsOn wrapWithPersistentChecksums(generateForUtil90Internal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) regenerate.dependsOn wrapWithPersistentChecksums(generateForUtil90Internal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
} }

View File

@ -159,8 +159,13 @@ configure(project(":lucene:analysis:icu")) {
} }
} }
regenerate.dependsOn wrapWithPersistentChecksums(genUtr30DataFilesInternal, [ ignoreWithSource: icuCompileTask ]) regenerate.dependsOn wrapWithPersistentChecksums(genUtr30DataFilesInternal, [
regenerate.dependsOn wrapWithPersistentChecksums(genRbbiInternal) ignoreWithSource: icuCompileTask,
mustRunBefore: [ "compileJava" ]
])
regenerate.dependsOn wrapWithPersistentChecksums(genRbbiInternal, [
mustRunBefore: [ "compileJava" ]
])
task compileIcuWindows() { task compileIcuWindows() {
doFirst { doFirst {
@ -281,5 +286,8 @@ configure(project(":lucene:analysis:common")) {
} }
} }
regenerate.dependsOn wrapWithPersistentChecksums(generateUnicodePropsInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) regenerate.dependsOn wrapWithPersistentChecksums(generateUnicodePropsInternal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
} }

View File

@ -232,9 +232,14 @@ configure(project(":lucene:queryparser")) {
description "Regenerate query parsers (javacc syntax definitions)." description "Regenerate query parsers (javacc syntax definitions)."
group "generation" group "generation"
dependsOn wrapWithPersistentChecksums(javaccParserClassicInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]), def extraConfig = [
wrapWithPersistentChecksums(javaccParserSurroundInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]), andThenTasks: ["spotlessJava", "spotlessJavaApply"],
wrapWithPersistentChecksums(javaccParserFlexibleInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) mustRunBefore: [ "compileJava" ]
]
dependsOn wrapWithPersistentChecksums(javaccParserClassicInternal, extraConfig),
wrapWithPersistentChecksums(javaccParserSurroundInternal, extraConfig),
wrapWithPersistentChecksums(javaccParserFlexibleInternal, extraConfig)
} }
regenerate.dependsOn javacc regenerate.dependsOn javacc

View File

@ -51,7 +51,10 @@ configure(project(":lucene:core")) {
} }
} }
def generateStandardTokenizer = wrapWithPersistentChecksums(generateStandardTokenizerInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) def generateStandardTokenizer = wrapWithPersistentChecksums(generateStandardTokenizerInternal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
regenerate.dependsOn generateStandardTokenizer regenerate.dependsOn generateStandardTokenizer
} }
@ -149,7 +152,11 @@ configure(project(":lucene:analysis:common")) {
} }
} }
def generateUAX29URLEmailTokenizer = wrapWithPersistentChecksums(generateUAX29URLEmailTokenizerInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) def generateUAX29URLEmailTokenizer = wrapWithPersistentChecksums(generateUAX29URLEmailTokenizerInternal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
// UAX29URLEmailTokenizerImpl.jflex includes: ASCIITLD.jflex // UAX29URLEmailTokenizerImpl.jflex includes: ASCIITLD.jflex
// so we make sure it is up to date. Also, make sure the ordering of internal // so we make sure it is up to date. Also, make sure the ordering of internal
// tasks is enforced (just scheduling top-level wrappers doesn't mean their subtask graphs cannot be reordered). // tasks is enforced (just scheduling top-level wrappers doesn't mean their subtask graphs cannot be reordered).
@ -197,7 +204,12 @@ configure(project(":lucene:analysis:common")) {
skeleton = skeletonDefault skeleton = skeletonDefault
} }
def generateHTMLStripCharFilter = wrapWithPersistentChecksums(generateHTMLStripCharFilterInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) def extraConfig = [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
]
def generateHTMLStripCharFilter = wrapWithPersistentChecksums(generateHTMLStripCharFilterInternal, extraConfig)
// HTMLStripCharFilter.jflex includes HTMLCharacterEntities.jflex so we make sure it's up to date. // HTMLStripCharFilter.jflex includes HTMLCharacterEntities.jflex so we make sure it's up to date.
configure(generateHTMLStripCharFilter) { configure(generateHTMLStripCharFilter) {
dependsOn "generateHTMLCharacterEntities" dependsOn "generateHTMLCharacterEntities"
@ -206,12 +218,12 @@ configure(project(":lucene:analysis:common")) {
dependsOn "generateHTMLCharacterEntitiesInternal" dependsOn "generateHTMLCharacterEntitiesInternal"
} }
regenerate.dependsOn wrapWithPersistentChecksums(generateWikipediaTokenizerInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]), regenerate.dependsOn wrapWithPersistentChecksums(generateWikipediaTokenizerInternal, extraConfig),
wrapWithPersistentChecksums(generateClassicTokenizerInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]), wrapWithPersistentChecksums(generateClassicTokenizerInternal, extraConfig),
generateUAX29URLEmailTokenizer, generateUAX29URLEmailTokenizer,
wrapWithPersistentChecksums(generateHTMLCharacterEntitiesInternal), wrapWithPersistentChecksums(generateHTMLCharacterEntitiesInternal, extraConfig),
generateHTMLStripCharFilter, generateHTMLStripCharFilter,
wrapWithPersistentChecksums(generateTldsInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) wrapWithPersistentChecksums(generateTldsInternal, extraConfig)
} }
class JFlexTask extends DefaultTask { class JFlexTask extends DefaultTask {

View File

@ -105,8 +105,13 @@ configure(project(":lucene:core")) {
description "Regenerate Moman-based sources." description "Regenerate Moman-based sources."
group "generation" group "generation"
dependsOn wrapWithPersistentChecksums(utilGenPackedInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) def extraConfig = [
dependsOn wrapWithPersistentChecksums(utilGenLevInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
]
dependsOn wrapWithPersistentChecksums(utilGenPackedInternal, extraConfig)
dependsOn wrapWithPersistentChecksums(utilGenLevInternal, extraConfig)
} }
regenerate.dependsOn moman regenerate.dependsOn moman

View File

@ -105,16 +105,21 @@ configure([
// //
// The idea is that, given source-generating task "sourceTaskInternal" (note the suffix), // The idea is that, given source-generating task "sourceTaskInternal" (note the suffix),
// we create a bunch of other tasks that perform checksum generation, validation and // we create a bunch of other tasks that perform checksum generation, validation and
// source task skipping; example (sourceTask has Internal suffix stripped) // source task skipping. For example, let's say we have a task 'genFooInternal";
// the following tasks would be created
// //
// ${sourceTask}ChecksumLoad // genFooChecksumLoad
// ${sourceTask}ChecksumSave // genFooChecksumSave
// ${sourceTask}ChecksumCheck (fails if checksums are inconsistent) // genFooChecksumCheck (fails if checksums are inconsistent)
// ${sourceTask} dependsOn [checksum-load, ${sourceTask}Internal, checksum-save] //
// and the following set of dependencies would be created (with additional
// constraints to run them in this particular order!).
//
// genFoo.dependsOn [genFooChecksumLoad, genFooInternal, genFooChecksumSave]
// //
// Checksums are persisted and computed from sourceTask's inputs/outputs. If the // Checksums are persisted and computed from sourceTask's inputs/outputs. If the
// persisted checksums are identical to current checksums, source task // persisted checksums are identical to the now-current checksums, the "internal" task
// is skipped (via sourceTaskInternal.onlyIf { false }). // is skipped (using onlyIf { false }).
// //
// Implementation-wise things get complicated because gradle doesn't have the notion // Implementation-wise things get complicated because gradle doesn't have the notion
// of "ordered" task execution with respect to task AND its dependencies (we can add // of "ordered" task execution with respect to task AND its dependencies (we can add
@ -122,8 +127,11 @@ configure([
// //
// sourceTask - the task to wrap // sourceTask - the task to wrap
// extraConfig - a map with extra (optional) configuration options. // extraConfig - a map with extra (optional) configuration options.
// andThenTasks: other tasks that should be scheduled to run after source task and // andThenTasks: any other tasks that should be scheduled to run after the internal task and
// before checksum calculation. // before checksum calculation/ saving. spotless is a good example of this.
// ignoreWithSource: any other tasks that should be ignored if the internal task is ignored
// (checksums are identical)
// mustRunBefore: any tasks which should be scheduled to run after the internal task.
wrapWithPersistentChecksums = { Task sourceTask, Map<String, Object> extraConfig = [:] -> wrapWithPersistentChecksums = { Task sourceTask, Map<String, Object> extraConfig = [:] ->
if (!sourceTask.name.endsWith("Internal")) { if (!sourceTask.name.endsWith("Internal")) {
throw new GradleException("Wrapped task must follow the convention name of *Internal: ${sourceTask.name}") throw new GradleException("Wrapped task must follow the convention name of *Internal: ${sourceTask.name}")
@ -144,6 +152,13 @@ configure([
List<Object> andThenTasks = toList(extraConfig.get("andThenTasks")) List<Object> andThenTasks = toList(extraConfig.get("andThenTasks"))
List<Object> ignoreWithSource = toList(extraConfig.get("ignoreWithSource")) List<Object> ignoreWithSource = toList(extraConfig.get("ignoreWithSource"))
// Schedule must-run-afters
List<Object> mustRunBefore = toList(extraConfig.get("mustRunBefore"))
// TODO: maybe ensure all task refs here are strings?
tasks.matching { it.name in mustRunBefore }.configureEach {
mustRunAfter sourceTask
}
// Create checksum-loader task. // Create checksum-loader task.
Task checksumLoadTask = tasks.create("${sourceTaskName}ChecksumLoad", { Task checksumLoadTask = tasks.create("${sourceTaskName}ChecksumLoad", {
ext { ext {

View File

@ -109,5 +109,9 @@ configure(project(":lucene:analysis:common")) {
} }
} }
regenerate.dependsOn wrapWithPersistentChecksums(snowballInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"], ignoreWithSource: [downloadSnowballStemmers, downloadSnowballWebsite] ]) regenerate.dependsOn wrapWithPersistentChecksums(snowballInternal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
ignoreWithSource: [downloadSnowballStemmers, downloadSnowballWebsite],
mustRunBefore: [ "compileJava" ]
])
} }

View File

@ -43,7 +43,10 @@ configure(project(":lucene:test-framework")) {
} }
} }
} }
regenerate.dependsOn wrapWithPersistentChecksums(generateEmojiTokenizationTestInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) regenerate.dependsOn wrapWithPersistentChecksums(generateEmojiTokenizationTestInternal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
task generateJavaUnicodeWordBreakTestInternal() { task generateJavaUnicodeWordBreakTestInternal() {
def unicodeVersion = "12.1" def unicodeVersion = "12.1"
@ -71,6 +74,8 @@ configure(project(":lucene:test-framework")) {
} }
} }
regenerate.dependsOn wrapWithPersistentChecksums(generateJavaUnicodeWordBreakTestInternal, [ andThenTasks: ["spotlessJava", "spotlessJavaApply"] ]) regenerate.dependsOn wrapWithPersistentChecksums(generateJavaUnicodeWordBreakTestInternal, [
andThenTasks: ["spotlessJava", "spotlessJavaApply"],
mustRunBefore: [ "compileJava" ]
])
} }

View File

@ -16,22 +16,6 @@ In many cases hitting (1) means you'll have to do (2) so let's discuss
these in order. these in order.
SPECIAL NOTE
------------
Regeneration tasks currently don't play well with the current gradle version.
To workaround the issue, compile everything first:
gradlew compileJava
Then run the commands as described in this document, excluding compileJava.
For example to run "regenerate":
gradlew regenerate -x compileJava
More information: https://github.com/apache/lucene/issues/13240
Checksum validation errors Checksum validation errors
-------------------------- --------------------------