mirror of https://github.com/apache/lucene.git
127 lines
3.7 KiB
Groovy
127 lines
3.7 KiB
Groovy
/*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright ownership.
|
|
* The ASF licenses this file to You under the Apache License, Version 2.0
|
|
* (the "License"); you may not use this file except in compliance with
|
|
* the License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
// Configure Java project defaults.
|
|
|
|
allprojects {
|
|
plugins.withType(JavaPlugin) {
|
|
sourceCompatibility = rootProject.minJavaVersion
|
|
targetCompatibility = rootProject.minJavaVersion
|
|
|
|
// Use 'release' flag instead of 'source' and 'target'
|
|
tasks.withType(JavaCompile) {
|
|
options.compilerArgs += ["--release", rootProject.minJavaVersion.toString()]
|
|
}
|
|
|
|
// Configure warnings.
|
|
// Use 'javac --help-lint' to get the supported list
|
|
tasks.withType(JavaCompile) {
|
|
options.encoding = "UTF-8"
|
|
options.compilerArgs += [
|
|
"-Xlint:auxiliaryclass",
|
|
"-Xlint:cast",
|
|
"-Xlint:classfile",
|
|
"-Xlint:-deprecation",
|
|
"-Xlint:dep-ann",
|
|
"-Xlint:divzero",
|
|
"-Xlint:empty",
|
|
// TODO: uh-oh we have broken APIs.
|
|
"-Xlint:-exports",
|
|
"-Xlint:fallthrough",
|
|
"-Xlint:finally",
|
|
// TODO: untested
|
|
"-Xlint:-missing-explicit-ctor",
|
|
"-Xlint:module",
|
|
"-Xlint:opens",
|
|
"-Xlint:options",
|
|
"-Xlint:overloads",
|
|
"-Xlint:overrides",
|
|
// TODO: some tests seem to have bad classpaths?
|
|
// this check seems to be a good sanity check for gradle?
|
|
"-Xlint:-path",
|
|
"-Xlint:processing",
|
|
"-Xlint:rawtypes",
|
|
"-Xlint:removal",
|
|
"-Xlint:requires-automatic",
|
|
"-Xlint:requires-transitive-automatic",
|
|
"-Xlint:-serial",
|
|
"-Xlint:static",
|
|
"-Xlint:strictfp",
|
|
"-Xlint:synchronization",
|
|
"-Xlint:text-blocks",
|
|
"-Xlint:try",
|
|
"-Xlint:unchecked",
|
|
"-Xlint:varargs",
|
|
"-Xlint:preview",
|
|
"-Xdoclint:all/protected",
|
|
"-Xdoclint:-missing",
|
|
"-Xdoclint:-accessibility",
|
|
"-proc:none", // proc:none was added because of LOG4J2-1925 / JDK-8186647
|
|
]
|
|
|
|
if (propertyOrDefault("javac.failOnWarnings", true).toBoolean()) {
|
|
options.compilerArgs += "-Werror"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
configure(project(":lucene:core")) {
|
|
plugins.withType(JavaPlugin) {
|
|
sourceSets {
|
|
main19 {
|
|
java {
|
|
srcDirs = ['src/java19']
|
|
}
|
|
}
|
|
}
|
|
|
|
configurations {
|
|
// Inherit any dependencies from the main source set.
|
|
main19Implementation.extendsFrom implementation
|
|
}
|
|
|
|
dependencies {
|
|
// We need the main classes to compile our Java 19 pieces.
|
|
main19Implementation sourceSets.main.output
|
|
}
|
|
|
|
tasks.named('compileMain19Java').configure {
|
|
javaCompiler = javaToolchains.compilerFor {
|
|
languageVersion = JavaLanguageVersion.of(19)
|
|
}
|
|
|
|
// undo alternative JDK support:
|
|
options.forkOptions.javaHome = null
|
|
|
|
sourceCompatibility = 19
|
|
targetCompatibility = 19
|
|
options.compilerArgs += ["--release", 19 as String, "--enable-preview"]
|
|
}
|
|
|
|
tasks.named('jar').configure {
|
|
into('META-INF/versions/19') {
|
|
from sourceSets.main19.output
|
|
}
|
|
|
|
manifest.attributes(
|
|
'Multi-Release': 'true'
|
|
)
|
|
}
|
|
}
|
|
}
|