From 8a855bd1823c225cac2216acc2da9c65fcf93c1c Mon Sep 17 00:00:00 2001 From: nathan Date: Sun, 17 Mar 2019 22:40:35 +0100 Subject: [PATCH] Added kotlin build script for gradle --- build.gradle.kts | 379 ++++++++++++++++++++++++++++++++++++++++++++ gradlew | 172 ++++++++++++++++++++ gradlew.bat | 84 ++++++++++ settings.gradle.kts | 15 ++ 4 files changed, 650 insertions(+) create mode 100644 build.gradle.kts create mode 100755 gradlew create mode 100644 gradlew.bat create mode 100644 settings.gradle.kts diff --git a/build.gradle.kts b/build.gradle.kts new file mode 100644 index 0000000..721a84d --- /dev/null +++ b/build.gradle.kts @@ -0,0 +1,379 @@ +/* + * Copyright 2018 dorkbox, llc + * + * Licensed 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. + */ + +import com.github.benmanes.gradle.versions.updates.DependencyUpdatesTask +import java.time.Instant +import java.util.Properties +import kotlin.collections.ArrayList +import kotlin.collections.component1 +import kotlin.collections.component2 +import kotlin.collections.set +import kotlin.reflect.KMutableProperty +import kotlin.reflect.full.declaredMemberProperties + +/////////////////////////////// +////// PUBLISH TO SONATYPE / MAVEN CENTRAL +////// +////// TESTING : local maven repo +////// +////// RELEASE : sonatype / maven central, then +/////////////////////////////// + +println("\tGradle ${project.gradle.gradleVersion}") + +plugins { + java + signing + `maven-publish` + + // close and release on sonatype + id("io.codearte.nexus-staging") version "0.20.0" + + id("com.dorkbox.CrossCompile") version "1.0.1" + id("com.dorkbox.Licensing") version "1.4" + id("com.dorkbox.VersionUpdate") version "1.4.1" + + // setup checking for the latest version of a plugin or dependency + id("com.github.ben-manes.versions") version "0.20.0" + + kotlin("jvm") version "1.3.11" +} + +object Extras { + // set for the project + const val description = "Linux, MacOS, or Windows (notification/growl/toast/) popups for the desktop for Java 6+" + const val group = "com.dorkbox" + const val version = "3.7" + + // set as project.ext + const val name = "Notify" + const val id = "Notify" + const val vendor = "Dorkbox LLC" + const val url = "https://git.dorkbox.com/dorkbox/Notify" + val buildDate = Instant.now().toString() + + val JAVA_VERSION = JavaVersion.VERSION_1_6.toString() + + var sonatypeUserName = "" + var sonatypePassword = "" +} + +/////////////////////////////// +///// assign 'Extras' +///////////////////////////////z +description = Extras.description +group = Extras.group +version = Extras.version + +val propsFile = File("$projectDir/../../gradle.properties").normalize() +if (propsFile.canRead()) { + println("\tLoading custom property data from: [$propsFile]") + + val props = Properties() + propsFile.inputStream().use { + props.load(it) + } + + val extraProperties = Extras::class.declaredMemberProperties.filterIsInstance>() + props.forEach { (k, v) -> run { + val key = k as String + val value = v as String + + val member = extraProperties.find { it.name == key } + if (member != null) { + member.setter.call(Extras::class.objectInstance, value) + } + else { + project.extra.set(k, v) + } + }} +} + +licensing { + license(License.APACHE_2) { + author(Extras.vendor) + url(Extras.url) + note(Extras.description) + } + + license("Dorkbox Utils", License.APACHE_2) { + author(Extras.vendor) + url("https://git.dorkbox.com/dorkbox/Utilities") + } + + license("Dorkbox TweenEngine", License.APACHE_2) { + author(Extras.vendor) + url("https://git.dorkbox.com/dorkbox/TweenEngine") + } +} + +sourceSets { + main { + java { + setSrcDirs(listOf("src")) + + // want to include java files for the source. 'setSrcDirs' resets includes... + include("**/*.java") + } + } + + test { + java { + setSrcDirs(listOf("test")) + + // want to include java files for the source. 'setSrcDirs' resets includes... + include("**/*.java") + } + } +} + +repositories { + mavenLocal() // this must be first! + jcenter() +} + +/////////////////////////////// +////// UTILITIES COMPILE +/////////////////////////////// + +// as long as the 'Utilities' project is ALSO imported into IntelliJ, class resolution will work (add the sources in the intellij project) +val utils : Configuration by configurations.creating + +fun javaFile(vararg fileNames: String): Iterable { + val fileList = ArrayList(fileNames.size) + + fileNames.forEach { name -> + fileList.add(name.replace('.', '/') + ".java") + } + + return fileList +} + + +task("compileUtils") { + // we don't want the default include of **/*.java + includes.clear() + + source = fileTree("../Utilities/src") + include(javaFile( + "dorkbox.util.OS", + "dorkbox.util.OSType", + "dorkbox.util.Property", + "dorkbox.util.IO", + "dorkbox.util.FileUtil", + "dorkbox.util.FontUtil", + + "dorkbox.util.LocationResolver", + "dorkbox.util.ScreenUtil", + + "dorkbox.util.SwingUtil", + "dorkbox.util.ImageUtil", + "dorkbox.util.MathUtil", + + "dorkbox.util.ActionHandler", + "dorkbox.util.ActionHandlerLong" + )) + + // entire packages/directories + include("dorkbox/util/swing/*.java") + + classpath = files(utils) + destinationDir = file("$rootDir/build/classes_utilities") +} + +/////////////////////////////// +////// Task defaults +/////////////////////////////// +tasks.withType { + options.encoding = "UTF-8" + + sourceCompatibility = Extras.JAVA_VERSION + targetCompatibility = Extras.JAVA_VERSION +} + +tasks.withType { + duplicatesStrategy = DuplicatesStrategy.FAIL +} + +tasks.jar.get().apply { + // include applicable class files from subset of Utilities project + from((tasks["compileUtils"] as JavaCompile).outputs) + + manifest { + // https://docs.oracle.com/javase/tutorial/deployment/jar/packageman.html + attributes["Name"] = Extras.name + + attributes["Specification-Title"] = Extras.name + attributes["Specification-Version"] = Extras.version + attributes["Specification-Vendor"] = Extras.vendor + + attributes["Implementation-Title"] = "${Extras.group}.${Extras.id}" + attributes["Implementation-Version"] = Extras.buildDate + attributes["Implementation-Vendor"] = Extras.vendor + } +} + +tasks.compileJava.get().apply { + println("\tCompiling classes to Java $sourceCompatibility") +} + + +dependencies { + api("com.dorkbox:TweenEngine:8.3") + + // add compile utils to dependencies + implementation(files((tasks["compileUtils"] as JavaCompile).outputs)) +} + +/////////////////////////////// +////// PUBLISH TO SONATYPE / MAVEN CENTRAL +////// +////// TESTING : local maven repo +////// +////// RELEASE : sonatype / maven central, then +/////////////////////////////// +val sourceJar = task("sourceJar") { + description = "Creates a JAR that contains the source code." + + from(sourceSets["main"].java) + + archiveClassifier.set("sources") +} + +val javaDocJar = task("javaDocJar") { + description = "Creates a JAR that contains the javadocs." + + archiveClassifier.set("javadoc") +} + +publishing { + publications { + create("maven") { + groupId = Extras.group + artifactId = Extras.id + version = Extras.version + + from(components["java"]) + + artifact(sourceJar) + artifact(javaDocJar) + + pom { + name.set(Extras.name) + description.set(Extras.description) + url.set(Extras.url) + + issueManagement { + url.set("${Extras.url}/issues") + system.set("Gitea Issues") + } + organization { + name.set(Extras.vendor) + url.set("https://dorkbox.com") + } + developers { + developer { + id.set("dorkbox") + name.set(Extras.vendor) + email.set("email@dorkbox.com") + } + } + scm { + url.set(Extras.url) + connection.set("scm:${Extras.url}.git") + } + } + + } + } + + + repositories { + maven { + setUrl("https://oss.sonatype.org/service/local/staging/deploy/maven2") + credentials { + username = Extras.sonatypeUserName + password = Extras.sonatypePassword + } + } + } + + + tasks.withType { + onlyIf { + publication == publishing.publications["maven"] && repository == publishing.repositories["maven"] + } + } + + tasks.withType { + onlyIf { + publication == publishing.publications["maven"] + } + } + + // output the release URL in the console + tasks["releaseRepository"].doLast { + val url = "https://oss.sonatype.org/content/repositories/releases/" + val projectName = Extras.group.replace('.', '/') + val name = Extras.name + val version = Extras.version + + println("Maven URL: $url$projectName/$name/$version/") + } +} + +nexusStaging { + username = Extras.sonatypeUserName + password = Extras.sonatypePassword +} + +signing { + sign(publishing.publications["maven"]) +} + + + +/////////////////////////////// +///// Prevent anything other than a release from showing version updates +//// https://github.com/ben-manes/gradle-versions-plugin/blob/master/README.md +/////////////////////////////// +tasks.named("dependencyUpdates") { + resolutionStrategy { + componentSelection { + all { + val rejected = listOf("alpha", "beta", "rc", "cr", "m", "preview") + .map { qualifier -> Regex("(?i).*[.-]$qualifier[.\\d-]*") } + .any { it.matches(candidate.version) } + if (rejected) { + reject("Release candidate") + } + } + } + } + + // optional parameters + checkForGradleUpdate = true +} + + +/////////////////////////////// +////// Gradle Wrapper Configuration. +///// Run this task, then refresh the gradle project +/////////////////////////////// +val wrapperUpdate by tasks.creating(Wrapper::class) { + gradleVersion = "5.1.1" + distributionUrl = distributionUrl.replace("bin", "all") +} diff --git a/gradlew b/gradlew new file mode 100755 index 0000000..af6708f --- /dev/null +++ b/gradlew @@ -0,0 +1,172 @@ +#!/usr/bin/env sh + +############################################################################## +## +## Gradle start up script for UN*X +## +############################################################################## + +# Attempt to set APP_HOME +# Resolve links: $0 may be a link +PRG="$0" +# Need this for relative symlinks. +while [ -h "$PRG" ] ; do + ls=`ls -ld "$PRG"` + link=`expr "$ls" : '.*-> \(.*\)$'` + if expr "$link" : '/.*' > /dev/null; then + PRG="$link" + else + PRG=`dirname "$PRG"`"/$link" + fi +done +SAVED="`pwd`" +cd "`dirname \"$PRG\"`/" >/dev/null +APP_HOME="`pwd -P`" +cd "$SAVED" >/dev/null + +APP_NAME="Gradle" +APP_BASE_NAME=`basename "$0"` + +# Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +DEFAULT_JVM_OPTS='"-Xmx64m"' + +# Use the maximum available, or set MAX_FD != -1 to use that value. +MAX_FD="maximum" + +warn () { + echo "$*" +} + +die () { + echo + echo "$*" + echo + exit 1 +} + +# OS specific support (must be 'true' or 'false'). +cygwin=false +msys=false +darwin=false +nonstop=false +case "`uname`" in + CYGWIN* ) + cygwin=true + ;; + Darwin* ) + darwin=true + ;; + MINGW* ) + msys=true + ;; + NONSTOP* ) + nonstop=true + ;; +esac + +CLASSPATH=$APP_HOME/gradle/wrapper/gradle-wrapper.jar + +# Determine the Java command to use to start the JVM. +if [ -n "$JAVA_HOME" ] ; then + if [ -x "$JAVA_HOME/jre/sh/java" ] ; then + # IBM's JDK on AIX uses strange locations for the executables + JAVACMD="$JAVA_HOME/jre/sh/java" + else + JAVACMD="$JAVA_HOME/bin/java" + fi + if [ ! -x "$JAVACMD" ] ; then + die "ERROR: JAVA_HOME is set to an invalid directory: $JAVA_HOME + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." + fi +else + JAVACMD="java" + which java >/dev/null 2>&1 || die "ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. + +Please set the JAVA_HOME variable in your environment to match the +location of your Java installation." +fi + +# Increase the maximum file descriptors if we can. +if [ "$cygwin" = "false" -a "$darwin" = "false" -a "$nonstop" = "false" ] ; then + MAX_FD_LIMIT=`ulimit -H -n` + if [ $? -eq 0 ] ; then + if [ "$MAX_FD" = "maximum" -o "$MAX_FD" = "max" ] ; then + MAX_FD="$MAX_FD_LIMIT" + fi + ulimit -n $MAX_FD + if [ $? -ne 0 ] ; then + warn "Could not set maximum file descriptor limit: $MAX_FD" + fi + else + warn "Could not query maximum file descriptor limit: $MAX_FD_LIMIT" + fi +fi + +# For Darwin, add options to specify how the application appears in the dock +if $darwin; then + GRADLE_OPTS="$GRADLE_OPTS \"-Xdock:name=$APP_NAME\" \"-Xdock:icon=$APP_HOME/media/gradle.icns\"" +fi + +# For Cygwin, switch paths to Windows format before running java +if $cygwin ; then + APP_HOME=`cygpath --path --mixed "$APP_HOME"` + CLASSPATH=`cygpath --path --mixed "$CLASSPATH"` + JAVACMD=`cygpath --unix "$JAVACMD"` + + # We build the pattern for arguments to be converted via cygpath + ROOTDIRSRAW=`find -L / -maxdepth 1 -mindepth 1 -type d 2>/dev/null` + SEP="" + for dir in $ROOTDIRSRAW ; do + ROOTDIRS="$ROOTDIRS$SEP$dir" + SEP="|" + done + OURCYGPATTERN="(^($ROOTDIRS))" + # Add a user-defined pattern to the cygpath arguments + if [ "$GRADLE_CYGPATTERN" != "" ] ; then + OURCYGPATTERN="$OURCYGPATTERN|($GRADLE_CYGPATTERN)" + fi + # Now convert the arguments - kludge to limit ourselves to /bin/sh + i=0 + for arg in "$@" ; do + CHECK=`echo "$arg"|egrep -c "$OURCYGPATTERN" -` + CHECK2=`echo "$arg"|egrep -c "^-"` ### Determine if an option + + if [ $CHECK -ne 0 ] && [ $CHECK2 -eq 0 ] ; then ### Added a condition + eval `echo args$i`=`cygpath --path --ignore --mixed "$arg"` + else + eval `echo args$i`="\"$arg\"" + fi + i=$((i+1)) + done + case $i in + (0) set -- ;; + (1) set -- "$args0" ;; + (2) set -- "$args0" "$args1" ;; + (3) set -- "$args0" "$args1" "$args2" ;; + (4) set -- "$args0" "$args1" "$args2" "$args3" ;; + (5) set -- "$args0" "$args1" "$args2" "$args3" "$args4" ;; + (6) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" ;; + (7) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" ;; + (8) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" ;; + (9) set -- "$args0" "$args1" "$args2" "$args3" "$args4" "$args5" "$args6" "$args7" "$args8" ;; + esac +fi + +# Escape application args +save () { + for i do printf %s\\n "$i" | sed "s/'/'\\\\''/g;1s/^/'/;\$s/\$/' \\\\/" ; done + echo " " +} +APP_ARGS=$(save "$@") + +# Collect all arguments for the java command, following the shell quoting and substitution rules +eval set -- $DEFAULT_JVM_OPTS $JAVA_OPTS $GRADLE_OPTS "\"-Dorg.gradle.appname=$APP_BASE_NAME\"" -classpath "\"$CLASSPATH\"" org.gradle.wrapper.GradleWrapperMain "$APP_ARGS" + +# by default we should be in the correct project dir, but when run from Finder on Mac, the cwd is wrong +if [ "$(uname)" = "Darwin" ] && [ "$HOME" = "$PWD" ]; then + cd "$(dirname "$0")" +fi + +exec "$JAVACMD" "$@" diff --git a/gradlew.bat b/gradlew.bat new file mode 100644 index 0000000..6d57edc --- /dev/null +++ b/gradlew.bat @@ -0,0 +1,84 @@ +@if "%DEBUG%" == "" @echo off +@rem ########################################################################## +@rem +@rem Gradle startup script for Windows +@rem +@rem ########################################################################## + +@rem Set local scope for the variables with windows NT shell +if "%OS%"=="Windows_NT" setlocal + +set DIRNAME=%~dp0 +if "%DIRNAME%" == "" set DIRNAME=. +set APP_BASE_NAME=%~n0 +set APP_HOME=%DIRNAME% + +@rem Add default JVM options here. You can also use JAVA_OPTS and GRADLE_OPTS to pass JVM options to this script. +set DEFAULT_JVM_OPTS="-Xmx64m" + +@rem Find java.exe +if defined JAVA_HOME goto findJavaFromJavaHome + +set JAVA_EXE=java.exe +%JAVA_EXE% -version >NUL 2>&1 +if "%ERRORLEVEL%" == "0" goto init + +echo. +echo ERROR: JAVA_HOME is not set and no 'java' command could be found in your PATH. +echo. +echo Please set the JAVA_HOME variable in your environment to match the +echo location of your Java installation. + +goto fail + +:findJavaFromJavaHome +set JAVA_HOME=%JAVA_HOME:"=% +set JAVA_EXE=%JAVA_HOME%/bin/java.exe + +if exist "%JAVA_EXE%" goto init + +echo. +echo ERROR: JAVA_HOME is set to an invalid directory: %JAVA_HOME% +echo. +echo Please set the JAVA_HOME variable in your environment to match the +echo location of your Java installation. + +goto fail + +:init +@rem Get command-line arguments, handling Windows variants + +if not "%OS%" == "Windows_NT" goto win9xME_args + +:win9xME_args +@rem Slurp the command line arguments. +set CMD_LINE_ARGS= +set _SKIP=2 + +:win9xME_args_slurp +if "x%~1" == "x" goto execute + +set CMD_LINE_ARGS=%* + +:execute +@rem Setup the command line + +set CLASSPATH=%APP_HOME%\gradle\wrapper\gradle-wrapper.jar + +@rem Execute Gradle +"%JAVA_EXE%" %DEFAULT_JVM_OPTS% %JAVA_OPTS% %GRADLE_OPTS% "-Dorg.gradle.appname=%APP_BASE_NAME%" -classpath "%CLASSPATH%" org.gradle.wrapper.GradleWrapperMain %CMD_LINE_ARGS% + +:end +@rem End local scope for the variables with windows NT shell +if "%ERRORLEVEL%"=="0" goto mainEnd + +:fail +rem Set variable GRADLE_EXIT_CONSOLE if you need the _script_ return code instead of +rem the _cmd.exe /c_ return code! +if not "" == "%GRADLE_EXIT_CONSOLE%" exit 1 +exit /b 1 + +:mainEnd +if "%OS%"=="Windows_NT" endlocal + +:omega diff --git a/settings.gradle.kts b/settings.gradle.kts new file mode 100644 index 0000000..cce9d6c --- /dev/null +++ b/settings.gradle.kts @@ -0,0 +1,15 @@ +/* + * Copyright 2018 dorkbox, llc + * + * Licensed 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. + */