diff --git a/.gitignore b/.gitignore
index a680191b..6d6a56f8 100644
--- a/.gitignore
+++ b/.gitignore
@@ -11,5 +11,3 @@ libs
out
.DS_Store
lib/kotlin-*
-build
-.history
diff --git a/README.md b/README.md
index d5d7cbe0..81d87855 100644
--- a/README.md
+++ b/README.md
@@ -1,6 +1,6 @@
# Kobalt
-[
](https://teamcity.jetbrains.com/project.html?projectId=OpenSourceProjects_Kobalt&tab=projectOverview)
+[
](https://teamcity.jetbrains.com/project.html?projectId=OpenSourceProjects_Kobalt&tab=projectOverview)
Kobalt is a universal build system.
@@ -8,7 +8,7 @@ Kobalt is a universal build system.
To build it:
```
-$ ./kobaltw assemble
+./kobaltw assemble
```
Please see [the web site](http://beust.com/kobalt/) for the full documentation.
diff --git a/build.gradle b/build.gradle
deleted file mode 100644
index 3f0053cc..00000000
--- a/build.gradle
+++ /dev/null
@@ -1,58 +0,0 @@
-allprojects {
- group = 'com.beust'
- version = '1.1.0'
-}
-
-subprojects {
- apply plugin: 'java'
- apply plugin: 'maven-publish'
-
- ext {
- bndlib = '3.5.0'
- findbugs = '3.0.2'
- groovy = '2.4.12'
- gson = '2.8.2'
- guice = '4.2.2'
- inject = '1'
- jaxb = '2.3.0'
- jcommander = '1.72'
- kotlin = '1.2.71'
- maven = '3.5.2'
- mavenResolver = '1.1.0'
- okhttp = '3.9.1'
- okio = '1.13.0'
- retrofit = '2.3.0'
- slf4j = '1.7.3'
- spark = '2.6.0'
- testng = '6.12'
-
- junit = '4.12'
- junitJupiter = '5.1.0'
- junitPlatform = '1.1.0'
- }
-
- repositories {
- mavenCentral()
- mavenLocal()
- jcenter()
- maven {
- url = 'https://dl.bintray.com/cbeust/maven'
- }
-
- maven {
- url = 'https://repo.maven.apache.org/maven2'
- }
- }
-
- sourceCompatibility = '1.7'
-
- task sourcesJar(type: Jar) {
- from sourceSets.main.allJava
- archiveClassifier = 'sources'
- }
-
- task javadocJar(type: Jar) {
- from javadoc
- archiveClassifier = 'javadoc'
- }
-}
diff --git a/gradle/wrapper/gradle-wrapper.jar b/gradle/wrapper/gradle-wrapper.jar
deleted file mode 100644
index 5c2d1cf0..00000000
Binary files a/gradle/wrapper/gradle-wrapper.jar and /dev/null differ
diff --git a/gradle/wrapper/gradle-wrapper.properties b/gradle/wrapper/gradle-wrapper.properties
deleted file mode 100644
index 838e6bc8..00000000
--- a/gradle/wrapper/gradle-wrapper.properties
+++ /dev/null
@@ -1,5 +0,0 @@
-distributionBase=GRADLE_USER_HOME
-distributionPath=wrapper/dists
-distributionUrl=https\://services.gradle.org/distributions/gradle-5.3-bin.zip
-zipStoreBase=GRADLE_USER_HOME
-zipStorePath=wrapper/dists
diff --git a/gradlew b/gradlew
deleted file mode 100755
index b0d6d0ab..00000000
--- a/gradlew
+++ /dev/null
@@ -1,188 +0,0 @@
-#!/usr/bin/env sh
-
-#
-# Copyright 2015 the original author or authors.
-#
-# 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.
-#
-
-##############################################################################
-##
-## 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" "-Xms64m"'
-
-# 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
deleted file mode 100644
index 9991c503..00000000
--- a/gradlew.bat
+++ /dev/null
@@ -1,100 +0,0 @@
-@rem
-@rem Copyright 2015 the original author or authors.
-@rem
-@rem Licensed under the Apache License, Version 2.0 (the "License");
-@rem you may not use this file except in compliance with the License.
-@rem You may obtain a copy of the License at
-@rem
-@rem http://www.apache.org/licenses/LICENSE-2.0
-@rem
-@rem Unless required by applicable law or agreed to in writing, software
-@rem distributed under the License is distributed on an "AS IS" BASIS,
-@rem WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
-@rem See the License for the specific language governing permissions and
-@rem limitations under the License.
-@rem
-
-@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" "-Xms64m"
-
-@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/kobalt/src/Build.kt b/kobalt/src/Build.kt
index 0d09844a..76c1a7af 100644
--- a/kobalt/src/Build.kt
+++ b/kobalt/src/Build.kt
@@ -21,29 +21,29 @@ import java.util.zip.ZipEntry
import java.util.zip.ZipOutputStream
val bs = buildScript {
- repos("https://dl.bintray.com/cbeust/maven")
+ repos("http://dl.bintray.com/cbeust/maven")
}
object Versions {
- val kotlin = "1.2.71"
- val okhttp = "3.9.1"
- val okio = "1.13.0"
- val retrofit = "2.3.0"
- val gson = "2.8.2"
- val guice = "4.2.2"
- val maven = "3.5.2"
- val mavenResolver = "1.1.0"
+ val okhttp = "3.2.0"
+ val okio = "1.6.0"
+ val retrofit = "2.1.0"
+ val gson = "2.6.2"
+ val maven = "3.3.9"
+ val mavenResolver = "1.0.3"
val slf4j = "1.7.3"
+ val kotlin = "1.1.1"
val aether = "1.0.2.v20150114"
- val testng = "6.12"
- val jcommander = "1.72"
+ val testng = "6.11"
// JUnit 5
val junit = "4.12"
- val junitPlatform = "1.1.0"
- val junitJupiter = "5.1.0"
+ val junitPlatform = "1.0.0-M4"
+ val junitJupiter = "5.0.0-M4"
+ val junitVintageVersion = "$junit.0-M4"
}
+
fun mavenResolver(vararg m: String)
= m.map { "org.apache.maven.resolver:maven-resolver-$it:${Versions.mavenResolver}" }
.toTypedArray()
@@ -79,7 +79,6 @@ val wrapper = project {
bintray {
publish = true
- sign = true
}
pom = createPom(name, "Wrapper for Kobalt")
@@ -92,42 +91,41 @@ val kobaltPluginApi = project {
version = readVersion()
directory = "modules/kobalt-plugin-api"
description = "A build system in Kotlin"
- url = "https://beust.com/kobalt"
+ url = "http://beust.com/kobalt"
pom = createPom(name, "A build system in Kotlin")
dependencies {
compile(
"org.jetbrains.kotlin:kotlin-stdlib:${Versions.kotlin}",
- "com.google.inject:guice:${Versions.guice}",
- "com.google.inject.extensions:guice-assistedinject:4.1.0",
+ "com.google.inject:guice:4.0",
+ "com.google.inject.extensions:guice-assistedinject:4.0",
"javax.inject:javax.inject:1",
- "com.google.guava:guava:27.0.1-jre",
+ "com.google.guava:guava:19.0",
"org.apache.maven:maven-model:${Versions.maven}",
- "io.reactivex:rxjava:1.3.3",
+ "io.reactivex:rxjava:1.1.5",
"com.squareup.okio:okio:${Versions.okio}",
"com.google.code.gson:gson:${Versions.gson}",
"com.squareup.okhttp3:okhttp:${Versions.okhttp}",
"com.squareup.retrofit2:retrofit:${Versions.retrofit}",
"com.squareup.retrofit2:converter-gson:${Versions.retrofit}",
- "com.beust:jcommander:${Versions.jcommander}",
- "org.eclipse.jgit:org.eclipse.jgit:4.9.0.201710071750-r",
+ "com.beust:jcommander:1.48",
+ "org.eclipse.jgit:org.eclipse.jgit:4.5.0.201609210915-r",
"org.slf4j:slf4j-simple:${Versions.slf4j}",
*mavenResolver("api", "spi", "util", "impl", "connector-basic", "transport-http", "transport-file"),
"org.apache.maven:maven-aether-provider:3.3.9",
"org.testng.testng-remote:testng-remote:1.3.2",
"org.testng:testng:${Versions.testng}",
+ "commons-io:commons-io:2.5",
"org.junit.platform:junit-platform-surefire-provider:${Versions.junitPlatform}",
"org.junit.platform:junit-platform-runner:${Versions.junitPlatform}",
"org.junit.platform:junit-platform-engine:${Versions.junitPlatform}",
"org.junit.platform:junit-platform-console:${Versions.junitPlatform}",
"org.junit.jupiter:junit-jupiter-engine:${Versions.junitJupiter}",
- "org.junit.vintage:junit-vintage-engine:${Versions.junitJupiter}",
- "org.apache.commons:commons-compress:1.15",
- "commons-io:commons-io:2.6",
+ "org.junit.vintage:junit-vintage-engine:${Versions.junitVintageVersion}",
- // Java 9
- "javax.xml.bind:jaxb-api:2.3.0"
+ "org.apache.commons:commons-compress:1.13",
+ "commons-io:commons-io:2.5"
)
exclude(*aether("impl", "spi", "util", "api"))
}
@@ -142,8 +140,12 @@ val kobaltPluginApi = project {
}
}
+// install {
+// libDir = "lib-test"
+// }
+
kotlinCompiler {
- args("nowarn")
+ args("-nowarn")
}
bintray {
@@ -164,30 +166,24 @@ val kobaltApp = project(kobaltPluginApi, wrapper) {
// Used by the main app
compile(
"org.jetbrains.kotlin:kotlin-stdlib:${Versions.kotlin}",
- "com.github.spullara.mustache.java:compiler:0.9.5",
+ "com.github.spullara.mustache.java:compiler:0.9.1",
"javax.inject:javax.inject:1",
- "com.google.inject:guice:${Versions.guice}",
- "com.google.inject.extensions:guice-assistedinject:${Versions.guice}",
- "com.beust:jcommander:${Versions.jcommander}",
+ "com.google.inject:guice:4.0",
+ "com.google.inject.extensions:guice-assistedinject:4.0",
+ "com.beust:jcommander:1.65",
"org.apache.maven:maven-model:${Versions.maven}",
- "com.google.code.findbugs:jsr305:3.0.2",
+ "com.google.code.findbugs:jsr305:3.0.1",
"com.google.code.gson:gson:${Versions.gson}",
"com.squareup.retrofit2:retrofit:${Versions.retrofit}",
"com.squareup.retrofit2:converter-gson:${Versions.retrofit}",
-// "com.squareup.okhttp3:okhttp-ws:3.4.2",
- "biz.aQute.bnd:biz.aQute.bndlib:3.5.0",
+ "com.squareup.okhttp3:okhttp-ws:${Versions.okhttp}",
+ "biz.aQute.bnd:bndlib:2.4.0",
*mavenResolver("spi"),
- "com.squareup.okhttp3:logging-interceptor:3.9.0",
+ "com.squareup.okhttp3:logging-interceptor:3.2.0",
- "com.sparkjava:spark-core:2.6.0",
- "org.codehaus.groovy:groovy:2.4.12",
-
- // Java 9
- "javax.xml.bind:jaxb-api:2.3.0",
- "com.sun.xml.bind:jaxb-impl:2.3.0",
- "com.sun.xml.bind:jaxb-core:2.3.0",
- "com.sun.activation:javax.activation:1.2.0"
+ "com.sparkjava:spark-core:2.5",
+ "org.codehaus.groovy:groovy:2.4.8"
// "org.eclipse.jetty:jetty-server:${Versions.jetty}",
// "org.eclipse.jetty:jetty-servlet:${Versions.jetty}",
@@ -203,7 +199,7 @@ val kobaltApp = project(kobaltPluginApi, wrapper) {
dependenciesTest {
compile("org.jetbrains.kotlin:kotlin-test:${Versions.kotlin}",
"org.testng:testng:${Versions.testng}",
- "org.assertj:assertj-core:3.8.0",
+ "org.assertj:assertj-core:3.4.1",
*mavenResolver("util")
)
}
@@ -237,7 +233,7 @@ val kobaltApp = project(kobaltPluginApi, wrapper) {
}
kotlinCompiler {
- args("nowarn")
+ args("-nowarn")
}
bintray {
@@ -309,13 +305,13 @@ fun taskCopyVersionForWrapper(project: Project) : TaskResult {
fun createPom(projectName: String, projectDescription: String) = Model().apply {
name = projectName
description = projectDescription
- url = "https://beust.com/kobalt"
+ url = "http://beust.com/kobalt"
licenses = listOf(License().apply {
name = "Apache-2.0"
- url = "https://www.apache.org/licenses/LICENSE-2.0"
+ url = "http://www.apache.org/licenses/LICENSE-2.0"
})
scm = Scm().apply {
- url = "https://github.com/cbeust/kobalt"
+ url = "http://github.com/cbeust/kobalt"
connection = "https://github.com/cbeust/kobalt.git"
developerConnection = "git@github.com:cbeust/kobalt.git"
}
@@ -323,4 +319,4 @@ fun createPom(projectName: String, projectDescription: String) = Model().apply {
name = "Cedric Beust"
email = "cedric@beust.com"
})
-}
+}
\ No newline at end of file
diff --git a/kobalt/wrapper/kobalt-wrapper.properties b/kobalt/wrapper/kobalt-wrapper.properties
index 0ca8045f..bd5e50a2 100644
--- a/kobalt/wrapper/kobalt-wrapper.properties
+++ b/kobalt/wrapper/kobalt-wrapper.properties
@@ -1 +1 @@
-kobalt.version=1.0.122
\ No newline at end of file
+kobalt.version=1.0.65
diff --git a/kobaltw-test b/kobaltw-test
deleted file mode 100755
index 2693c3aa..00000000
--- a/kobaltw-test
+++ /dev/null
@@ -1,8 +0,0 @@
-#!/usr/bin/env sh
-JAR=$(ls -1 -t kobaltBuild/libs/*.jar | grep -Ev "(sources|javadoc)" | head -1)
-TEMPDIR=$(mktemp -d)
-cp -pf "$JAR" "$TEMPDIR"
-TEMPJAR=$TEMPDIR/$(basename "$JAR")
-export KOBALT_JAR=$TEMPJAR
-java -jar "$TEMPJAR" "$@"
-rm -rf "$TEMPDIR"
\ No newline at end of file
diff --git a/modules/kobalt-plugin-api/build.gradle b/modules/kobalt-plugin-api/build.gradle
deleted file mode 100644
index 56085220..00000000
--- a/modules/kobalt-plugin-api/build.gradle
+++ /dev/null
@@ -1,85 +0,0 @@
-plugins {
- id 'org.jetbrains.kotlin.jvm' version '1.2.71'
- id 'com.github.johnrengelman.shadow' version '5.0.0'
-}
-
-dependencies {
- implementation "biz.aQute.bnd:biz.aQute.bndlib:$bndlib"
- implementation "com.google.code.findbugs:jsr305:$findbugs"
- implementation "com.sparkjava:spark-core:$spark"
- implementation "com.squareup.okhttp3:logging-interceptor:$okhttp"
- implementation 'commons-io:commons-io:2.6'
- implementation 'io.reactivex:rxjava:1.3.3'
- implementation "javax.inject:javax.inject:$inject"
- implementation "javax.xml.bind:jaxb-api:$jaxb"
- implementation 'org.apache.commons:commons-compress:1.15'
- implementation 'org.apache.maven:maven-aether-provider:3.3.9'
- implementation "org.apache.maven.resolver:maven-resolver-api:$mavenResolver"
- implementation "org.apache.maven.resolver:maven-resolver-connector-basic:$mavenResolver"
- implementation "org.apache.maven.resolver:maven-resolver-impl:$mavenResolver"
- implementation "org.apache.maven.resolver:maven-resolver-spi:$mavenResolver"
- implementation "org.apache.maven.resolver:maven-resolver-transport-file:$mavenResolver"
- implementation "org.apache.maven.resolver:maven-resolver-transport-http:$mavenResolver"
- implementation "org.apache.maven.resolver:maven-resolver-util:$mavenResolver"
- implementation "org.codehaus.groovy:groovy:$groovy"
- implementation 'org.eclipse.jgit:org.eclipse.jgit:4.9.0.201710071750-r'
- implementation "org.junit.jupiter:junit-jupiter-engine:$junitJupiter"
- implementation "org.junit.platform:junit-platform-console:$junitPlatform"
- implementation "org.junit.platform:junit-platform-engine:$junitPlatform"
- implementation "org.junit.platform:junit-platform-runner:$junitPlatform"
- implementation "org.junit.platform:junit-platform-surefire-provider:$junitPlatform"
- implementation "org.junit.vintage:junit-vintage-engine:$junitJupiter"
- implementation "org.slf4j:slf4j-simple:$slf4j"
- implementation "org.testng:testng:$testng"
- implementation 'org.testng.testng-remote:testng-remote:1.3.2'
- implementation "com.beust:jcommander:$jcommander"
- implementation "com.google.code.gson:gson:$gson"
- implementation "com.google.inject:guice:$guice"
- implementation "com.google.inject.extensions:guice-assistedinject:$guice"
- implementation "com.squareup.okio:okio:$okio"
- implementation "com.squareup.retrofit2:converter-gson:$retrofit"
- implementation "com.squareup.retrofit2:retrofit:$retrofit"
- implementation "org.apache.maven:maven-model:$maven"
- implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin"
-}
-
-shadowJar {
- classifier = null
-}
-
-test {
- useTestNG()
-}
-
-publishing {
- publications {
- shadow(MavenPublication) { publication ->
- project.shadow.component(publication)
- artifact sourcesJar
- artifact javadocJar
-
- pom {
- name = project.name
- description = 'A build system in Kotlin'
- url = 'https://beust.com/kobalt'
- licenses {
- license {
- name = 'Apache-2.0'
- url = 'https://www.apache.org/licenses/LICENSE-2.0'
- }
- }
- developers {
- developer {
- name = 'Cedric Beust'
- email = 'cedric@beust.com'
- }
- }
- scm {
- connection = 'scm:https://github.com/cbeust/kobalt.git'
- developerConnection = 'scm:git@github.com:cbeust/kobalt.git'
- url = 'https://github.com/cbeust/kobalt'
- }
- }
- }
- }
-}
diff --git a/modules/kobalt-plugin-api/pom.xml b/modules/kobalt-plugin-api/pom.xml
deleted file mode 100644
index f9026387..00000000
--- a/modules/kobalt-plugin-api/pom.xml
+++ /dev/null
@@ -1,279 +0,0 @@
-
- 4.0.0
-
- com.beust
- kobalt-pom
- 1.1.0
- ../..
-
-
- kobalt-plugin-api
- jar
- 1.1.0
-
-
-
- org.jetbrains.kotlin
- kotlin-stdlib
- ${kotlin.version}
-
-
- org.apache.maven
- maven-aether-provider
- 3.3.9
-
-
- org.eclipse.aether
- impl
-
-
- org.eclipse.aether
- spi
-
-
- org.eclipse.aether
- util
-
-
- org.eclipse.aether
- api
-
-
-
-
- org.apache.maven.resolver
- maven-resolver-api
- ${mavenresolver.version}
-
-
- org.apache.maven.resolver
- maven-resolver-spi
- ${mavenresolver.version}
-
-
- org.apache.maven.resolver
- maven-resolver-util
- ${mavenresolver.version}
-
-
- org.apache.maven.resolver
- maven-resolver-impl
- ${mavenresolver.version}
-
-
- org.apache.maven.resolver
- maven-resolver-connector-basic
- ${mavenresolver.version}
-
-
- org.apache.maven.resolver
- maven-resolver-transport-http
- ${mavenresolver.version}
-
-
- org.apache.maven.resolver
- maven-resolver-transport-file
- ${mavenresolver.version}
-
-
- io.reactivex
- rxjava
- 1.3.3
-
-
- com.squareup.okio
- okio
- ${okio.version}
-
-
- javax.inject
- javax.inject
- 1
- compile
-
-
- com.google.inject
- guice
- 4.2.2
-
-
- com.google.inject.extensions
- guice-assistedinject
- 4.2.2
-
-
- com.beust
- jcommander
- 1.72
-
-
- org.apache.maven
- maven-model
- 3.5.2
-
-
- com.google.code.findbugs
- jsr305
- 3.0.2
-
-
- com.google.code.gson
- gson
- 2.8.2
-
-
- com.squareup.retrofit2
- retrofit
- 2.3.0
-
-
- com.squareup.retrofit2
- converter-gson
- 2.3.0
-
-
- biz.aQute.bnd
- biz.aQute.bndlib
- 3.5.0
-
-
- com.squareup.okhttp3
- logging-interceptor
- ${okhttp3.version}
-
-
- com.sparkjava
- spark-core
- 2.6.0
-
-
- org.codehaus.groovy
- groovy
- 2.4.12
-
-
- org.apache.commons
- commons-compress
- 1.15
-
-
- commons-io
- commons-io
- 2.6
-
-
- org.junit.platform
- junit-platform-surefire-provider
- ${junit.version}
-
-
- org.junit.platform
- junit-platform-runner
- ${junit.version}
-
-
- org.junit.platform
- junit-platform-engine
- ${junit.version}
-
-
- org.junit.platform
- junit-platform-console
- ${junit.version}
-
-
- org.junit.jupiter
- junit-jupiter-engine
- ${junitJupiter.version}
-
-
- org.junit.vintage
- junit-vintage-engine
- ${junitJupiter.version}
-
-
- org.testng.testng-remote
- testng-remote
- 1.3.2
-
-
- org.testng
- testng
- ${testng.version}
-
-
- org.eclipse.jgit
- org.eclipse.jgit
- 4.9.0.201710071750-r
-
-
- org.slf4j
- slf4j-simple
- ${slf4j.version}
-
-
-
- javax.xml.bind
- jaxb-api
- 2.3.0
-
-
-
-
-
-
- org.jetbrains.kotlin
- kotlin-maven-plugin
- ${kotlin.version}
-
-
- compile
- compile
-
-
- ${project.basedir}/src/main/kotlin
-
-
-
-
- test-compile
- test-compile
-
-
- ${project.basedir}/src/test/kotlin
-
-
-
-
-
-
- org.apache.maven.plugins
- maven-compiler-plugin
- 3.5.1
-
-
-
- default-compile
- none
-
-
-
- default-testCompile
- none
-
-
- java-compile
- compile
- compile
-
-
- java-test-compile
- test-compile
- testCompile
-
-
-
-
-
-
\ No newline at end of file
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Args.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Args.kt
index 372f1ba1..b8cdc2fe 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Args.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Args.kt
@@ -61,9 +61,6 @@ class Args {
@Parameter(names = arrayOf("--noIncremental"), description = "Turn off incremental builds")
var noIncremental: Boolean = false
- @Parameter(names = arrayOf("--offline"), description = "Don't try to download dependencies even if there is no cached version")
- var offline: Boolean = false
-
@Parameter(names = arrayOf("--plugins"), description = "Comma-separated list of plug-in Maven id's")
var pluginIds: String? = null
@@ -104,8 +101,5 @@ class Args {
@Parameter(names = arrayOf("--update"), description = "Update to the latest version of Kobalt")
var update: Boolean = false
-
- @Parameter(names = arrayOf("--version"), description = "Display the current version of Kobalt")
- var version: Boolean = false
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/BuildScript.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/BuildScript.kt
index 4c35b9ed..48ecc0e3 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/BuildScript.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/BuildScript.kt
@@ -74,18 +74,8 @@ data class ProxyConfig(val host: String = "", val port: Int = 0, val type: Strin
fun toAetherProxy() = Proxy(type, host, port) // TODO make support for proxy auth
}
-data class HostConfig(var url: String = "", var name: String = HostConfig.createRepoName(url),
- var username: String? = null, var password: String? = null) {
-
- companion object {
- /**
- * For repos specified in the build file (repos()) that don't have an associated unique name,
- * create such a name from the URL. This is a requirement from Maven Resolver, and failing to do
- * this leads to very weird resolution errors.
- */
- private fun createRepoName(url: String) = url.replace("/", "_").replace("\\", "_").replace(":", "_")
- }
-
+data class HostConfig(var url: String = "", var name: String = url, var username: String? = null,
+ var password: String? = null) {
fun hasAuth() : Boolean {
return (! username.isNullOrBlank()) && (! password.isNullOrBlank())
}
@@ -116,7 +106,6 @@ fun buildFileClasspath(vararg deps: String) {
}
fun newBuildFileClasspath(vararg deps: String) {
- //FIXME newBuildFileClasspath called twice
deps.forEach { Kobalt.addBuildFileClasspath(it) }
}
@@ -126,7 +115,7 @@ fun authRepos(vararg repos : HostConfig) {
}
@Directive
-fun authRepo(init: HostConfig.() -> Unit) = HostConfig(name = "").apply { init() }
+fun authRepo(init: HostConfig.() -> Unit) = HostConfig().apply { init() }
@Directive
fun glob(g: String) : IFileSpec.GlobSpec = IFileSpec.GlobSpec(g)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Constants.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Constants.kt
index 8eb73c84..979c2ffe 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Constants.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Constants.kt
@@ -9,13 +9,13 @@ object Constants {
val BUILD_FILE_NAME = "Build.kt"
val BUILD_FILE_DIRECTORY = "kobalt/src"
val BUILD_FILE_PATH = KFiles.joinDir(BUILD_FILE_DIRECTORY, BUILD_FILE_NAME)
- val KOTLIN_COMPILER_VERSION = "1.2.70"
+ val KOTLIN_COMPILER_VERSION = "1.1.1"
internal val DEFAULT_REPOS = listOf(
// "https://maven-central.storage.googleapis.com/",
- HostConfig("https://repo1.maven.org/maven2/", "Maven"),
+ HostConfig("http://repo1.maven.org/maven2/", "Maven"),
HostConfig("https://jcenter.bintray.com/", "JCenter")
-// "https://repository.jetbrains.com/all/", // <-- contains snapshots
+// "http://repository.jetbrains.com/all/", // <-- contains snapshots
// snapshots
// "https://oss.sonatype.org/content/repositories/snapshots/"
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/JarGenerator.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/JarGenerator.kt
index 19bb52c6..61acb1e1 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/JarGenerator.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/JarGenerator.kt
@@ -3,7 +3,6 @@ package com.beust.kobalt
import com.beust.kobalt.api.KobaltContext
import com.beust.kobalt.api.Project
import com.beust.kobalt.archive.Archives
-import com.beust.kobalt.archive.MetaArchive
import com.beust.kobalt.archive.Zip
import com.beust.kobalt.maven.DependencyManager
import com.beust.kobalt.maven.aether.Scope
@@ -142,7 +141,7 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
val allFiles = includedFiles.flatMap { file ->
file.allFromFiles(project.directory).map { file.from(it.path) }
}
- val manifestFiles = allFiles.filter { it.path.contains(MetaArchive.MANIFEST_MF) }
+ val manifestFiles = allFiles.filter { it.path.contains("META-INF/MANIFEST.MF") }
return if (manifestFiles.any()) manifestFiles[0] else null
}
@@ -151,7 +150,7 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
context.logger.log(project.name, 2, "Including MANIFEST.MF file $manifestFile")
Manifest(FileInputStream(manifestFile))
} else {
- null
+ Manifest()
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Jvm.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Jvm.kt
index 14c55efd..598ca401 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Jvm.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Jvm.kt
@@ -67,7 +67,7 @@ open class Jvm constructor(
return toolsJar
}
if (javaHome!!.name.equals("jre", true)) {
- _javaHome = javaHome!!.parentFile
+ javaHome = javaHome!!.parentFile
toolsJar = File(javaHome, "lib/tools.jar")
if (toolsJar.exists()) {
return toolsJar
@@ -78,7 +78,7 @@ open class Jvm constructor(
val version = SystemProperties.Companion.javaVersion
if (javaHome!!.name.toRegex().matches("jre\\d+")
|| javaHome!!.name == "jre$version") {
- _javaHome = File(javaHome!!.parentFile, "jdk$version")
+ javaHome = File(javaHome!!.parentFile, "jdk$version")
toolsJar = File(javaHome, "lib/tools.jar")
if (toolsJar.exists()) {
return toolsJar
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/SystemProperties.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/SystemProperties.kt
index d5507497..b003aa9f 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/SystemProperties.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/SystemProperties.kt
@@ -2,16 +2,8 @@ package com.beust.kobalt
class SystemProperties {
companion object {
- val javaBase : String
- get() {
- val jh = System.getenv("JAVA_HOME")
- ?: System.getProperty("java.home")
- ?: throw IllegalArgumentException("JAVA_HOME not defined")
- val result =
- if (jh.toLowerCase().endsWith("jre")) jh.substring(0, jh.length - 4)
- else jh
- return result
- }
+ val javaBase = System.getProperty("java.home") ?:
+ (System.getenv("JAVA_HOME") ?: throw IllegalArgumentException("JAVA_HOME not defined"))
val javaVersion = System.getProperty("java.version")
val homeDir = System.getProperty("user.home")
val tmpDir = System.getProperty("java.io.tmpdir")
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Variant.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Variant.kt
index 13120fa0..d15327b1 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Variant.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Variant.kt
@@ -126,62 +126,61 @@ class Variant(val initialProductFlavor: ProductFlavorConfig? = null,
var generatedSourceDirectory: File? = null
- private fun findBuildTypeBuildConfig(project: Project, variant: Variant?) : BuildConfig? {
- val buildTypeName = variant?.buildType?.name
- return project.buildTypes[buildTypeName]?.buildConfig
- }
-
- private fun findProductFlavorBuildConfig(project: Project, variant: Variant?) : BuildConfig? {
- val buildTypeName = variant?.productFlavor?.name
- return project.productFlavors[buildTypeName]?.buildConfig
- }
+// private fun findBuildTypeBuildConfig(project: Project, variant: Variant?) : BuildConfig? {
+// val buildTypeName = variant?.buildType?.name
+// return project.buildTypes[buildTypeName]?.buildConfig
+// }
+//
+// private fun findProductFlavorBuildConfig(project: Project, variant: Variant?) : BuildConfig? {
+// val buildTypeName = variant?.productFlavor?.name
+// return project.productFlavors[buildTypeName]?.buildConfig
+// }
/**
* Return a list of the BuildConfigs found on the productFlavor{}, buildType{} and project{} (in that order).
*/
- private fun findBuildConfigs(project: Project, variant: Variant?) : List {
- val result = listOf(
- findBuildTypeBuildConfig(project, variant),
- findProductFlavorBuildConfig(project, variant),
- project.buildConfig)
- .filterNotNull()
-
- return result
- }
+// private fun findBuildConfigs(project: Project, variant: Variant?) : List {
+// val result = listOf(
+// findBuildTypeBuildConfig(project, variant),
+// findProductFlavorBuildConfig(project, variant),
+// project.buildConfig)
+// .filterNotNull()
+//
+// return result
+// }
/**
* Generate BuildConfig.java if requested. Also look up if any BuildConfig is defined on the current build type,
* product flavor or main project, and use them to generateAndSave any additional field (in that order to
* respect the priorities). Return the generated file if it was generated, null otherwise.
*/
- fun maybeGenerateBuildConfig(project: Project, context: KobaltContext) : File? {
- val buildConfigs = findBuildConfigs(project, this)
-
- if (buildConfigs.size > 0) {
- val pkg = project.packageName ?: project.group
- ?: throw KobaltException(
- "packageName needs to be defined on the project in order to generateAndSave BuildConfig")
-
- val contributor = ActorUtils.selectAffinityActor(project, context,
- context.pluginInfo.buildConfigContributors)
- if (contributor != null) {
- val code = contributor.generateBuildConfig(project, context, pkg, this, buildConfigs)
- val result = KFiles.makeDir(KFiles.generatedSourceDir(project, this, "buildConfig"))
- // Make sure the generatedSourceDirectory doesn't contain the project.directory since
- // that directory will be added when trying to find recursively all the sources in it
- generatedSourceDirectory = result.relativeTo(File(project.directory))
- val outputGeneratedSourceDirectory = File(result, pkg.replace('.', File.separatorChar))
- val outputDir = File(outputGeneratedSourceDirectory, "BuildConfig." + contributor.buildConfigSuffix)
- KFiles.saveFile(outputDir, code)
- context.logger.log(project.name, 2, "Generated ${outputDir.path}")
- return result
- } else {
- throw KobaltException("Couldn't find a contributor to generateAndSave BuildConfig")
- }
- } else {
- return null
- }
- }
+// fun maybeGenerateBuildConfig(project: Project, context: KobaltContext) : File? {
+// val buildConfigs = findBuildConfigs(project, this)
+//
+// if (buildConfigs.size > 0) {
+// val pkg = project.packageName ?: project.group
+// ?: throw KobaltException(
+// "packageName needs to be defined on the project in order to generateAndSave BuildConfig")
+//
+// val contributor = ActorUtils.selectAffinityActor(context.pluginInfo.buildConfigContributors, project)
+// if (contributor != null) {
+// val code = contributor.generateBuildConfig(project, context, pkg, this, buildConfigs)
+// val result = KFiles.makeDir(KFiles.generatedSourceDir(project, this, "buildConfig"))
+// // Make sure the generatedSourceDirectory doesn't contain the project.directory since
+// // that directory will be added when trying to find recursively all the sources in it
+// generatedSourceDirectory = result.relativeTo(File(project.directory))
+// val outputGeneratedSourceDirectory = File(result, pkg.replace('.', File.separatorChar))
+// val outputDir = File(outputGeneratedSourceDirectory, "BuildConfig." + contributor.buildConfigSuffix)
+// KFiles.saveFile(outputDir, code)
+// context.logger.log(project.name, 2, "Generated ${outputDir.path}")
+// return result
+// } else {
+// throw KobaltException("Couldn't find a contributor to generateAndSave BuildConfig")
+// }
+// } else {
+// return null
+// }
+// }
override fun toString() = toTask("")
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/CompilerActionInfo.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/CompilerActionInfo.kt
index e323e474..d2521255 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/CompilerActionInfo.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/CompilerActionInfo.kt
@@ -12,5 +12,4 @@ data class CompilerActionInfo(val directory: String?,
val outputDir: File,
val compilerArgs: List,
val friendPaths: List,
- val forceRecompile: Boolean,
- val compilerSeparateProcess: Boolean = false)
+ val forceRecompile: Boolean)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IBuildConfigContributor.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IBuildConfigContributor.kt
index ef9d3b4d..35553f74 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IBuildConfigContributor.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IBuildConfigContributor.kt
@@ -5,7 +5,7 @@ import com.beust.kobalt.Variant
/**
* Plug-ins that can generate a BuildConfig file.
*/
-interface IBuildConfigContributor : IProjectAffinity {
+interface IBuildConfigContributor : ISimpleAffinity {
fun generateBuildConfig(project: Project, context: KobaltContext, packageName: String, variant: Variant,
buildConfigs: List) : String
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IRunnerContributor.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IRunnerContributor.kt
index f8c28b52..5ab88cb0 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IRunnerContributor.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IRunnerContributor.kt
@@ -1,11 +1,10 @@
package com.beust.kobalt.api
import com.beust.kobalt.TaskResult
+import com.beust.kobalt.api.IClasspathDependency
/**
* Plugins that can run a project (task "run" or "test") should implement this interface.
- *
- * Currently not used.
*/
interface IRunnerContributor : IContributor, IProjectAffinity {
/**
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/ITaskContributor.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/ITaskContributor.kt
index c606d54f..714bd61b 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/ITaskContributor.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/ITaskContributor.kt
@@ -26,7 +26,6 @@ class DynamicTask(override val plugin: IPlugin, override val name: String, overr
return TaskResult2(taskResult.success, errorMessage = taskResult.errorMessage, value = this)
}
- override fun toString() =
- "[DynamicTask ${project.name}:$name dependsOn=$dependsOn reverseDependsOn=$reverseDependsOn]"
+ override fun toString() = "[DynamicTask $name dependsOn=$dependsOn reverseDependsOn=$reverseDependsOn]"
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/Kobalt.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/Kobalt.kt
index 7d37a0b8..f825efeb 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/Kobalt.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/Kobalt.kt
@@ -135,7 +135,6 @@ class Kobalt {
fun cleanUp() {
buildSourceDirs.clear()
- buildFileClasspath.clear()
}
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/TaskContributor.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/TaskContributor.kt
index 8c68be94..65eb529d 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/TaskContributor.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/TaskContributor.kt
@@ -44,25 +44,6 @@ class TaskContributor @Inject constructor(val incrementalManagerFactory: Increme
}
}
- fun addTask(plugin: IPlugin, project: Project, taskName: String, description: String,
- group: String = AnnotationDefault.GROUP,
- dependsOn: List = emptyList(),
- reverseDependsOn : List = emptyList(),
- runBefore : List = emptyList(),
- runAfter : List = emptyList(),
- alwaysRunAfter: List = emptyList(),
- runTask: (Project) -> TaskResult) {
- dynamicTasks.add(DynamicTask(plugin, taskName, description, group, project,
- dependsOn = dependsOn,
- reverseDependsOn = reverseDependsOn,
- runBefore = runBefore,
- runAfter = runAfter,
- alwaysRunAfter = alwaysRunAfter,
- closure = { p: Project ->
- runTask(project)
- }))
- }
-
fun addIncrementalVariantTasks(plugin: IPlugin, project: Project, context: KobaltContext, taskName: String,
group: String = AnnotationDefault.GROUP,
dependsOn: List = emptyList(),
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Archives.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Archives.kt
index 5334e09f..f8bd656c 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Archives.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Archives.kt
@@ -17,8 +17,7 @@ class Archives {
@ExportedProjectProperty(doc = "The name of the a jar file with a main() method", type = "String")
const val JAR_NAME_WITH_MAIN_CLASS = "jarNameWithMainClass"
- fun defaultArchiveName(project: Project) = project.name +
- if (project.version.isNullOrBlank()) "" else "-${project.version}"
+ fun defaultArchiveName(project: Project) = project.name + "-" + project.version
fun generateArchive(project: Project,
context: KobaltContext,
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/MetaArchive.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/MetaArchive.kt
index c217c83e..69918dd4 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/MetaArchive.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/MetaArchive.kt
@@ -9,6 +9,7 @@ import java.io.Closeable
import java.io.File
import java.io.FileInputStream
import java.io.FileOutputStream
+import java.nio.file.Files
import java.util.jar.Manifest
import org.apache.commons.compress.archivers.zip.ZipFile as ApacheZipFile
@@ -17,40 +18,15 @@ import org.apache.commons.compress.archivers.zip.ZipFile as ApacheZipFile
* Uses ZipArchiveOutputStream for fast inclusion of expanded jar files.
*/
class MetaArchive(outputFile: File, val manifest: Manifest?) : Closeable {
- companion object {
- const val MANIFEST_MF = "META-INF/MANIFEST.MF"
- }
-
- private val zos= ZipArchiveOutputStream(outputFile).apply {
+ private val zos = ZipArchiveOutputStream(outputFile).apply {
encoding = "UTF-8"
}
- init {
- // If no manifest was passed, create an empty one so it's the first one in the archive
- val m = manifest ?: Manifest()
- val manifestFile = File.createTempFile("kobalt", "tmpManifest")
- addEntry(ZipArchiveEntry("META-INF/"), null)
- if (manifest != null) {
- FileOutputStream(manifestFile).use { fos ->
- m.write(fos)
- }
- }
- val entry = zos.createArchiveEntry(manifestFile, MetaArchive.MANIFEST_MF)
- addEntry(entry, FileInputStream(manifestFile))
- }
-
-
fun addFile(f: File, entryFile: File, path: String?) {
- maybeCreateParentDirectories(f)
- addFile2(f, entryFile, path)
- }
-
- private fun addFile2(f: File, entryFile: File, path: String?) {
val file = f.normalize()
FileInputStream(file).use { inputStream ->
- val actualPath = KFiles.fixSlashes(if (path != null) path + entryFile.path else entryFile.path)
+ val actualPath = if (path != null) path + entryFile.path else entryFile.path
ZipArchiveEntry(actualPath).let { entry ->
- maybeCreateParentDirectories(File(actualPath))
maybeAddEntry(entry) {
addEntry(entry, inputStream)
}
@@ -58,30 +34,6 @@ class MetaArchive(outputFile: File, val manifest: Manifest?) : Closeable {
}
}
- private val createdDirs = hashSetOf()
-
- /**
- * For an entry a/b/c/File, an entry needs to be created for each individual directory:
- * a/
- * a/b/
- * a/b/c
- * a/b/c/File
- */
- private fun maybeCreateParentDirectories(file: File) {
- val toCreate = arrayListOf()
- var current = file.parentFile
- while (current != null && current.path != ".") {
- if (!createdDirs.contains(current.path)) {
- toCreate.add(0, KFiles.fixSlashes(current) + "/")
- createdDirs.add(current.path)
- }
- current = current.parentFile
- }
- toCreate.forEach { dir ->
- addEntry(ZipArchiveEntry(dir), null)
- }
- }
-
fun addArchive(jarFile: File) {
ApacheZipFile(jarFile).use { jar ->
val jarEntries = jar.entries
@@ -93,33 +45,40 @@ class MetaArchive(outputFile: File, val manifest: Manifest?) : Closeable {
}
}
+ private val DEFAULT_JAR_EXCLUDES =
+ Glob("META-INF/*.SF", "META-INF/*.DSA", "META-INF/*.RSA")
+ private val seen = hashSetOf()
- private fun okToAdd(name: String) : Boolean {
- val result = !KFiles.isExcluded(name,
- Glob("META-INF/*.SF", "META-INF/*.DSA", "META-INF/*.RSA", MANIFEST_MF))
-// if (name.startsWith("META-INF")) println((if (result) "ADDING" else "NOT ADDING") + " $name")
- return result
+ private fun okToAdd(name: String): Boolean = ! seen.contains(name)
+ && ! KFiles.isExcluded(name, DEFAULT_JAR_EXCLUDES)
+
+ override fun close() {
+ if (manifest != null) {
+ Files.createTempFile("aaa", "bbb").toFile().let { manifestFile ->
+ FileOutputStream(manifestFile).use { fos ->
+ manifest.write(fos)
+ }
+
+ val entry = zos.createArchiveEntry(manifestFile, "META-INF/MANIFEST.MF")
+ addEntry(entry, FileInputStream(manifestFile))
+ }
+ }
+ zos.close()
}
- override fun close() = zos.close()
-
- private fun addEntry(entry: ArchiveEntry, inputStream: FileInputStream?) {
+ private fun addEntry(entry: ArchiveEntry, inputStream: FileInputStream) {
zos.putArchiveEntry(entry)
- inputStream?.use { ins ->
+ inputStream.use { ins ->
ins.copyTo(zos, 50 * 1024)
}
zos.closeArchiveEntry()
}
- private val seen = hashSetOf()
-
private fun maybeAddEntry(entry: ArchiveEntry, action:() -> Unit) {
- entry.name.let { name ->
- if (!seen.contains(name) && okToAdd(name)) {
- action()
- }
- seen.add(name)
+ if (okToAdd(entry.name)) {
+ action()
}
+ seen.add(entry.name)
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/DocUrl.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/DocUrl.kt
index 93010294..8acab0ab 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/DocUrl.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/DocUrl.kt
@@ -2,7 +2,7 @@ package com.beust.kobalt.internal
class DocUrl {
companion object {
- private const val HOST = "https://beust.com/kobalt/"
+ private const val HOST = "http://beust.com/kobalt/"
private fun url(path: String) = HOST + path
val PUBLISH_PLUGIN_URL = url("plug-ins/index.html#publishing")
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/GenericRunner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/GenericRunner.kt
index 995dba53..01836be1 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/GenericRunner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/GenericRunner.kt
@@ -4,7 +4,6 @@ import com.beust.kobalt.*
import com.beust.kobalt.api.*
import com.beust.kobalt.misc.KFiles
import com.google.common.annotations.VisibleForTesting
-import com.google.inject.Inject
import java.io.File
import java.util.*
@@ -20,9 +19,6 @@ abstract class GenericTestRunner: ITestRunnerContributor {
open var shortMessage: String? = null
open var longMessage: String? = null
- @Inject
- private lateinit var jvm: Jvm
-
abstract fun args(project: Project, context: KobaltContext, classpath: List,
testConfig: TestConfig) : List
@@ -30,7 +26,7 @@ abstract class GenericTestRunner: ITestRunnerContributor {
open val extraClasspath: List = emptyList()
- open fun filterTestClasses(project: Project, context: KobaltContext, classes: List) : List = classes
+ open fun filterTestClasses(classes: List) : List = classes
override fun run(project: Project, context: KobaltContext, configName: String,
classpath: List) : TaskResult {
@@ -69,7 +65,7 @@ abstract class GenericTestRunner: ITestRunnerContributor {
// }
context.logger.log(project.name, 2, "Found ${result.size} test classes")
- return filterTestClasses(project, context, result.map { it.second })
+ return filterTestClasses(result.map { it.second })
}
/**
@@ -112,16 +108,15 @@ abstract class GenericTestRunner: ITestRunnerContributor {
configName: String) : TestResult {
var result = false
- context.logger.log(project.name, 1, "Running tests with $runnerName")
+ context.logger.log(project.name, 1, "Running tests with " + runnerName)
val testConfig = project.testConfigs.firstOrNull { it.name == configName }
- var errorCode = -1
if (testConfig != null) {
val args = args(project, context, classpath, testConfig)
if (args.size > 0) {
- val java = jvm.javaExecutable
+ val java = JavaInfo.create(File(SystemProperties.javaBase)).javaExecutable
val jvmArgs = calculateAllJvmArgs(project, context, testConfig, classpath,
Kobalt.INJECTOR.getInstance (PluginInfo::class.java))
val allArgs = arrayListOf().apply {
@@ -137,7 +132,12 @@ abstract class GenericTestRunner: ITestRunnerContributor {
context.logger.log(project.name, 2, "Running tests with classpath size ${classpath.size}")
context.logger.log(project.name, 2, "Launching " + allArgs.joinToString(" "))
val process = pb.start()
- errorCode = process.waitFor()
+ val errorCode = process.waitFor()
+ if (errorCode == 0) {
+ context.logger.log(project.name, 1, "All tests passed")
+ } else {
+ context.logger.log(project.name, 1, "Test failures")
+ }
result = result || errorCode == 0
} else {
context.logger.log(project.name, 1, " No tests to run")
@@ -148,13 +148,6 @@ abstract class GenericTestRunner: ITestRunnerContributor {
}
onFinish(project)
-
- if (errorCode == 0) {
- context.logger.log(project.name, 1, "All tests passed")
- } else {
- context.logger.log(project.name, 1, longMessage!!)
- }
-
return TestResult(result, shortMessage, longMessage)
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnit5Runner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnit5Runner.kt
index 2e9b534c..7dd72df7 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnit5Runner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnit5Runner.kt
@@ -35,8 +35,7 @@ class JUnit5Runner @Inject constructor(kFiles: KFiles) : GenericTestRunner() {
override fun affinity(project: Project, context: KobaltContext) : Int {
val result =
- if (project.testDependencies.any { it.id.contains("junit5") || it.id.contains("jupiter") })
- IAffinity.DEFAULT_POSITIVE_AFFINITY + 100
+ if (project.testDependencies.any { it.id.contains("jupiter") }) IAffinity.DEFAULT_POSITIVE_AFFINITY + 100
else 0
return result
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnitRunner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnitRunner.kt
index c5b36997..bfe6d800 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnitRunner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnitRunner.kt
@@ -4,10 +4,6 @@ import com.beust.kobalt.TestConfig
import com.beust.kobalt.api.IClasspathDependency
import com.beust.kobalt.api.KobaltContext
import com.beust.kobalt.api.Project
-import com.beust.kobalt.maven.DependencyManager
-import com.google.inject.Inject
-import java.lang.reflect.Modifier
-import java.net.URLClassLoader
open class JUnitRunner() : GenericTestRunner() {
@@ -18,15 +14,5 @@ open class JUnitRunner() : GenericTestRunner() {
override fun args(project: Project, context: KobaltContext, classpath: List,
testConfig: TestConfig) = findTestClasses(project, context, testConfig)
-
- @Inject
- lateinit var dependencyManager: DependencyManager
-
- override fun filterTestClasses(project: Project, context: KobaltContext, classes: List) : List {
- val deps = dependencyManager.testDependencies(project, context)
- val cl = URLClassLoader(deps.map { it.jarFile.get().toURI().toURL() }.toTypedArray())
- return classes.filter { !Modifier.isAbstract(cl.loadClass(it).modifiers) }
- }
-
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JvmCompiler.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JvmCompiler.kt
index e7773737..58f65776 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JvmCompiler.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JvmCompiler.kt
@@ -28,6 +28,7 @@ class JvmCompiler @Inject constructor(val dependencyManager: DependencyManager)
.distinct()
// Plugins that add flags to the compiler
+ val currentFlags = arrayListOf().apply { addAll(info.compilerArgs) }
val contributorFlags : List = if (project != null) flags else emptyList()
val addedFlags = contributorFlags + ArrayList(info.compilerArgs)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JvmCompilerPlugin.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JvmCompilerPlugin.kt
index 5e2a9354..43a9c6dd 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JvmCompilerPlugin.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JvmCompilerPlugin.kt
@@ -9,6 +9,7 @@ import com.beust.kobalt.api.annotation.ExportedProjectProperty
import com.beust.kobalt.api.annotation.IncrementalTask
import com.beust.kobalt.api.annotation.Task
import com.beust.kobalt.maven.DependencyManager
+import com.beust.kobalt.maven.LocalRepo
import com.beust.kobalt.maven.Md5
import com.beust.kobalt.maven.aether.Scope
import com.beust.kobalt.misc.KFiles
@@ -26,6 +27,7 @@ import javax.inject.Singleton
*/
@Singleton
open class JvmCompilerPlugin @Inject constructor(
+ open val localRepo: LocalRepo,
open val files: KFiles,
open val dependencyManager: DependencyManager,
open val executors: KobaltExecutors,
@@ -157,10 +159,6 @@ open class JvmCompilerPlugin @Inject constructor(
if (compilerContributors.isEmpty()) {
throw KobaltException("Couldn't find any compiler for project ${project.name}")
} else {
-
- // Generate BuildConfig if applicable
- context.variant.maybeGenerateBuildConfig(project, context)
-
val allCompilers = compilerContributors.flatMap { it.compilersFor(project, context)}.sorted()
/**
@@ -174,10 +172,7 @@ open class JvmCompilerPlugin @Inject constructor(
if (wi.value.sourceSuffixes.contains("java")) ij = wi.index
if (wi.value.sourceSuffixes.contains("kt")) ik = wi.index
}
-
- if (ik >= 0 && ij >= 0) {
- Collections.swap(result, ik, ij)
- }
+ Collections.swap(result, ik, ij)
return result
}
@@ -187,8 +182,8 @@ open class JvmCompilerPlugin @Inject constructor(
var done = false
// The directory where the classes get compiled
val buildDirectory =
- if (isTest) File(KFiles.joinDir(project.buildDirectory, KFiles.TEST_CLASSES_DIR))
- else File(KFiles.joinDir(project.classesDir(context)))
+ if (isTest) File(project.buildDirectory, KFiles.TEST_CLASSES_DIR)
+ else File(project.classesDir(context))
allCompilersSorted.doWhile({ ! done }) { compiler ->
val compilerResults = compilerUtils.invokeCompiler(project, context, compiler,
@@ -226,7 +221,7 @@ open class JvmCompilerPlugin @Inject constructor(
}
@Task(name = "doc", description = "Generate the documentation for the project", group = GROUP_DOCUMENTATION,
- runBefore = arrayOf("assemble"), runAfter = arrayOf("clean"))
+ runBefore = arrayOf("assemble"))
fun taskJavadoc(project: Project): TaskResult {
val docGenerator = ActorUtils.selectAffinityActor(project, context, context.pluginInfo.docContributors)
if (docGenerator != null) {
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KobaltPluginXml.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KobaltPluginXml.kt
index d8ca3555..59b3b894 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KobaltPluginXml.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KobaltPluginXml.kt
@@ -78,7 +78,7 @@ class PluginInfo(val xml: KobaltPluginXml, val pluginClassLoader: ClassLoader?,
val compilerInterceptors = arrayListOf()
val sourceDirectoriesInterceptors = arrayListOf()
val buildDirectoryInterceptors = arrayListOf()
-// val runnerContributors = arrayListOf()
+ val runnerContributors = arrayListOf()
val testRunnerContributors = arrayListOf()
val classpathInterceptors = arrayListOf()
val compilerContributors = arrayListOf()
@@ -197,7 +197,7 @@ class PluginInfo(val xml: KobaltPluginXml, val pluginClassLoader: ClassLoader?,
if (this is IPlugin) plugins.add(this)
if (this is IProjectContributor) projectContributors.add(this)
if (this is IRepoContributor) repoContributors.add(this)
-// if (this is IRunnerContributor) runnerContributors.add(this)
+ if (this is IRunnerContributor) runnerContributors.add(this)
if (this is ISourceDirectoryContributor) sourceDirContributors.add(this)
if (this is ISourceDirectoryInterceptor) sourceDirectoriesInterceptors.add(this)
if (this is ITaskContributor) taskContributors.add(this)
@@ -225,7 +225,7 @@ class PluginInfo(val xml: KobaltPluginXml, val pluginClassLoader: ClassLoader?,
listOf(projectContributors, classpathContributors, templateContributors,
repoContributors, compilerFlagContributors, compilerInterceptors,
sourceDirectoriesInterceptors, buildDirectoryInterceptors,
- /* runnerContributors, */ testRunnerContributors, classpathInterceptors,
+ runnerContributors, testRunnerContributors, classpathInterceptors,
compilerContributors, docContributors, sourceDirContributors,
testSourceDirContributors, buildConfigFieldContributors,
taskContributors, incrementalTaskContributors, assemblyContributors,
@@ -252,7 +252,7 @@ class PluginInfo(val xml: KobaltPluginXml, val pluginClassLoader: ClassLoader?,
compilerInterceptors.addAll(pluginInfo.compilerInterceptors)
sourceDirectoriesInterceptors.addAll(pluginInfo.sourceDirectoriesInterceptors)
buildDirectoryInterceptors.addAll(pluginInfo.buildDirectoryInterceptors)
-// runnerContributors.addAll(pluginInfo.runnerContributors)
+ runnerContributors.addAll(pluginInfo.runnerContributors)
testRunnerContributors.addAll(pluginInfo.testRunnerContributors)
classpathInterceptors.addAll(pluginInfo.classpathInterceptors)
compilerContributors.addAll(pluginInfo.compilerContributors)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KotlinJarFiles.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KotlinJarFiles.kt
index 123e8b76..3f29427a 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KotlinJarFiles.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KotlinJarFiles.kt
@@ -16,5 +16,6 @@ class KotlinJarFiles @Inject constructor(val dependencyManager: DependencyManage
}
val stdlib: File get() = getKotlinCompilerJar("stdlib")
+ val runtime: File get() = getKotlinCompilerJar("runtime")
val compiler: File get() = getKotlinCompilerJar("compiler-embeddable")
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KotlinTestRunner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KotlinTestRunner.kt
index 24e643d5..b78da1db 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KotlinTestRunner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KotlinTestRunner.kt
@@ -1,8 +1,5 @@
package com.beust.kobalt.internal
-import com.beust.kobalt.api.KobaltContext
-import com.beust.kobalt.api.Project
-
/**
* KotlinTestRunner triggers if it finds a dependency on io.kotlintest but other than that, it just
* uses the regular JUnitRunner.
@@ -15,7 +12,6 @@ class KotlinTestRunner : JUnitRunner() {
* KotlinTestRunner runs tests in the init{} initializer, so ignore all the extra
* classes generated by the Kotlin compiler.
*/
- override fun filterTestClasses(projet: Project, context: KobaltContext, classes: List)
- = classes.filter { !it.contains("$") }
+ override fun filterTestClasses(classes: List) = classes.filter { ! it.contains("$") }
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/TaskManager.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/TaskManager.kt
index 99aa7624..dd1c4c99 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/TaskManager.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/TaskManager.kt
@@ -320,9 +320,7 @@ class TaskWorker(val tasks: List, val dryRun: Boolean, val pluginInfo: Pl
val tr = if (dryRun) TaskResult() else it.call()
BaseProjectRunner.runBuildListenersForTask(it.project, context, name, start = false, success = tr.success)
success = success and tr.success
- tr.errorMessage?.let {
- errorMessages.add(it)
- }
+ if (tr.errorMessage != null) errorMessages.add(tr.errorMessage)
}
return TaskResult2(success, errorMessage = errorMessages.joinToString("\n"), value = tasks[0])
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/TestNgRunner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/TestNgRunner.kt
index f4ee96f8..345919c9 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/TestNgRunner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/TestNgRunner.kt
@@ -14,14 +14,11 @@ import org.testng.remote.strprotocol.MessageHelper
import org.testng.remote.strprotocol.MessageHub
import org.testng.remote.strprotocol.TestResultMessage
import org.w3c.dom.Attr
-import org.w3c.dom.NodeList
import org.xml.sax.InputSource
import java.io.File
import java.io.FileReader
import java.io.IOException
import javax.xml.parsers.DocumentBuilderFactory
-import javax.xml.xpath.XPathConstants
-import javax.xml.xpath.XPathFactory
class TestNgRunner : GenericTestRunner() {
@@ -30,10 +27,7 @@ class TestNgRunner : GenericTestRunner() {
override val annotationPackage = "org.testng"
override val runnerName = "TestNG"
- private fun defaultOutputWithoutProjectDir(project: Project)
- = KFiles.joinDir(project.buildDirectory, "test-output")
- private fun defaultOutput(project: Project)
- = KFiles.joinDir(project.directory, project.buildDirectory, "test-output")
+ fun defaultOutput(project: Project) = KFiles.joinDir(project.buildDirectory, "test-output")
override fun args(project: Project, context: KobaltContext, classpath: List,
testConfig: TestConfig) = arrayListOf().apply {
@@ -45,9 +39,7 @@ class TestNgRunner : GenericTestRunner() {
if (testConfig.testArgs.none { it == "-d" }) {
add("-d")
- // Don't include the project directory here since the generic runner will cd to that directory before
- // running the tests
- add(defaultOutputWithoutProjectDir(project))
+ add(defaultOutput(project))
}
if (testConfig.testArgs.size == 0) {
@@ -85,15 +77,6 @@ class TestNgRunner : GenericTestRunner() {
var failed = 0
var skipped = 0
var passed = 0
- val xp = XPathFactory.newInstance().newXPath()
- val testMethods = xp.compile("/testng-results/suite/test/class/test-method[@status='FAIL']")
- .evaluate(doc, XPathConstants.NODESET)
- as NodeList
- val failedMethods = arrayListOf()
- repeat(testMethods.length) {
- val tm = testMethods.item(it)
- failedMethods.add(tm.attributes.getNamedItem("signature").textContent)
- }
repeat(root.attributes.length) {
val attribute = root.attributes.item(it)
if (attribute is Attr) when (attribute.name) {
@@ -107,7 +90,6 @@ class TestNgRunner : GenericTestRunner() {
shortMessage = "$passed tests"
} else if (failed > 0) {
shortMessage = "$failed failed" + (if (skipped > 0) ", $skipped skipped" else "") + " tests"
- longMessage = "Failed tests:\n " + failedMethods.joinToString("\n ")
}
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Gpg.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Gpg.kt
index 60a4335c..27eeee83 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Gpg.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Gpg.kt
@@ -1,18 +1,16 @@
package com.beust.kobalt.maven
import com.beust.kobalt.OperatingSystem
-import com.beust.kobalt.misc.LocalProperties
import com.beust.kobalt.misc.error
import com.beust.kobalt.misc.kobaltLog
import com.beust.kobalt.misc.warn
-import com.google.inject.Inject
import com.google.inject.Singleton
import java.io.BufferedReader
import java.io.File
import java.io.InputStreamReader
@Singleton
-class Gpg @Inject constructor(val localProperties: LocalProperties) {
+class Gpg {
val COMMANDS = listOf("gpg", "gpg2")
fun findGpgCommand() : String? {
@@ -44,21 +42,6 @@ class Gpg @Inject constructor(val localProperties: LocalProperties) {
ascFile.delete()
val allArgs = arrayListOf()
allArgs.add(gpg)
-
- fun maybeAdd(prop: String, f: (String) -> Unit) = localProperties.getNoThrows(prop)?.let {
- f(it)
- }
-
- maybeAdd("gpg.password") {
- allArgs.addAll(listOf("--passphrase", it, "--batch", "--yes"))
- }
- maybeAdd("gpg.keyId") {
- allArgs.addAll(listOf("--local-user", it))
- }
- maybeAdd("gpg.secretKeyRingFile") {
- allArgs.addAll(listOf("--secret-keyring", "\"$it\""))
- }
-
allArgs.add("-ab")
allArgs.add(file.absolutePath)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Booter.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Booter.kt
index 02917929..e3b52dcd 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Booter.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Booter.kt
@@ -2,7 +2,6 @@ package com.beust.kobalt.maven.aether
import com.beust.kobalt.internal.KobaltSettings
import com.google.common.eventbus.EventBus
-import com.beust.kobalt.Args
import org.eclipse.aether.DefaultRepositorySystemSession
import org.eclipse.aether.RepositorySystem
import org.eclipse.aether.repository.LocalRepository
@@ -33,9 +32,8 @@ object Booter {
// }
fun newRepositorySystemSession(system: RepositorySystem, repo: File, settings: KobaltSettings,
- args: Args, eventBus: EventBus): DefaultRepositorySystemSession {
+ eventBus: EventBus): DefaultRepositorySystemSession {
val session = MavenRepositorySystemUtils.newSession(settings)
- session.isOffline = args.offline
val localRepo = LocalRepository(repo.absolutePath)
session.localRepositoryManager = system.newLocalRepositoryManager(session, localRepo)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/KobaltMavenResolver.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/KobaltMavenResolver.kt
index 7c8b705f..18ed6659 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/KobaltMavenResolver.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/KobaltMavenResolver.kt
@@ -52,7 +52,7 @@ class KobaltMavenResolver @Inject constructor(val settings: KobaltSettings,
}
fun error(s1: String, s2: String) {
throw KobaltException("Found \"$s1\" but not \"$s2\" in local.properties for ${Kurl.KEY}.$host",
- docUrl = "https://beust.com/kobalt/documentation/index.html#maven-repos-authenticated")
+ docUrl = "http://beust.com/kobalt/documentation/index.html#maven-repos-authenticated")
}
if (! hostInfo.username.isNullOrBlank() && hostInfo.password.isNullOrBlank()) {
error("username", "password")
@@ -76,13 +76,9 @@ class KobaltMavenResolver @Inject constructor(val settings: KobaltSettings,
val artifact = DefaultArtifact(mavenId)
val request = VersionRangeRequest(artifact, createRepos(repos), null)
val rr = system.resolveVersionRange(session, request)
- if (rr.highestVersion != null) {
- val newArtifact = DefaultArtifact(artifact.groupId, artifact.artifactId, artifact.classifier,
- artifact.extension, rr.highestVersion.toString())
- artifactToId(newArtifact)
- } else {
- throw KobaltException("Couldn't resolve $passedId")
- }
+ val newArtifact = DefaultArtifact(artifact.groupId, artifact.artifactId, artifact.classifier,
+ artifact.extension, rr.highestVersion.toString())
+ artifactToId(newArtifact)
} else {
passedId
}
@@ -141,7 +137,7 @@ class KobaltMavenResolver @Inject constructor(val settings: KobaltSettings,
fun create(id: String, optional: Boolean) = AetherDependency(DefaultArtifact(id), optional, args)
private val system = Booter.newRepositorySystem()
- private val session = Booter.newRepositorySystemSession(system, localRepo.localRepo, settings, args, eventBus)
+ private val session = Booter.newRepositorySystemSession(system, localRepo.localRepo, settings, eventBus)
private fun createRepo(hostConfig: HostConfig) : RemoteRepository {
val builder = RemoteRepository.Builder(hostConfig.name, "default", hostConfig.url)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/Git.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/Git.kt
index cf6b5885..f8892390 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/Git.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/Git.kt
@@ -6,11 +6,10 @@ import com.google.inject.Inject
import java.io.File
class Git @Inject constructor() {
- fun maybeTagRelease(project: Project, uploadResult: TaskResult, enabled: Boolean, annotated: Boolean,
- push: Boolean, tag: String, message: String) : TaskResult {
+ fun maybeTagRelease(project: Project, uploadResult: TaskResult, enabled: Boolean, annotated: Boolean, tag: String, message: String) : TaskResult {
val result =
if (uploadResult.success && enabled) {
- val tagSuccess = tagRelease(project, annotated, push, tag, message)
+ val tagSuccess = tagRelease(project, annotated, tag, message)
if (! tagSuccess) {
TaskResult(false, errorMessage = "Couldn't tag the project")
} else {
@@ -22,7 +21,7 @@ class Git @Inject constructor() {
return result
}
- private fun tagRelease(project: Project, annotated: Boolean, push: Boolean, tag: String, message: String) : Boolean {
+ private fun tagRelease(project: Project, annotated: Boolean, tag: String, message: String) : Boolean {
val version = if (tag.isNullOrBlank()) project.version else tag
val success = try {
log(2, "Tagging this release as \"$version\"")
@@ -38,9 +37,7 @@ class Git @Inject constructor() {
} else {
git.tag().setName(version).setMessage(message).call()
}
- if (push) {
- git.push().setPushTags().call()
- }
+ git.push().setPushTags().call()
true
} catch(ex: Exception) {
warn("Couldn't create tag ${version}: ${ex.message}", ex)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/GithubApi2.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/GithubApi2.kt
index b33286e0..9f89a01d 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/GithubApi2.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/GithubApi2.kt
@@ -86,12 +86,12 @@ class GithubApi2 @Inject constructor(
.execute()
val code = response.code()
if (code != Http.CREATED) {
- val error = Gson().fromJson(response.errorBody()?.string(), RetrofitError::class.java)
+ val error = Gson().fromJson(response.errorBody().string(), RetrofitError::class.java)
throw KobaltException("Couldn't upload release, ${error.message}: " + error.errors[0].code)
} else {
val body = response.body()
- uploadAsset(accessToken, body?.uploadUrl!!, Http.TypedFile("application/zip", zipFile), tagName)
+ uploadAsset(accessToken, body.uploadUrl!!, Http.TypedFile("application/zip", zipFile), tagName)
.toBlocking()
.forEach { action ->
kobaltLog(1, "\n${zipFile.name} successfully uploaded")
@@ -120,8 +120,8 @@ class GithubApi2 @Inject constructor(
Duration.between(VersionCheckTimestampFile.timestamp, Instant.now())) {
kobaltLog(2, "Skipping GitHub latest release check, too soon.")
} else {
- val username = localProperties.getNoThrows(PROPERTY_USERNAME)
- val accessToken = localProperties.getNoThrows(PROPERTY_ACCESS_TOKEN)
+ val username = localProperties.getNoThrows(PROPERTY_USERNAME, DOC_URL)
+ val accessToken = localProperties.getNoThrows(PROPERTY_ACCESS_TOKEN, DOC_URL)
try {
val req =
if (username != null && accessToken != null) {
@@ -138,8 +138,8 @@ class GithubApi2 @Inject constructor(
val releases = ex.body()
if (releases != null) {
releases.firstOrNull()?.let {
- result = try {
- listOf(it.name, it.tagName).filterNotNull().first { !it.isBlank() }
+ try {
+ result = listOf(it.name, it.tagName).filterNotNull().first { !it.isBlank() }
} catch(ex: NoSuchElementException) {
throw KobaltException("Couldn't find the latest release")
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/JarUtils.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/JarUtils.kt
index ba83b0a6..5d4aa8cd 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/JarUtils.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/JarUtils.kt
@@ -55,6 +55,7 @@ class JarUtils {
kobaltLog(2, " Writing contents of jar file $foundFile")
metaArchive.addArchive(foundFile)
} else {
+ val fp = foundFile.path
val toPath = File(file.to).normalize().path
val finalPath = if (toPath.isEmpty()) null else (toPath + "/")
metaArchive.addFile(File(directory, fromFile.path), foundFile, finalPath)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KFiles.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KFiles.kt
index fcf5b86a..15c2a15d 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KFiles.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KFiles.kt
@@ -10,9 +10,7 @@ import java.nio.file.Files
import java.nio.file.Path
import java.nio.file.Paths
import java.nio.file.StandardCopyOption
-import java.util.*
import java.util.jar.JarInputStream
-import java.util.regex.Pattern
class KFiles {
@@ -22,20 +20,6 @@ class KFiles {
*/
val kobaltJar : List
get() {
- val PATTERN = Pattern.compile("kobalt-([-.0-9]+)")
-
- fun latestInstalledVersion() : StringVersion {
- val versions = File(distributionsDir).listFiles().map { it.name }.map {
- val matcher = PATTERN.matcher(it)
- val result =
- if (matcher.matches()) matcher.group(1)
- else null
- result
- }.filterNotNull().map(::StringVersion)
- Collections.sort(versions, reverseOrder())
- return versions[0]
- }
-
val envJar = System.getenv("KOBALT_JAR")
if (envJar != null) {
debug("Using kobalt jar $envJar")
@@ -47,21 +31,19 @@ class KFiles {
if (jarFile.exists()) {
return listOf(jarFile.absolutePath)
} else {
- // In development mode, keep your kobalt.properties version to a nonexistent version
+ // In development mode, keep your kobalt.properties version one above kobalt-wrapper.properties:
// kobalt.properties: kobalt.version=0.828
// kobalt-wrapper.properties: kobalt.version=0.827
// When Kobalt can't find the newest jar file, it will instead use the classes produced by IDEA
// in the directories specified here:
- val previousVersion = latestInstalledVersion().version
+ val leftSuffix = Kobalt.version.substring(0, Kobalt.version.lastIndexOf(".") + 1)
+ val previousVersion = leftSuffix +
+ (Kobalt.version.split(".").let { it[it.size - 1] }.toInt() - 1).toString()
val previousJar = joinDir(distributionsDir, "kobalt-" + previousVersion,
"kobalt/wrapper/kobalt-$previousVersion.jar")
- latestInstalledVersion()
val result = listOf("", "modules/kobalt-plugin-api", "modules/wrapper").map {
- File(homeDir(KFiles.joinDir("kotlin", "kobalt", it, "kobaltBuild", "classes"))) //kobalt build dirs
- .absolutePath
- } + listOf("modules/kobalt", "modules/kobalt-plugin-api", "modules/wrapper").map {
- File(homeDir(KFiles.joinDir("kotlin", "kobalt", it, "target", "classes"))) //maven build dirs
- .absolutePath
+ File(homeDir(KFiles.joinDir("kotlin", "kobalt", it, "kobaltBuild", "classes")))
+ .absolutePath
} + listOf(previousJar)
debug("Couldn't find ${jarFile.absolutePath}, using\n " + result.joinToString(" "))
return result.filter { File(it).exists() }
@@ -137,7 +119,7 @@ class KFiles {
fun joinFileAndMakeDir(vararg ts: String) = joinDir(joinAndMakeDir(ts.slice(0..ts.size - 2)), ts[ts.size - 1])
fun fixSlashes(f: File) = f.normalize().path.replace('\\', '/')
- fun fixSlashes(s: String) = s.replace('\\', '/')
+ fun fixSlashes(s: String) = fixSlashes(File(s))
fun makeDir(dir: String, s: String? = null) =
(if (s != null) File(dir, s) else File(dir)).apply { mkdirs() }
@@ -245,18 +227,22 @@ class KFiles {
private fun isWindows() = System.getProperty("os.name").contains("Windows")
fun copy(from: Path?, to: Path?, option: StandardCopyOption = StandardCopyOption.REPLACE_EXISTING) {
- try {
- if (from != null && to != null) {
- if (!Files.exists(to) || Md5.toMd5(from.toFile()) != Md5.toMd5(to.toFile())) {
- kobaltLog(3, "Copy from $from to $to")
- Files.copy(from, to, option)
- } else {
- kobaltLog(3, " Not copying, indentical files: $from $to")
+ if (isWindows() && to!!.toFile().exists()) {
+ kobaltLog(2, "Windows detected, not overwriting $to")
+ } else {
+ try {
+ if (from != null && to != null) {
+ if (!Files.exists(to) || Md5.toMd5(from.toFile()) != Md5.toMd5(to.toFile())) {
+ kobaltLog(3, "Copy from $from to $to")
+ Files.copy(from, to, option)
+ } else {
+ kobaltLog(3, " Not copying, indentical files: $from $to")
+ }
}
+ } catch(ex: IOException) {
+ // Windows is anal about this
+ kobaltLog(1, "Couldn't copy $from to $to: ${ex.message}")
}
- } catch(ex: IOException) {
- // Windows is anal about this
- kobaltLog(1, "Couldn't copy $from to $to: ${ex.message}")
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KobaltLogger.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KobaltLogger.kt
index e2bd89de..1d235a44 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KobaltLogger.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KobaltLogger.kt
@@ -1,9 +1,6 @@
package com.beust.kobalt.misc
-import com.beust.kobalt.Args
-import com.beust.kobalt.AsciiArt
-import com.beust.kobalt.Constants
-import com.beust.kobalt.KobaltException
+import com.beust.kobalt.*
import com.beust.kobalt.api.Kobalt
import com.beust.kobalt.maven.aether.Exceptions
import java.lang.Exception
@@ -51,7 +48,7 @@ fun Any.error(text: CharSequence, e: Throwable? = null) {
object KobaltLogger {
var LOG_LEVEL: Int = 1
-
+
val isQuiet: Boolean get() = (LOG_LEVEL == Constants.LOG_QUIET_LEVEL)
val logger: Logger get() =
@@ -60,14 +57,6 @@ object KobaltLogger {
} else {
Logger(false)
}
-
- fun setLogLevel(args: Args) {
- LOG_LEVEL = when {
- args.log < Constants.LOG_QUIET_LEVEL -> Constants.LOG_DEFAULT_LEVEL
- args.log > Constants.LOG_MAX_LEVEL -> Constants.LOG_MAX_LEVEL
- else -> args.log
- }
- }
}
class Logger(val dev: Boolean) {
@@ -86,8 +75,7 @@ class Logger(val dev: Boolean) {
fun error(tag: String, message: CharSequence, e: Throwable? = null) {
val docUrl = if (e is KobaltException && e.docUrl != null) e.docUrl else null
- val text =
- if (message.isNotBlank()) message
+ val text = if (! message.isBlank()) message
else if (e != null && (! e.message.isNullOrBlank())) e.message
else { e?.toString() }
val shortMessage = "***** E $text " + if (docUrl != null) " Documentation: $docUrl" else ""
@@ -100,10 +88,7 @@ class Logger(val dev: Boolean) {
}
fun warn(tag: String, message: CharSequence, e: Throwable? = null) {
- val fullMessage = "***** WARNING " +
- if (message.isNotBlank()) message
- else if (e != null && (!e.message.isNullOrBlank())) e.message
- else e?.toString()
+ val fullMessage = "***** WARNING " + (e?.message ?: message)
println(AsciiArt.Companion.warnColor(getPattern("W", fullMessage, fullMessage, tag)))
if (KobaltLogger.LOG_LEVEL > 1 && e != null) {
Exceptions.printStackTrace(e)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KobaltWrapperProperties.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KobaltWrapperProperties.kt
index a7b5177d..06d01e7b 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KobaltWrapperProperties.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/KobaltWrapperProperties.kt
@@ -24,7 +24,7 @@ class KobaltWrapperProperties @Inject constructor() {
}
private fun defaultUrlFor(version: String) =
- "https://beust.com/kobalt/kobalt-$version.zip"
+ "http://beust.com/kobalt/kobalt-$version.zip"
private val file: File
get() = File("$WRAPPER_DIR/$KOBALT_WRAPPER_PROPERTIES")
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/LocalProperties.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/LocalProperties.kt
index 2cf0775e..4fe16a5c 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/LocalProperties.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/LocalProperties.kt
@@ -6,9 +6,6 @@ import java.nio.file.Files
import java.nio.file.Paths
import java.util.*
-/**
- * Encapsulate read access to local.properties.
- */
@Singleton
class LocalProperties {
val localProperties: Properties by lazy {
@@ -25,11 +22,11 @@ class LocalProperties {
result
}
- fun getNoThrows(name: String): String? = localProperties.getProperty(name)
+ fun getNoThrows(name: String, docUrl: String? = null) = localProperties.getProperty(name)
fun get(name: String, docUrl: String? = null) : String {
- val result = getNoThrows(name)
+ val result = getNoThrows(name, docUrl)
?: throw KobaltException("Couldn't find $name in local.properties", docUrl = docUrl)
- return result
+ return result as String
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/NewRunCommand.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/NewRunCommand.kt
index e105133b..67b666a6 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/NewRunCommand.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/NewRunCommand.kt
@@ -19,7 +19,6 @@ class RunCommandInfo {
*/
var useErrorStreamAsErrorIndicator : Boolean = true
var useInputStreamAsErrorIndicator : Boolean = false
- var ignoreExitValue : Boolean = false
var errorCallback: Function1, Unit> = NewRunCommand.DEFAULT_ERROR
var successCallback: Function1, Unit> = NewRunCommand.DEFAULT_SUCCESS
@@ -79,31 +78,19 @@ open class NewRunCommand(val info: RunCommandInfo) {
val process = pb.start()
// Run the command and collect the return code and streams
- val processFinished = process.waitFor(120, TimeUnit.SECONDS)
-
- if (!processFinished)
- kobaltError("process timed out!")
-
- val input =
- if (process.inputStream.available() > 0) fromStream(process.inputStream)
- else listOf()
- val error =
- if (process.errorStream.available() > 0) fromStream(process.errorStream)
- else listOf()
-
- kobaltLog(3, "info contains errors: " + (info.containsErrors != null))
+ val returnCode = process.waitFor(30, TimeUnit.SECONDS)
+ val input = if (process.inputStream.available() > 0) fromStream(process.inputStream)
+ else listOf()
+ val error = if (process.errorStream.available() > 0) fromStream(process.errorStream)
+ else listOf()
// Check to see if the command succeeded
val isSuccess =
if (info.containsErrors != null) ! info.containsErrors!!(error)
- else isSuccess(if (info.ignoreExitValue) true else processFinished, input, error)
+ else isSuccess(returnCode, input, error)
if (isSuccess) {
- if (!info.useErrorStreamAsErrorIndicator) {
- info.successCallback(error + input)
- } else {
- info.successCallback(input)
- }
+ info.successCallback(input)
} else {
info.errorCallback(error + input)
}
@@ -116,12 +103,12 @@ open class NewRunCommand(val info: RunCommandInfo) {
* have various ways to signal errors.
*/
open protected fun isSuccess(isSuccess: Boolean, input: List, error: List) : Boolean {
- var hasErrors: Boolean = ! isSuccess
+ var hasErrors = ! isSuccess
if (info.useErrorStreamAsErrorIndicator && ! hasErrors) {
- hasErrors = hasErrors || error.isNotEmpty()
+ hasErrors = hasErrors || error.size > 0
}
if (info.useInputStreamAsErrorIndicator && ! hasErrors) {
- hasErrors = hasErrors || input.isNotEmpty()
+ hasErrors = hasErrors || input.size > 0
}
return ! hasErrors
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/StringVersion.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/StringVersion.kt
index b421e558..fc620554 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/StringVersion.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/StringVersion.kt
@@ -29,12 +29,8 @@ class StringVersion(val version: String) : Comparable {
if (v1 < v2) return -1
else if (v1 > v2) return 1
} catch(ex: NumberFormatException) {
- if (version == other.toString()) {
- return 0
- } else {
- log(2, "Couldn't parse version $version or $other")
- return -1
- }
+ warn("Couldn't parse version $version or $other")
+ return -1
}
}
return 0
diff --git a/modules/kobalt/build.gradle b/modules/kobalt/build.gradle
deleted file mode 100644
index 57e009c7..00000000
--- a/modules/kobalt/build.gradle
+++ /dev/null
@@ -1,79 +0,0 @@
-plugins {
- id 'org.jetbrains.kotlin.jvm' version '1.2.71'
- id 'com.github.johnrengelman.shadow' version '5.0.0'
-}
-
-dependencies {
- implementation project(':wrapper')
- implementation project(':kobalt-plugin-api')
- implementation "biz.aQute.bnd:biz.aQute.bndlib:$bndlib"
- implementation 'com.github.spullara.mustache.java:compiler:0.9.5'
- implementation "com.google.code.findbugs:jsr305:$findbugs"
- implementation "com.sparkjava:spark-core:$spark"
- implementation "com.squareup.okhttp3:logging-interceptor:$okhttp"
- implementation 'com.sun.activation:javax.activation:1.2.0'
- implementation "com.sun.xml.bind:jaxb-core:$jaxb"
- implementation "com.sun.xml.bind:jaxb-impl:$jaxb"
- implementation "javax.inject:javax.inject:$inject"
- implementation "javax.xml.bind:jaxb-api:$jaxb"
- implementation "org.apache.maven.resolver:maven-resolver-spi:$mavenResolver"
- implementation "org.codehaus.groovy:groovy:$groovy"
- implementation "com.beust:jcommander:$jcommander"
- implementation "com.google.code.gson:gson:$gson"
- implementation "com.google.inject:guice:$guice"
- implementation "com.google.inject.extensions:guice-assistedinject:$guice"
- implementation "com.squareup.retrofit2:converter-gson:$retrofit"
- implementation "com.squareup.retrofit2:retrofit:$retrofit"
- implementation "org.apache.maven:maven-model:$maven"
- implementation "org.jetbrains.kotlin:kotlin-compiler-embeddable:$kotlin"
- implementation "org.jetbrains.kotlin:kotlin-stdlib:$kotlin"
- testImplementation 'org.assertj:assertj-core:3.8.0'
- testImplementation "org.jetbrains.kotlin:kotlin-test:$kotlin"
- testImplementation "org.testng:testng:$testng"
-}
-
-sourceSets {
- main.kotlin.srcDirs += "${rootProject.projectDir}../../src/main/kotlin"
- test.kotlin.srcDirs += "${rootProject.projectDir}../../src/test/kotlin"
-}
-
-shadowJar {
- classifier = null
-}
-
-test {
- useTestNG()
-}
-
-publishing {
- publications {
- shadow(MavenPublication) { publication ->
- project.shadow.component(publication)
- artifact sourcesJar
- artifact javadocJar
-
- pom {
- name = project.name
- description = 'A build system in Kotlin'
- url = 'https://beust.com/kobalt'
- licenses {
- license {
- name = 'Apache-2.0'
- url = 'https://www.apache.org/licenses/LICENSE-2.0'
- }
- }
- developers {
- developer {
- name = 'Cedric Beust'
- email = 'cedric@beust.com'
- }
- }
- scm {
- connection = 'scm:https://github.com/cbeust/kobalt.git'
- developerConnection = 'scm:git@github.com:cbeust/kobalt.git'
- url = 'https://github.com/cbeust/kobalt'
- }
- }
- }
- }
-}
diff --git a/modules/kobalt/pom.xml b/modules/kobalt/pom.xml
deleted file mode 100644
index 44dc799c..00000000
--- a/modules/kobalt/pom.xml
+++ /dev/null
@@ -1,231 +0,0 @@
-
- 4.0.0
-
- com.beust
- kobalt-pom
- 1.1.0
- ../..
-
-
- kobalt
- jar
- 1.1.0
-
-
-
- com.beust
- kobalt-plugin-api
- 1.1.0
-
-
- com.beust
- wrapper
- 1.1.0
-
-
- org.jetbrains.kotlin
- kotlin-compiler-embeddable
- ${kotlin.version}
-
-
- org.jetbrains.kotlin
- kotlin-stdlib
- ${kotlin.version}
-
-
- com.github.spullara.mustache.java
- compiler
- 0.9.5
- compile
-
-
- javax.inject
- javax.inject
- 1
- compile
-
-
- com.google.inject
- guice
- 4.2.2
-
-
- com.google.inject.extensions
- guice-assistedinject
- 4.2.2
-
-
- com.beust
- jcommander
- 1.72
-
-
- org.apache.maven
- maven-model
- 3.5.2
-
-
- com.google.code.findbugs
- jsr305
- 3.0.2
-
-
- com.google.code.gson
- gson
- 2.8.2
-
-
- com.squareup.retrofit2
- retrofit
- 2.3.0
-
-
- com.squareup.retrofit2
- converter-gson
- 2.3.0
-
-
- biz.aQute.bnd
- biz.aQute.bndlib
- 3.5.0
-
-
- com.squareup.okhttp3
- logging-interceptor
- ${okhttp3.version}
-
-
- com.sparkjava
- spark-core
- 2.6.0
-
-
- org.codehaus.groovy
- groovy
- 2.4.12
-
-
- org.apache.maven.resolver
- maven-resolver-spi
- ${mavenresolver.version}
-
-
-
- javax.xml.bind
- jaxb-api
- 2.3.0
-
-
- com.sun.xml.bind
- jaxb-impl
- 2.3.0
-
-
- com.sun.xml.bind
- jaxb-core
- 2.3.0
-
-
- com.sun.activation
- javax.activation
- 1.2.0
-
-
-
- org.assertj
- assertj-core
- 3.8.0
- test
-
-
- org.jetbrains.kotlin
- kotlin-test
- ${kotlin.version}
- test
-
-
- org.testng
- testng
- ${testng.version}
- test
-
-
-
-
-
-
- org.jetbrains.kotlin
- kotlin-maven-plugin
- ${kotlin.version}
-
-
- compile
- compile
-
-
- ${project.basedir}../../src/main/kotlin
-
-
-
-
- test-compile
- test-compile
-
-
- ${project.basedir}../../src/test/kotlin
-
-
-
-
-
-
- org.apache.maven.plugins
- maven-compiler-plugin
- 3.5.1
-
-
-
- default-compile
- none
-
-
-
- default-testCompile
- none
-
-
- java-compile
- compile
- compile
-
-
- java-test-compile
- test-compile
- testCompile
-
-
-
-
- org.apache.maven.plugins
- maven-shade-plugin
- 3.2.1
-
-
-
- com.beust.kobalt.MainKt
-
-
-
-
-
- package
-
- shade
-
-
-
-
-
-
-
\ No newline at end of file
diff --git a/modules/wrapper/build.gradle b/modules/wrapper/build.gradle
deleted file mode 100644
index c0b5dafe..00000000
--- a/modules/wrapper/build.gradle
+++ /dev/null
@@ -1,38 +0,0 @@
-jar {
- manifest {
- attributes 'Main-Class': 'com.beust.kobalt.wrapper.Main'
- }
-}
-
-publishing {
- publications {
- maven(MavenPublication) {
- from(components.java)
- artifact sourcesJar
- artifact javadocJar
-
- pom {
- name = project.name
- description = 'Wrapper for Kobalt'
- url = 'https://beust.com/kobalt'
- licenses {
- license {
- name = 'Apache-2.0'
- url = 'https://www.apache.org/licenses/LICENSE-2.0'
- }
- }
- developers {
- developer {
- name = 'Cedric Beust'
- email = 'cedric@beust.com'
- }
- }
- scm {
- connection = 'scm:https://github.com/cbeust/kobalt.git'
- developerConnection = 'scm:git@github.com:cbeust/kobalt.git'
- url = 'https://github.com/cbeust/kobalt'
- }
- }
- }
- }
-}
diff --git a/modules/wrapper/pom.xml b/modules/wrapper/pom.xml
deleted file mode 100644
index a9dc8796..00000000
--- a/modules/wrapper/pom.xml
+++ /dev/null
@@ -1,28 +0,0 @@
-
- 4.0.0
-
- com.beust
- kobalt-pom
- 1.1.0
- ../..
-
-
- wrapper
- jar
- 1.1.0
-
-
-
-
- org.apache.maven.plugins
- maven-compiler-plugin
- 3.8.0
-
- 1.7
- 1.7
-
-
-
-
-
\ No newline at end of file
diff --git a/modules/wrapper/src/main/java/com/beust/kobalt/wrapper/Main.java b/modules/wrapper/src/main/java/com/beust/kobalt/wrapper/Main.java
index f31bbc3f..f57db6d2 100644
--- a/modules/wrapper/src/main/java/com/beust/kobalt/wrapper/Main.java
+++ b/modules/wrapper/src/main/java/com/beust/kobalt/wrapper/Main.java
@@ -47,6 +47,7 @@ public class Main {
private int installAndLaunchMain(String[] argv) throws IOException, InterruptedException {
String version = getVersion();
+ initWrapperFile(version);
List kobaltArgv = new ArrayList<>();
boolean noLaunch = false;
@@ -77,7 +78,6 @@ public class Main {
}
int result = 0;
if (! exit) {
- initWrapperFile(version);
Path kobaltJarFile = installDistribution();
if (!noLaunch) {
result = launchMain(kobaltJarFile, kobaltArgv);
@@ -118,7 +118,7 @@ public class Main {
}
private static String downloadUrl(String version) {
- return "https://beust.com/kobalt/kobalt-" + version + ".zip";
+ return "http://beust.com/kobalt/kobalt-" + version + ".zip";
}
private void initWrapperFile(String version) throws IOException {
@@ -133,7 +133,7 @@ public class Main {
}
private String getWrapperVersion() {
- return wrapperProperties.getProperty(PROPERTY_VERSION, "N/A");
+ return wrapperProperties.getProperty(PROPERTY_VERSION);
}
private String getWrapperDownloadUrl(String version) {
diff --git a/pom.xml b/pom.xml
deleted file mode 100644
index 3a87c7ac..00000000
--- a/pom.xml
+++ /dev/null
@@ -1,34 +0,0 @@
-
- 4.0.0
-
- com.beust
- kobalt-pom
- pom
- 1.1.0
-
-
- modules/kobalt-plugin-api
- modules/wrapper
- modules/kobalt
-
-
-
-
- testng
- https://dl.bintray.com/cbeust/maven
-
-
-
-
- 1.2.71
- 1.13.0
- 3.9.1
- 1.1.0
- 1.1.0
- 5.1.0
- 6.12
- 1.7.3
-
-
-
\ No newline at end of file
diff --git a/settings.gradle b/settings.gradle
deleted file mode 100644
index c36e45fd..00000000
--- a/settings.gradle
+++ /dev/null
@@ -1,5 +0,0 @@
-rootProject.name = 'kobalt-pom'
-include(':kobalt-plugin-api', ':wrapper', ':kobalt')
-project(':kobalt-plugin-api').projectDir = file('modules/kobalt-plugin-api')
-project(':wrapper').projectDir = file('modules/wrapper')
-project(':kobalt').projectDir = file('modules/kobalt')
diff --git a/src/main/kotlin/com/beust/kobalt/Main.kt b/src/main/kotlin/com/beust/kobalt/Main.kt
index 19b85404..aeedb001 100644
--- a/src/main/kotlin/com/beust/kobalt/Main.kt
+++ b/src/main/kotlin/com/beust/kobalt/Main.kt
@@ -38,14 +38,6 @@ class Main @Inject constructor(
companion object {
fun mainNoExit(argv: Array): Int {
val (jc, args) = parseArgs(argv)
- if (args.usage) {
- jc.usage()
- return 0
- }
- if (args.version) {
- println("Kobalt ${Kobalt.version}")
- return 0
- }
Kobalt.init(MainModule(args, KobaltSettings.readSettingsXml()))
val result = launchMain(Kobalt.INJECTOR.getInstance(Main::class.java), jc, args, argv)
return result
@@ -55,7 +47,11 @@ class Main @Inject constructor(
val args = Args()
val result = JCommander(args)
result.parse(*argv)
- KobaltLogger.setLogLevel(args)
+ KobaltLogger.LOG_LEVEL = if (args.log < Constants.LOG_QUIET_LEVEL) {
+ Constants.LOG_DEFAULT_LEVEL
+ } else if (args.log > Constants.LOG_MAX_LEVEL) {
+ Constants.LOG_MAX_LEVEL
+ } else args.log
return Main.RunInfo(result, args)
}
diff --git a/src/main/kotlin/com/beust/kobalt/Options.kt b/src/main/kotlin/com/beust/kobalt/Options.kt
index ef4cbfd4..16166e11 100644
--- a/src/main/kotlin/com/beust/kobalt/Options.kt
+++ b/src/main/kotlin/com/beust/kobalt/Options.kt
@@ -1,10 +1,8 @@
package com.beust.kobalt
import com.beust.jcommander.JCommander
-import com.beust.kobalt.api.ITask
import com.beust.kobalt.api.Kobalt
-import com.beust.kobalt.api.KobaltContext
-import com.beust.kobalt.api.Project
+import com.beust.kobalt.api.PluginTask
import com.beust.kobalt.app.ProjectFinder
import com.beust.kobalt.app.ProjectGenerator
import com.beust.kobalt.app.Templates
@@ -46,26 +44,10 @@ class Options @Inject constructor(
val p = if (args.buildFile != null) File(args.buildFile) else File(".")
// val buildFile = BuildFile(Paths.get(p.absolutePath), p.name)
val buildSources = if (p.isDirectory) BuildSources(p.absoluteFile) else SingleFileBuildSources(p)
- val pluginClassLoader = javaClass.classLoader
+ var pluginClassLoader = javaClass.classLoader
- //
- // Attempt to parse the build file in order to correctly set up repos, plug-ins, etc...
- // If the build file can't be parsed, don't give up just yet since some options don't need
- // a correct build file to work.
- //
- var buildError: Throwable? = null
- val allProjects =
- try {
- projectFinder.initForBuildFile(buildSources, args).projects
- } catch(ex: Exception) {
- buildError = ex
- listOf()
- }
-
- fun runIfSuccessfulBuild(buildError: Throwable?, action: () -> Unit) {
- buildError?.let { throw it }
- action()
- }
+ val allProjectResult = projectFinder.initForBuildFile(buildSources, args)
+ val allProjects = allProjectResult.projects
// Modify `args` with options found in buildScript { kobaltOptions(...) }, if any
addOptionsFromBuild(args, Kobalt.optionsFromBuild)
@@ -95,11 +77,9 @@ class Options @Inject constructor(
}),
Option( { -> args.projectInfo }, {
// --projectInfo
- runIfSuccessfulBuild(buildError) {
- allProjects.forEach {
- it.compileDependencies.filter { it.isMaven }.forEach {
- resolveDependency.run(it.id)
- }
+ allProjects.forEach {
+ it.compileDependencies.filter { it.isMaven }.forEach {
+ resolveDependency.run(it.id)
}
}
}),
@@ -109,15 +89,11 @@ class Options @Inject constructor(
}),
Option( { args.tasks }, {
// --tasks
- runIfSuccessfulBuild(buildError) {
- displayTasks(allProjects, Kobalt.context!!)
- }
+ displayTasks()
}),
Option( { args.checkVersions }, {
// --checkVersions
- runIfSuccessfulBuild(buildError) {
- checkVersions.run(allProjects)
- }
+ checkVersions.run(allProjects)
}),
Option( { args.download }, {
// --download
@@ -145,19 +121,17 @@ class Options @Inject constructor(
if (! buildSources.exists()) {
throw KobaltException("Could not find build file: " + buildSources)
}
- runIfSuccessfulBuild(buildError) {
- val runTargetResult = taskManager.runTargets(args.targets, allProjects)
- if (result == 0) {
- result = if (runTargetResult.taskResult.success) 0 else 1
- }
+ val runTargetResult = taskManager.runTargets(args.targets, allProjects)
+ if (result == 0) {
+ result = if (runTargetResult.taskResult.success) 0 else 1
+ }
- // Shutdown all plug-ins
- plugins.shutdownPlugins()
+ // Shutdown all plug-ins
+ plugins.shutdownPlugins()
- // Run the build report contributors
- pluginInfo.buildReportContributors.forEach {
- it.generateReport(Kobalt.context!!)
- }
+ // Run the build report contributors
+ pluginInfo.buildReportContributors.forEach {
+ it.generateReport(Kobalt.context!!)
}
}
return result
@@ -178,29 +152,19 @@ class Options @Inject constructor(
}
}
- private fun displayTasks(projects: List, context: KobaltContext) {
+ private fun displayTasks() {
//
// List of tasks, --tasks
//
- val tasksByPlugins = HashMultimap.create()
- projects.forEach { project ->
- pluginInfo.taskContributors.forEach {
- val tasks = it.tasksFor(project, context)
- tasks.forEach {
- tasksByPlugins.put(it.plugin.name, it)
- }
- }
- }
- listOf(taskManager.annotationTasks, taskManager.dynamicTasks).forEach { tasks ->
- tasks.forEach {
- tasksByPlugins.put(it.plugin.name, it)
- }
+ val tasksByPlugins = HashMultimap.create()
+ taskManager.annotationTasks.forEach {
+ tasksByPlugins.put(it.plugin.name, it)
}
val sb = StringBuffer("List of tasks\n")
tasksByPlugins.keySet().forEach { name ->
sb.append("\n " + AsciiArt.horizontalDoubleLine + " $name "
+ AsciiArt.horizontalDoubleLine + "\n")
- tasksByPlugins[name].distinctBy(ITask::name).sortedBy(ITask::name).forEach { task ->
+ tasksByPlugins[name].distinctBy(PluginTask::name).sortedBy(PluginTask::name).forEach { task ->
sb.append(" ${task.name}\t\t${task.doc}\n")
}
}
diff --git a/src/main/kotlin/com/beust/kobalt/app/BuildFiles.kt b/src/main/kotlin/com/beust/kobalt/app/BuildFiles.kt
index b630f253..98d8815a 100644
--- a/src/main/kotlin/com/beust/kobalt/app/BuildFiles.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/BuildFiles.kt
@@ -119,7 +119,7 @@ class BuildFiles @Inject constructor(val factory: BuildFileCompiler.IFactory,
parentFile.mkdirs()
val imp = arrayListOf().apply {
addAll(imports)
- }.toMutableSet().toMutableList()
+ }.distinct()
Collections.sort(imp)
writeText(imp.joinToString("\n"))
appendText(code.joinToString("\n"))
diff --git a/src/main/kotlin/com/beust/kobalt/app/LanguageTemplateGenerator.kt b/src/main/kotlin/com/beust/kobalt/app/LanguageTemplateGenerator.kt
index e17a7cd8..441939a2 100644
--- a/src/main/kotlin/com/beust/kobalt/app/LanguageTemplateGenerator.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/LanguageTemplateGenerator.kt
@@ -20,8 +20,6 @@ abstract class LanguageTemplateGenerator : ITemplate {
abstract val defaultSourceDirectories : HashSet
abstract val defaultTestDirectories : HashSet
- abstract val mainDependencies : ArrayList
- abstract val testDependencies : ArrayList
abstract val directive : String
abstract val fileMatch : (String) -> Boolean
abstract val fileMap: List
@@ -133,19 +131,20 @@ abstract class LanguageTemplateGenerator : ITemplate {
put("directory", currentDir.absolutePath)
put("sourceDirectories", defaultSourceDirectories)
put("sourceDirectoriesTest", defaultTestDirectories)
- put("mainDependencies", mainDependencies)
- put("testDependencies", testDependencies)
put("imports", "import com.beust.kobalt.plugin.$templateName.*")
put("directive", "project")
}
+ var mainDeps = arrayListOf()
+ var testDeps = arrayListOf()
+ map.put("mainDependencies", mainDeps)
+ map.put("testDependencies", testDeps)
File("pom.xml").let {
if (it.absoluteFile.exists()) {
- importPom(it, mainDependencies, testDependencies, map)
+ importPom(it, mainDeps, testDeps, map)
}
}
-
val fileInputStream = javaClass.classLoader
.getResource(ITemplateContributor.DIRECTORY_NAME + "/build.mustache").openStream()
val sw = StringWriter()
diff --git a/src/main/kotlin/com/beust/kobalt/app/MainModule.kt b/src/main/kotlin/com/beust/kobalt/app/MainModule.kt
index 1f9e07b2..8181a3b9 100644
--- a/src/main/kotlin/com/beust/kobalt/app/MainModule.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/MainModule.kt
@@ -1,8 +1,6 @@
package com.beust.kobalt.app
import com.beust.kobalt.Args
-import com.beust.kobalt.JavaInfo
-import com.beust.kobalt.Jvm
import com.beust.kobalt.app.remote.KobaltServer
import com.beust.kobalt.internal.IncrementalManager
import com.beust.kobalt.internal.KobaltSettings
@@ -19,7 +17,6 @@ import com.google.inject.Provider
import com.google.inject.Singleton
import com.google.inject.TypeLiteral
import com.google.inject.assistedinject.FactoryModuleBuilder
-import java.io.File
import java.util.concurrent.ExecutorService
open class MainModule(val args: Args, val settings: KobaltSettings) : AbstractModule() {
@@ -52,14 +49,15 @@ open class MainModule(val args: Args, val settings: KobaltSettings) : AbstractMo
bind(Args::class.java).toProvider(Provider {
args
})
- bind(EventBus::class.java).toInstance(EventBus())
+ EventBus().let { eventBus ->
+ bind(EventBus::class.java).toInstance(eventBus)
+ }
bind(PluginInfo::class.java).toProvider(Provider {
PluginInfo.readKobaltPluginXml()
}).`in`(Singleton::class.java)
bind(KobaltSettings::class.java).toProvider(Provider {
settings
}).`in`(Singleton::class.java)
- bind(Jvm::class.java).toInstance(JavaInfo.create(File(com.beust.kobalt.SystemProperties.javaBase)))
// bindListener(Matchers.any(), object: TypeListener {
// override fun hear(typeLiteral: TypeLiteral?, typeEncounter: TypeEncounter?) {
diff --git a/src/main/kotlin/com/beust/kobalt/app/Profiles.kt b/src/main/kotlin/com/beust/kobalt/app/Profiles.kt
index b2cf1a5a..bb5ea346 100644
--- a/src/main/kotlin/com/beust/kobalt/app/Profiles.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/Profiles.kt
@@ -56,7 +56,7 @@ class Profiles(val context: KobaltContext) {
val variable = if (match.first) match.second else oldMatch.second
if (oldMatch.first) {
- warn("Old profile syntax detected for \"${line.trim()}\"," +
+ warn("Old profile syntax detected for \"$line\"," +
" please update to \"val $variable by profile()\"")
}
diff --git a/src/main/kotlin/com/beust/kobalt/app/java/JavaTemplateGenerator.kt b/src/main/kotlin/com/beust/kobalt/app/java/JavaTemplateGenerator.kt
index ef938f00..c34b80d3 100644
--- a/src/main/kotlin/com/beust/kobalt/app/java/JavaTemplateGenerator.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/java/JavaTemplateGenerator.kt
@@ -1,14 +1,11 @@
package com.beust.kobalt.app.java
import com.beust.kobalt.app.LanguageTemplateGenerator
-import com.beust.kobalt.maven.Pom
/**
* Template for the "java" generator.
*/
class JavaTemplateGenerator : LanguageTemplateGenerator() {
- override val mainDependencies = arrayListOf()
- override val testDependencies = arrayListOf()
override val defaultSourceDirectories = hashSetOf("src/main/java")
override val defaultTestDirectories = hashSetOf("src/test/java")
override val directive = "project"
diff --git a/src/main/kotlin/com/beust/kobalt/app/kotlin/KotlinTemplateGenerator.kt b/src/main/kotlin/com/beust/kobalt/app/kotlin/KotlinTemplateGenerator.kt
index f10698c4..51b11a14 100644
--- a/src/main/kotlin/com/beust/kobalt/app/kotlin/KotlinTemplateGenerator.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/kotlin/KotlinTemplateGenerator.kt
@@ -1,16 +1,10 @@
package com.beust.kobalt.app.kotlin
-import com.beust.kobalt.Constants
import com.beust.kobalt.app.LanguageTemplateGenerator
-import com.beust.kobalt.maven.Pom
class KotlinTemplateGenerator : LanguageTemplateGenerator() {
override val defaultSourceDirectories = hashSetOf("src/main/kotlin")
override val defaultTestDirectories = hashSetOf("src/test/kotlin")
- override val mainDependencies = arrayListOf(
- Pom.Dependency("org.jetbrains.kotlin", "kotlin-stdlib", null, Constants.KOTLIN_COMPILER_VERSION)
- )
- override val testDependencies = arrayListOf()
override val directive = "project"
override val templateName = "kotlin"
override val templateDescription = "Generate a simple Kotlin project"
diff --git a/src/main/kotlin/com/beust/kobalt/app/remote/GetDependencyGraphHandler.kt b/src/main/kotlin/com/beust/kobalt/app/remote/GetDependencyGraphHandler.kt
index 38eb6b0a..96e8658c 100644
--- a/src/main/kotlin/com/beust/kobalt/app/remote/GetDependencyGraphHandler.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/remote/GetDependencyGraphHandler.kt
@@ -35,7 +35,6 @@ class GetDependencyGraphHandler : WebSocketListener {
fun sendWebsocketCommand(endpoint: RemoteEndpoint, commandName: String, payload: T,
errorMessage: String? = null) {
- SparkServer.watchDog.rearm()
val json = Gson().toJson(WebSocketCommand(commandName, payload = Gson().toJson(payload),
errorMessage = errorMessage))
endpoint.sendString(json)
diff --git a/src/main/kotlin/com/beust/kobalt/app/remote/KobaltClient.kt b/src/main/kotlin/com/beust/kobalt/app/remote/KobaltClient.kt
index 41d9fdd4..a7c0a312 100644
--- a/src/main/kotlin/com/beust/kobalt/app/remote/KobaltClient.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/remote/KobaltClient.kt
@@ -12,7 +12,15 @@ import com.beust.kobalt.misc.KFiles
import com.beust.kobalt.misc.warn
import com.google.gson.Gson
import com.google.inject.Guice
-import okhttp3.*
+import okhttp3.OkHttpClient
+import okhttp3.Request
+import okhttp3.Response
+import okhttp3.ResponseBody
+import okhttp3.ws.WebSocket
+import okhttp3.ws.WebSocketCall
+import okhttp3.ws.WebSocketListener
+import okio.Buffer
+import java.io.IOException
fun main(argv: Array) {
Kobalt.INJECTOR = Guice.createInjector(MainModule(Args(), KobaltSettings.readSettingsXml()))
@@ -31,22 +39,26 @@ class KobaltClient : Runnable {
.url("$url?projectRoot=$projectRoot&buildFile=$buildFile")
.build()
var webSocket: WebSocket? = null
- val socketListener = object: WebSocketListener() {
- override fun onFailure(webSocket: WebSocket, ex: Throwable, response: Response?) {
- Exceptions.printStackTrace(ex)
- error("WebSocket failure: ${ex.message} response: $response")
- }
-
+ val ws = WebSocketCall.create(client, request).enqueue(object: WebSocketListener {
override fun onOpen(ws: WebSocket, response: Response) {
webSocket = ws
}
- override fun onClosing(webSocket: WebSocket, code: Int, reason: String) {
- println("Closing socket")
+ override fun onPong(p0: Buffer?) {
+ println("WebSocket pong")
}
- override fun onMessage(webSocket: WebSocket, text: String) {
- val json = text
+ override fun onClose(p0: Int, p1: String?) {
+ println("WebSocket closed")
+ }
+
+ override fun onFailure(ex: IOException, response: Response?) {
+ Exceptions.printStackTrace(ex)
+ error("WebSocket failure: ${ex.message} response: $response")
+ }
+
+ override fun onMessage(body: ResponseBody) {
+ val json = body.string()
val wsCommand = Gson().fromJson(json, WebSocketCommand::class.java)
if (wsCommand.errorMessage != null) {
warn("Received error message from server: " + wsCommand.errorMessage)
@@ -75,10 +87,7 @@ class KobaltClient : Runnable {
}
}
}
- }
-
- val ws = client.newWebSocket(request, socketListener)
- ws.close(1000, "All good")
+ })
}
}
diff --git a/src/main/kotlin/com/beust/kobalt/app/remote/KobaltServer.kt b/src/main/kotlin/com/beust/kobalt/app/remote/KobaltServer.kt
index 3c4339d3..2e068829 100644
--- a/src/main/kotlin/com/beust/kobalt/app/remote/KobaltServer.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/remote/KobaltServer.kt
@@ -1,5 +1,6 @@
package com.beust.kobalt.app.remote
+import com.beust.kobalt.api.Project
import com.beust.kobalt.homeDir
import com.beust.kobalt.internal.PluginInfo
import com.beust.kobalt.maven.aether.Exceptions
@@ -73,12 +74,15 @@ class KobaltServer @Inject constructor(@Assisted val force: Boolean, @Assisted @
try {
if (createServerFile(port, force)) {
kobaltLog(1, "KobaltServer listening on port $port")
+// OldServer(initCallback, cleanUpCallback).run(port)
+// JerseyServer(initCallback, cleanUpCallback).run(port)
SparkServer(cleanUpCallback, pluginInfo).run(port)
+// WasabiServer(initCallback, cleanUpCallback).run(port)
}
} catch(ex: Exception) {
Exceptions.printStackTrace(ex)
} finally {
- deleteServerFile()
+// deleteServerFile()
}
return port
}
diff --git a/src/main/kotlin/com/beust/kobalt/app/remote/RemoteDependencyData.kt b/src/main/kotlin/com/beust/kobalt/app/remote/RemoteDependencyData.kt
index fcd0a80c..bd1914ac 100644
--- a/src/main/kotlin/com/beust/kobalt/app/remote/RemoteDependencyData.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/remote/RemoteDependencyData.kt
@@ -2,7 +2,6 @@ package com.beust.kobalt.app.remote
import com.beust.kobalt.Args
import com.beust.kobalt.api.IClasspathDependency
-import com.beust.kobalt.api.Kobalt
import com.beust.kobalt.api.Project
import com.beust.kobalt.app.BuildFileCompiler
import com.beust.kobalt.internal.DynamicGraph
@@ -30,7 +29,7 @@ class RemoteDependencyData @Inject constructor(val executors: KobaltExecutors, v
val taskManager: TaskManager) {
fun dependenciesDataFor(buildSources: BuildSources, args: Args,
- projectResult: BuildFileCompiler.FindProjectResult,
+ findProjectResult: BuildFileCompiler.FindProjectResult,
progressListener: IProgressListener? = null,
useGraph : Boolean = false): GetDependenciesData {
val projectDatas = arrayListOf()
@@ -43,7 +42,9 @@ class RemoteDependencyData @Inject constructor(val executors: KobaltExecutors, v
fun allDeps(l: List, name: String) = dependencyManager.transitiveClosure(l,
requiredBy = name)
- val buildFileDependencies = Kobalt.buildFileClasspath.map {toDependencyData(it, "compile")}
+// val buildFile = BuildFile(Paths.get(buildFilePath), "GetDependenciesCommand")
+ val buildFileCompiler = buildFileCompilerFactory.create(buildSources, pluginInfo)
+ val projectResult = buildFileCompiler.compileBuildFiles(args)
val pluginDependencies = projectResult.pluginUrls.map { File(it.toURI()) }.map {
DependencyData(it.name, "compile", it.absolutePath)
@@ -175,8 +176,8 @@ class RemoteDependencyData @Inject constructor(val executors: KobaltExecutors, v
})
}
- return GetDependenciesData(projectDatas, allTasks, pluginDependencies, buildFileDependencies,
- projectResult.buildContentRoots, projectResult.taskResult.errorMessage)
+ return GetDependenciesData(projectDatas, allTasks, pluginDependencies, findProjectResult.buildContentRoots,
+ projectResult.taskResult.errorMessage)
}
/////
@@ -201,7 +202,6 @@ class RemoteDependencyData @Inject constructor(val executors: KobaltExecutors, v
class GetDependenciesData(val projects: List = emptyList(),
val allTasks: Collection = emptySet(),
val pluginDependencies: List = emptyList(),
- val buildFileDependencies: List = emptyList(),
val buildContentRoots: List = emptyList(),
val errorMessage: String?) {
companion object {
diff --git a/src/main/kotlin/com/beust/kobalt/app/remote/SparkServer.kt b/src/main/kotlin/com/beust/kobalt/app/remote/SparkServer.kt
index f78c8f37..49f3e4a1 100644
--- a/src/main/kotlin/com/beust/kobalt/app/remote/SparkServer.kt
+++ b/src/main/kotlin/com/beust/kobalt/app/remote/SparkServer.kt
@@ -5,7 +5,6 @@ import com.beust.kobalt.app.Templates
import com.beust.kobalt.internal.PluginInfo
import com.google.common.collect.ListMultimap
import com.google.gson.Gson
-import org.slf4j.Logger
import spark.ResponseTransformer
import spark.Route
import spark.Spark
@@ -15,8 +14,6 @@ class SparkServer(val cleanUpCallback: () -> Unit, val pluginInfo : PluginInfo)
companion object {
lateinit var cleanUpCallback: () -> Unit
- val URL_QUIT = "/quit"
- lateinit var watchDog: WatchDog
}
init {
@@ -31,25 +28,19 @@ class SparkServer(val cleanUpCallback: () -> Unit, val pluginInfo : PluginInfo)
private fun jsonRoute(path: String, route: Route)
= Spark.get(path, "application/json", route, JsonTransformer())
- val log: Logger = org.slf4j.LoggerFactory.getLogger("SparkServer")
+ val log = org.slf4j.LoggerFactory.getLogger("SparkServer")
override fun run(port: Int) {
- val threadPool = Executors.newFixedThreadPool(2)
- watchDog = WatchDog(port, 60 * 10 /* 10 minutes */, log)
- threadPool.submit {
- watchDog.run()
- }
log.debug("Server running")
Spark.port(port)
Spark.webSocket("/v1/getDependencyGraph", GetDependencyGraphHandler::class.java)
Spark.get("/ping") { req, res ->
- watchDog.rearm()
log.debug(" Received ping")
""" { "result" : "ok" } """
}
- Spark.get(URL_QUIT, { req, res ->
+ Spark.get("/quit", { req, res ->
log.debug(" Received quit")
- threadPool.let { executor ->
+ Executors.newFixedThreadPool(1).let { executor ->
executor.submit {
Thread.sleep(1000)
Spark.stop()
diff --git a/src/main/kotlin/com/beust/kobalt/app/remote/WatchDog.kt b/src/main/kotlin/com/beust/kobalt/app/remote/WatchDog.kt
deleted file mode 100644
index c006abd4..00000000
--- a/src/main/kotlin/com/beust/kobalt/app/remote/WatchDog.kt
+++ /dev/null
@@ -1,71 +0,0 @@
-package com.beust.kobalt.app.remote
-
-import com.beust.kobalt.misc.warn
-import org.slf4j.Logger
-import java.net.HttpURLConnection
-import java.net.URL
-import java.time.Duration
-import java.time.LocalDateTime
-import java.time.OffsetDateTime
-import java.time.format.DateTimeFormatter
-
-/**
- * Wakes up every `WAKE_UP_INTERVAL` and check if a certain period of time (`checkPeriod`) has elapsed
- * without being rearmed. If that time has elapsed, send a QUIT command to the Kobalt server. If the WatchDog
- * gets rearmed, the expiration period is reset.
- */
-class WatchDog(val port: Int, val checkPeriodSeconds: Long, val log: Logger) {
- private val WAKE_UP_INTERVAL: Duration = Duration.ofSeconds(60)
- private val FORMAT: DateTimeFormatter = DateTimeFormatter.ofPattern("MM/d/y HH:mm:ss")
-
- private var nextWakeUpMillis: Long = arm()
- private var stop: Boolean = false
-
- /**
- * Rearm for another `checkPeriod`.
- */
- fun rearm() {
- nextWakeUpMillis = arm()
- log.info("Watchdog rearmed for " + format(nextWakeUpMillis))
- }
-
- /**
- * Start the watch dog.
- */
- fun run() {
- val wakeUpSeconds = WAKE_UP_INTERVAL.toMillis()
- log.info("Server dying at " + format(nextWakeUpMillis) + ", next wake up in "
- + (wakeUpSeconds / 1000) + " seconds")
- while (! stop) {
- Thread.sleep(wakeUpSeconds)
- val diffSeconds = (nextWakeUpMillis - System.currentTimeMillis()) / 1000
- if (diffSeconds <= 0) {
- log.info("Time to die")
- stop = true
- } else {
- log.info("Dying in $diffSeconds seconds")
- }
- }
-
- try {
- val connection = (URL("http://localhost:$port" + SparkServer.URL_QUIT)
- .openConnection() as HttpURLConnection).apply {
- requestMethod = "GET"
- }
- val code = connection.responseCode
- if (code == 200) {
- log.info("Successfully stopped the server")
- } else {
- warn("Couldn't stop the server, response: " + code)
- }
- } catch(ex: Exception) {
- warn("Couldn't stop the server: " + ex.message, ex)
- }
- }
-
- private fun arm() = System.currentTimeMillis() + (checkPeriodSeconds * 1000)
-
- private fun toLocalDate(millis: Long) = LocalDateTime.ofEpochSecond(millis / 1000, 0, OffsetDateTime.now().offset)
-
- private fun format(millis: Long) = FORMAT.format(toLocalDate(millis))
-}
\ No newline at end of file
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/application/ApplicationPlugin.kt b/src/main/kotlin/com/beust/kobalt/plugin/application/ApplicationPlugin.kt
index 926a00bf..032c466d 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/application/ApplicationPlugin.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/application/ApplicationPlugin.kt
@@ -1,12 +1,11 @@
package com.beust.kobalt.plugin.application
-import com.beust.kobalt.Jvm
-import com.beust.kobalt.KobaltException
-import com.beust.kobalt.Plugins
-import com.beust.kobalt.TaskResult
+import com.beust.kobalt.*
import com.beust.kobalt.api.*
import com.beust.kobalt.api.annotation.Directive
+import com.beust.kobalt.api.annotation.Task
import com.beust.kobalt.archive.Archives
+import com.beust.kobalt.internal.ActorUtils
import com.beust.kobalt.maven.DependencyManager
import com.beust.kobalt.maven.aether.Scope
import com.beust.kobalt.misc.KFiles
@@ -20,9 +19,6 @@ import com.google.inject.Singleton
import java.io.File
class ApplicationConfig {
- @Directive
- var taskName: String = "run"
-
@Directive
var mainClass: String? = null
@@ -33,15 +29,6 @@ class ApplicationConfig {
@Directive
fun args(vararg argv: String) = argv.forEach { args.add(it) }
val args = arrayListOf()
-
- @Directive
- var ignoreErrorStream: Boolean = false
-
- @Directive
- var ignoreInputStream: Boolean = true
-
- @Directive
- var ignoreExitValue: Boolean = false
}
@Directive
@@ -53,10 +40,10 @@ fun Project.application(init: ApplicationConfig.() -> Unit): ApplicationConfig {
}
@Singleton
-class ApplicationPlugin @Inject constructor(val configActor: ConfigsActor,
+class ApplicationPlugin @Inject constructor(val configActor: ConfigActor,
val executors: KobaltExecutors, val nativeManager: NativeManager,
- val dependencyManager: DependencyManager, val taskContributor : TaskContributor, val jvm: Jvm)
- : BasePlugin(), ITaskContributor, IConfigsActor by configActor {
+ val dependencyManager: DependencyManager, val taskContributor : TaskContributor)
+ : BasePlugin(), IRunnerContributor, ITaskContributor, IConfigActor by configActor {
companion object {
const val PLUGIN_NAME = "Application"
@@ -66,50 +53,49 @@ class ApplicationPlugin @Inject constructor(val configActor: ConfigsActor
- configs.forEach { config ->
- taskContributor.addTask(this, project, config.taskName,
- description = "Run the class " + config.mainClass,
- group = "run",
- dependsOn = listOf("assemble"),
- runTask = { run(project, context, config) })
- }
- }
+ taskContributor.addVariantTasks(this, project, context, "run", group = "run", dependsOn = listOf("install"),
+ runTask = { taskRun(project) })
}
-// fun taskRun(project: Project, config: ApplicationConfig): TaskResult {
-// val runContributor = ActorUtils.selectAffinityActor(project, context,
-// context.pluginInfo.runnerContributors)
-// if (runContributor != null && runContributor.affinity(project, context) > 0) {
-// return runContributor.run(project, context,
-// dependencyManager.dependencies(project, context, listOf(Scope.RUNTIME)))
-// } else {
-// context.logger.log(project.name, 1,
-// "Couldn't find a runner for project ${project.name}. Please make sure" +
-// " your build file contains " +
-// "an application{} directive with a mainClass=... in it")
-// return TaskResult()
-// }
-// }
+ @Task(name = "run", description = "Run the main class", group = "run", dependsOn = arrayOf("install"))
+ fun taskRun(project: Project): TaskResult {
+ val runContributor = ActorUtils.selectAffinityActor(project, context,
+ context.pluginInfo.runnerContributors)
+ if (runContributor != null && runContributor.affinity(project, context) > 0) {
+ return runContributor.run(project, context,
+ dependencyManager.dependencies(project, context, listOf(Scope.RUNTIME)))
+ } else {
+ context.logger.log(project.name, 1,
+ "Couldn't find a runner for project ${project.name}. Please make sure" +
+ " your build file contains " +
+ "an application{} directive with a mainClass=... in it")
+ return TaskResult()
+ }
+ }
private fun isFatJar(packages: List, jarName: String): Boolean {
val foundJar = packages.flatMap { it.jars }.filter { jarName.endsWith(it.name) }
return foundJar.size == 1 && foundJar[0].fatJar
}
- private fun run(project: Project, context: KobaltContext, config: ApplicationConfig): TaskResult {
+ // IRunContributor
+
+ override fun affinity(project: Project, context: KobaltContext): Int {
+ return if (configurationFor(project) != null) IAffinity.DEFAULT_POSITIVE_AFFINITY else 0
+ }
+
+ override fun run(project: Project, context: KobaltContext, classpath: List): TaskResult {
+ var result = TaskResult()
if (project.nativeDependencies.any()) {
nativeManager.installLibraries(project)
}
-
- val result =
+ configurationFor(project)?.let { config ->
if (config.mainClass != null) {
- runJarFile(project, context, config)
+ result = runJarFile(project, context, config)
} else {
throw KobaltException("No \"mainClass\" specified in the application{} part of project ${project.name}")
}
-
+ }
return result
}
@@ -125,7 +111,7 @@ class ApplicationPlugin @Inject constructor(val configActor: ConfigsActor
val allDeps = arrayListOf(jarName)
- val java = jvm.javaExecutable!!
+ val java = JavaInfo.create(File(SystemProperties.javaBase)).javaExecutable!!
if (! isFatJar(packages, jarName)) {
@Suppress("UNCHECKED_CAST")
// If the jar file is not fat, we need to add the transitive closure of all dependencies
@@ -147,7 +133,6 @@ class ApplicationPlugin @Inject constructor(val configActor: ConfigsActor ->
kobaltLog(1, output.joinToString("\n"))
@@ -156,25 +141,11 @@ class ApplicationPlugin @Inject constructor(val configActor: ConfigsActor {
- val result = arrayListOf()
- configurationFor(project)?.let { configs ->
- configs.forEach { config ->
- result.add(DynamicTask(this, config.taskName, "Run the class " + config.mainClass, "run", project,
- dependsOn = listOf("assemble"),
- closure = { run(project, context, config) }))
- }
- }
-
- return result
- }
+ override fun tasksFor(project: Project, context: KobaltContext): List = taskContributor.dynamicTasks
}
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/apt/AptPlugin.kt b/src/main/kotlin/com/beust/kobalt/plugin/apt/AptPlugin.kt
index f2d7410b..b90c9f5a 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/apt/AptPlugin.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/apt/AptPlugin.kt
@@ -1,20 +1,10 @@
package com.beust.kobalt.plugin.apt
-import com.beust.kobalt.Constants
-import com.beust.kobalt.Jvm
-import com.beust.kobalt.TaskResult
import com.beust.kobalt.api.*
-import com.beust.kobalt.api.annotation.AnnotationDefault
import com.beust.kobalt.api.annotation.Directive
-import com.beust.kobalt.internal.CompilerUtils
import com.beust.kobalt.maven.DependencyManager
-import com.beust.kobalt.maven.aether.Filters
-import com.beust.kobalt.maven.aether.Scope
-import com.beust.kobalt.maven.dependency.FileDependency
import com.beust.kobalt.misc.KFiles
-import com.beust.kobalt.misc.KobaltLogger
import com.beust.kobalt.misc.warn
-import com.beust.kobalt.plugin.kotlin.KotlinPlugin
import com.google.common.collect.ArrayListMultimap
import com.google.inject.Inject
import java.io.File
@@ -22,16 +12,33 @@ import java.util.*
import javax.inject.Singleton
/**
- * The AptPlugin manages both apt and kapt. Each of them has two components:
+ * The AptPlugin has two components:
* 1) A new apt directive inside a dependency{} block (similar to compile()) that declares where
* the annotation processor is found
* 2) An apt{} configuration on Project that lets the user configure how the annotation is performed
* (outputDir, etc...).
*/
@Singleton
-class AptPlugin @Inject constructor(val dependencyManager: DependencyManager, val kotlinPlugin: KotlinPlugin,
- val compilerUtils: CompilerUtils, val jvm: Jvm)
- : BasePlugin(), ICompilerFlagContributor, ISourceDirectoryContributor, IClasspathContributor, ITaskContributor {
+class AptPlugin @Inject constructor(val dependencyManager: DependencyManager)
+ : BasePlugin(), ICompilerFlagContributor, ISourceDirectoryContributor {
+
+ // ISourceDirectoryContributor
+
+ private fun generatedDir(project: Project, outputDir: String) : File
+ = File(KFiles.joinDir(project.directory, KFiles.KOBALT_BUILD_DIR, outputDir))
+
+ override fun sourceDirectoriesFor(project: Project, context: KobaltContext): List {
+ val result = arrayListOf()
+ aptConfigs[project.name]?.let { config ->
+ result.add(generatedDir(project, config.outputDir))
+ }
+
+ kaptConfigs[project.name]?.let { config ->
+ result.add(generatedDir(project, config.outputDir))
+ }
+
+ return result
+ }
companion object {
const val PLUGIN_NAME = "Apt"
@@ -42,14 +49,10 @@ class AptPlugin @Inject constructor(val dependencyManager: DependencyManager, va
override val name = PLUGIN_NAME
override fun apply(project: Project, context: KobaltContext) {
- super.apply(project, context)
- val kaptConfig = kaptConfigs[project.name]
-
- // Delete the output directories
- listOf(aptConfigs[project.name]?.outputDir, kaptConfig?.outputDir)
+ listOf(aptConfigs[project.name]?.outputDir, aptConfigs[project.name]?.outputDir)
.filterNotNull()
.distinct()
- .map { aptGeneratedDir(project, it) }
+ .map { generatedDir(project, it) }
.forEach {
it.normalize().absolutePath.let { path ->
context.logger.log(project.name, 1, " Deleting " + path)
@@ -59,195 +62,21 @@ class AptPlugin @Inject constructor(val dependencyManager: DependencyManager, va
}
}
- // IClasspathContributor
- override fun classpathEntriesFor(project: Project?, context: KobaltContext): Collection {
- val result = arrayListOf()
- val kaptConfig = kaptConfigs[project?.name]
- if (project != null && kaptConfig != null) {
- kaptConfig.let { config ->
- val c = kaptClassesDir(project, config.outputDir)
- File(c).mkdirs()
- result.add(FileDependency(c))
- }
- }
- return result
- }
-
- private fun aptGeneratedDir(project: Project, outputDir: String) : File
- = File(KFiles.joinDir(project.directory, KFiles.KOBALT_BUILD_DIR, outputDir))
-
- // ISourceDirectoryContributor
- override fun sourceDirectoriesFor(project: Project, context: KobaltContext): List {
- val result = arrayListOf()
- aptConfigs[project.name]?.let { config ->
- result.add(aptGeneratedDir(project, config.outputDir))
- }
-
- kaptConfigs[project.name]?.let { config ->
- result.add(File(kaptSourcesDir(project, config.outputDir)))
- }
-
- return result
- }
-
- private fun kaptGenerated(project: Project, outputDir: String) =
- KFiles.joinAndMakeDir(project.directory, project.buildDirectory, outputDir)
-
- private fun kaptSourcesDir(project: Project, outputDir: String) =
- KFiles.joinDir(kaptGenerated(project, outputDir), "sources")
- private fun kaptStubsDir(project: Project, outputDir: String) =
- KFiles.joinDir(kaptGenerated(project, outputDir), "stubs")
- private fun kaptClassesDir(project: Project, outputDir: String) =
- KFiles.joinDir(kaptGenerated(project, outputDir), "classes")
-
- // ITaskContributor
- override fun tasksFor(project: Project, context: KobaltContext): List {
- val kaptConfig = kaptConfigs[project.name]
- val result =
- if (kaptConfig != null) {
- listOf(
- DynamicTask(this, "runKapt", "Run kapt", AnnotationDefault.GROUP, project,
- reverseDependsOn = listOf("compile"), runAfter = listOf("clean"),
- closure = {p: Project -> taskRunKapt(p)}),
- DynamicTask(this, "compileKapt", "Compile the sources generated by kapt",
- AnnotationDefault.GROUP, project,
- dependsOn = listOf("runKapt"), reverseDependsOn = listOf("compile"),
- closure = {p: Project -> taskCompileKapt(p)})
- )
- } else {
- emptyList()
- }
- return result
- }
-
- fun taskCompileKapt(project: Project) : TaskResult {
- var success = true
- kaptConfigs[project.name]?.let { config ->
- val sourceDirs = listOf(
- kaptStubsDir(project, config.outputDir),
- kaptSourcesDir(project, config.outputDir))
- val sourceFiles = KFiles.findSourceFiles(project.directory, sourceDirs, listOf("kt")).toList()
- val buildDirectory = File(KFiles.joinDir(project.directory,
- kaptClassesDir(project, config.outputDir)))
- val flags = listOf()
- val cai = CompilerActionInfo(project.directory, allDependencies(project), sourceFiles, listOf(".kt"),
- buildDirectory, flags, emptyList(), forceRecompile = true, compilerSeparateProcess = true)
-
- val cr = compilerUtils.invokeCompiler(project, context, kotlinPlugin.compiler, cai)
- success = cr.failedResult == null
- }
-
- return TaskResult(success)
- }
-
- val annotationDependencyId = "org.jetbrains.kotlin:kotlin-annotation-processing:" +
- Constants.KOTLIN_COMPILER_VERSION
-
- fun annotationProcessorDependency() = dependencyManager.create(annotationDependencyId)
-
- fun aptJarDependencies(project: Project) = aptDependencies[project.name].map { dependencyManager.create(it) }
-
- fun allDependencies(project: Project): List {
- val allDeps = arrayListOf()
- allDeps.add(annotationProcessorDependency())
- allDeps.addAll(aptJarDependencies(project))
-
- return allDeps
- }
-
- fun taskRunKapt(project: Project) : TaskResult {
- var success = true
- val flags = arrayListOf()
- val kaptConfig = kaptConfigs[project.name]
- kaptConfig?.let { config ->
- val generated = kaptGenerated(project, config.outputDir)
- val generatedSources = kaptSourcesDir(project, config.outputDir).replace("//", "/")
- File(generatedSources).mkdirs()
-
- //
- // Tell the Kotlin compiler to use the annotation plug-in
- //
- flags.add("-Xplugin")
- flags.add(annotationProcessorDependency().jarFile.get().absolutePath)
-
- // Also need tools.jar on the plug-in classpath
- val toolsJar = jvm.toolsJar
- if (toolsJar != null) {
- flags.add("-Xplugin")
- flags.add(toolsJar.absolutePath)
- } else {
- warn("Couldn't find tools.jar from the JDK")
- }
-
- aptJarDependencies(project).forEach {
- flags.add("-Xplugin")
- flags.add(it.jarFile.get().absolutePath)
- }
-
- //
- // Pass options to the annotation plugin
- //
- flags.add("-P")
- fun kaptPluginFlag(flagValue: String) = "plugin:org.jetbrains.kotlin.kapt3:$flagValue"
- val kaptPluginFlags = arrayListOf()
- val verbose = KobaltLogger.LOG_LEVEL >= 2
- listOf("sources=" + generatedSources,
- "classes=" + kaptClassesDir(project, config.outputDir),
- "stubs=" + kaptStubsDir(project, config.outputDir),
- "verbose=$verbose",
- "aptOnly=true").forEach {
- kaptPluginFlags.add(kaptPluginFlag(it))
- }
-
- //
- // Dependencies for the annotation plug-in and the generation
- //
- val allDeps = allDependencies(project)
- val dependencies = dependencyManager.calculateDependencies(project, context,
- Filters.EXCLUDE_OPTIONAL_FILTER,
- listOf(Scope.COMPILE),
- allDeps)
- dependencies.forEach {
- val jarFile = it.jarFile.get().absolutePath
- kaptPluginFlags.add(kaptPluginFlag("apclasspath=$jarFile"))
- }
-
- flags.add(kaptPluginFlags.joinToString(","))
- listOf("-language-version", "1.1", "-api-version", "1.1").forEach {
- flags.add(it)
- }
-
- val sourceFiles =
- KFiles.findSourceFiles(project.directory, project.sourceDirectories, listOf("kt"))
- .toList() + generatedSources
- val buildDirectory = File(KFiles.joinDir(project.directory, generated))
- val cai = CompilerActionInfo(project.directory, allDeps, sourceFiles, listOf(".kt"),
- buildDirectory, flags, emptyList(), forceRecompile = true, compilerSeparateProcess = true)
-
- context.logger.log(project.name, 2, "kapt3 flags:")
- context.logger.log(project.name, 2, " " + kaptPluginFlags.joinToString("\n "))
- val cr = compilerUtils.invokeCompiler(project, context, kotlinPlugin.compiler, cai)
- success = cr.failedResult == null
- }
-
- return TaskResult(success)
- }
+ private fun generated(project: Project, context: KobaltContext, outputDir: String) =
+ KFiles.joinAndMakeDir(project.directory, project.buildDirectory, outputDir,
+ context.variant.toIntermediateDir())
// ICompilerFlagContributor
override fun compilerFlagsFor(project: Project, context: KobaltContext, currentFlags: List,
suffixesBeingCompiled: List): List {
- val result = arrayListOf()
-
- // Only run for Java files
if (!suffixesBeingCompiled.contains("java")) return emptyList()
+ val result = arrayListOf()
+
fun addFlags(outputDir: String) {
aptDependencies[project.name]?.let {
result.add("-s")
- aptGeneratedDir(project, outputDir).let { generatedSource ->
- generatedSource.mkdirs()
- result.add(generatedSource.path)
- }
+ result.add(generated(project, context, outputDir))
}
}
@@ -255,6 +84,10 @@ class AptPlugin @Inject constructor(val dependencyManager: DependencyManager, va
addFlags(config.outputDir)
}
+ kaptConfigs[project.name]?.let { config ->
+ addFlags(config.outputDir)
+ }
+
context.logger.log(project.name, 2, "New flags from apt: " + result.joinToString(" "))
return result
}
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/java/JavaCompiler.kt b/src/main/kotlin/com/beust/kobalt/plugin/java/JavaCompiler.kt
index a88c2957..97d7644b 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/java/JavaCompiler.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/java/JavaCompiler.kt
@@ -1,6 +1,7 @@
package com.beust.kobalt.plugin.java
-import com.beust.kobalt.Jvm
+import com.beust.kobalt.JavaInfo
+import com.beust.kobalt.SystemProperties
import com.beust.kobalt.TaskResult
import com.beust.kobalt.api.*
import com.beust.kobalt.internal.CompilerUtils
@@ -21,7 +22,7 @@ import javax.tools.ToolProvider
@Singleton
class JavaCompiler @Inject constructor(val jvmCompiler: JvmCompiler, val kobaltLog: ParallelLogger,
- val compilerUtils: CompilerUtils, val jvm: Jvm) : ICompiler {
+ val compilerUtils: CompilerUtils) : ICompiler {
fun compilerAction(executable: File) = object : ICompilerAction {
override fun compile(project: Project?, info: CompilerActionInfo): TaskResult {
val projectName = project?.name
@@ -83,7 +84,7 @@ class JavaCompiler @Inject constructor(val jvmCompiler: JvmCompiler, val kobaltL
val pb = ProcessBuilder(executable.absolutePath, "@" + KFiles.fixSlashes(atFile))
pb.inheritIO()
logk(1, " Java compiling " + Strings.pluralizeAll(info.sourceFiles.size, "file"))
- logk(2, " Java compiling using file: " + KFiles.fixSlashes(atFile))
+ logk(2, " Java compiling file: " + KFiles.fixSlashes(atFile))
command = allArgs.joinToString(" ") + " " + info.sourceFiles.joinToString(" ")
val process = pb.start()
@@ -118,7 +119,7 @@ class JavaCompiler @Inject constructor(val jvmCompiler: JvmCompiler, val kobaltL
-> it.compilerFlagsFor(project, context, currentFlags, suffixesBeingCompiled) }
FlagContributor(it.flagPriority, closure)
}
- return run(project, context, info, jvm.javacExecutable!!,
+ return run(project, context, info, JavaInfo.create(File(SystemProperties.javaBase)).javacExecutable!!,
compilerUtils.compilerFlags(project, context, info, adapters))
}
@@ -129,7 +130,7 @@ class JavaCompiler @Inject constructor(val jvmCompiler: JvmCompiler, val kobaltL
-> it.docFlagsFor(project, context, currentFlags, suffixesBeingCompiled) }
FlagContributor(it.flagPriority, closure)
}
- return run(project, context, info, jvm.javadocExecutable!!,
+ return run(project, context, info, JavaInfo.create(File(SystemProperties.javaBase)).javadocExecutable!!,
compilerUtils.compilerFlags(project, context, info, adapters))
}
}
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/java/JavaPlugin.kt b/src/main/kotlin/com/beust/kobalt/plugin/java/JavaPlugin.kt
index 0b4d2e4b..9f6108d2 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/java/JavaPlugin.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/java/JavaPlugin.kt
@@ -44,18 +44,9 @@ class JavaPlugin @Inject constructor(val javaCompiler: JavaCompiler, override va
// IDocFlagContributor
override fun docFlagsFor(project: Project, context: KobaltContext, currentFlags: List,
suffixesBeingCompiled: List): List {
- val config = javadocConfigurations[project.name]
- return if (config == null || config.args.isEmpty()) DEFAULT_JAVADOC_ARGS
- else config.args
+ return listOf("-d", "javadoc", "-Xdoclint:none", "-Xmaxerrs", "1", "-quiet")
}
- val DEFAULT_JAVADOC_ARGS = listOf("-d", "javadoc", "-Xdoclint:none", "-Xmaxerrs", "1", "-quiet")
-
- val javadocConfigurations = hashMapOf()
-
- fun addJavadocConfiguration(project: Project, configuration: JavadocConfig)
- = javadocConfigurations.put(project.name, configuration)
-
// ICompilerContributor
val compiler = CompilerDescription(PLUGIN_NAME, "java", SOURCE_SUFFIXES, javaCompiler)
@@ -86,12 +77,4 @@ fun Project.javaCompiler(init: JavaConfig.() -> Unit) =
JavaConfig(this).also { config ->
config.init()
(Kobalt.findPlugin(JavaPlugin.PLUGIN_NAME) as JavaPlugin).addConfiguration(this, config)
- }
-
-@Directive
-fun Project.javadoc(init: JavadocConfig.() -> Unit) =
- JavadocConfig(this).also { config ->
- config.init()
- (Kobalt.findPlugin(JavaPlugin.PLUGIN_NAME) as JavaPlugin).addJavadocConfiguration(this, config)
- }
-
+ }
\ No newline at end of file
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/java/JavadocConfig.kt b/src/main/kotlin/com/beust/kobalt/plugin/java/JavadocConfig.kt
deleted file mode 100644
index 7129dcaa..00000000
--- a/src/main/kotlin/com/beust/kobalt/plugin/java/JavadocConfig.kt
+++ /dev/null
@@ -1,603 +0,0 @@
-package com.beust.kobalt.plugin.java
-
-import com.beust.kobalt.api.Project
-import com.google.inject.Singleton
-import java.io.BufferedReader
-import java.io.File
-import java.io.InputStream
-import java.io.InputStreamReader
-import java.util.concurrent.TimeUnit
-
-@Singleton
-class JavadocConfig(val project: Project) {
- val args = arrayListOf("-Xdoclint:none", "-Xmaxerrs", "1", "-quiet")
-
- private fun removeArg(match: String, startsWith: Boolean = false, pair: Boolean = false) {
- val it = args.iterator()
- while (it.hasNext()) {
- val next = it.next()
- var removed = false
- if (startsWith) {
- if (next.startsWith(match)) {
- it.remove()
- removed = true
- }
- } else if (next == match) {
- it.remove()
- removed = true
- }
- // If it's a pair, delete the next arg too.
- if (pair && removed && it.hasNext()) {
- it.next()
- it.remove()
- }
- }
- }
-
- private fun addInt(option: String, value: Int): Int {
- args.add("-$option")
- args.add(value.toString())
- return value
- }
-
- private fun addBoolean(option: String, value: Boolean): Boolean {
- args.remove("-$option")
- if (value) {
- args.add("-$option")
- }
- return value
- }
-
- private fun addString(option: String, value: String): String {
- if (value.isNotEmpty()) {
- args.add("-$option")
- args.add("\"$value\"")
- }
- return value
- }
-
- private fun addStrings(option: String, vararg value: String) {
- value.forEach {
- addString(option, it)
- }
- }
-
- private fun addPair(option: String, first: String, second: String) {
- if (first.isNotEmpty() && second.isNotEmpty()) {
- args.add("-$option")
- args.add("\"$first\"")
- args.add("\"$second\"")
- }
- }
-
- private fun addFile(option: String, value: String): String {
- val f = File(value)
- if (f.exists()) {
- args.add("-$option")
- args.add("\"${f.absolutePath}\"")
- }
- return value
- }
-
- /**
- * Set arguments manually.
- */
- fun args(vararg options: String) = args.addAll(options)
-
- //
- // Jvm Options
- //
-
- /**
- * @see -Xdoclint
- */
- var docLint: String = "none"
- set(value) {
- removeArg("-Xdoclint:", startsWith = true)
- addString("Xdoclint:", value)
- }
-
- /**
- * @see -Xmaxerrs
- */
- var maxErrs: Int = 1
- set(value) {
- removeArg("-Xmaxerrs", startsWith = true, pair = true)
- addInt("Xmaxerrs", value)
- }
-
- /**
- * @see -Xmaxwarns
- */
- var maxWarns: Int = 1
- set(value) {
- removeArg("-Xmaxwarns", startsWith = true, pair = true)
- addInt("Xmaxwarns", value)
- }
-
- //
- // Javadoc Options
- //
-
- /**
- * @see -overview
- */
- var overview: String = ""
- set(value) {
- addFile("overview", value)
- }
-
- /**
- * @see -public
- */
- var public: Boolean = false
- set(value) {
- addBoolean("public", value)
- }
-
- /**
- * @see -protected
- */
- var protected: Boolean = false
- set(value) {
- addBoolean("protected", value)
- }
-
- /**
- * @see -pakage
- */
- var pkg: Boolean = false
- set(value) {
- addBoolean("package", pkg)
- }
-
- /**
- * @see -private
- */
- var private: Boolean = false
- set(value) {
- addBoolean("private", private)
- }
-
- /**
- * @see -doclet
- */
- var doclet: String = ""
- set(value) {
- addString("doclet", value)
- }
-
- /**
- * @see -docletpath
- */
- var docletPath: String = ""
- set(value) {
- addString("docletpath", value)
- }
-
- /**
- * @see -source
- */
- var source: String = ""
- set(value) {
- addString("source", source)
- }
-
- /**
- * @see -sourcepath
- */
- var sourcePath: String = ""
- set(value) {
- addString("sourcepath", value)
- }
-
- /**
- * @see -classpath
- */
- var classPath: String = ""
- set(value) {
- addString("classpath", value)
- }
-
- /**
- * @see -subpackages
- */
- var subPackages: String = ""
- set(value) {
- addString("subpackages", value)
- }
-
- /**
- * @see -exclude
- */
- var exclude: String = ""
- set(value) {
- addString("exclude", value)
- }
-
- /**
- * @see -bootClassPath
- */
- var bootClassPath: String = ""
- set(value) {
- addString("bootclasspath", value)
- }
-
- /**
- * @see -extdirs
- */
- var extDirs: String = ""
- set(value) {
- addString("extdirs", value)
- }
-
- /**
- * @see -verbose
- */
- var verbose: Boolean = false
- set(value) {
- addBoolean("verbose", value)
- }
-
- /**
- * @see -quiet
- */
- var quiet: Boolean = true
- set(value) {
- addBoolean("quiet", value)
- }
-
- /**
- * @see -breakiterator
- */
- var breakIterator: Boolean = false
- set(value) {
- addBoolean("breakiterator", value)
- }
-
- /**
- * @see -locale
- */
- var locale: String = ""
- set(value) {
- addString("locale", value)
- }
-
- /**
- * @see -encoding
- */
- var encoding: String = ""
- set(value) {
- addString("encoding", value)
- }
-
- /**
- * @see -Jflag
- */
- var jFlag: String = ""
- set(value) {
- addString("J-", value)
- }
-
- //
- // Standard Doclet
- //
-
- /**
- * @see -use
- */
- var use: Boolean = false
- set(value) {
- addBoolean("use", value)
- }
-
- /**
- * @see -version
- */
- var version: Boolean = false
- set(value) {
- addBoolean("version", value)
- }
-
- /**
- * @see -author
- */
- var author: Boolean = false
- set(value) {
- addBoolean("author", value)
- }
-
- /**
- * @see -splitindex
- */
- var splitIndex: Boolean = false
- set(value) {
- addBoolean("splitindex", value)
- }
-
- /**
- * Set both the [windowTitle] and [docTitle]
- */
- var title: String = ""
- set(value) {
- windowTitle = value
- docTitle = value
- }
-
- /**
- * @see -windowtitle
- */
- var windowTitle: String = ""
- set(value) {
- addString("windowtitle", value)
- }
-
- /**
- * @see -doctitle
- */
- var docTitle: String = ""
- set(value) {
- addString("doctitle", value)
- }
-
- /**
- * @see -header
- */
- var header: String = ""
- set(value) {
- addString("header", value)
- }
-
- /**
- * @see -footer
- */
- var footer: String = ""
- set(value) {
- addString("footer", value)
- }
-
- /**
- * @see -top
- */
- var top: String = ""
- set(value) {
- addString("top", value)
- }
-
- /**
- * @see -bottom
- */
- var bottom: String = ""
- set(value) {
- addString("bottom", value)
- }
-
- /**
- * @see -linksource
- */
- var linkSource: Boolean = false
- set(value) {
- addBoolean("linksource", value)
- }
-
- /**
- * @see -nodeprecated
- */
- var noDeprecated: Boolean = false
- set(value) {
- addBoolean("nodeprecated", value)
- }
-
- /**
- * @see -nodeprecatedlist
- */
- var noDeprecatedList: Boolean = false
- set(value) {
- addBoolean("nodeprecatedlist", value)
- }
-
- /**
- * @see -nosince
- */
- var noSince: Boolean = false
- set(value) {
- addBoolean("nosince", value)
- }
-
- /**
- * @see -notree
- */
- var noTree: Boolean = false
- set(value) {
- addBoolean("notree", value)
- }
-
- /**
- * @see -noindex
- */
- var noIndex: Boolean = false
- set(value) {
- addBoolean("noindex", value)
- }
-
- /**
- * @see -nohelp
- */
- var noHelp: Boolean = false
- set(value) {
- addBoolean("nohelp", value)
- }
-
- /**
- * @see -nonavbar
- */
- var noNavBar: Boolean = false
- set(value) {
- addBoolean("nonavbar", value)
- }
-
- /**
- * @see -helpfile
- */
- var helpFile: String = ""
- set(value) {
- addFile("helpfile", value)
- }
-
- /**
- * @see -stylesheet
- */
- var stylesheet: String = ""
- set(value) {
- addFile("stylesheet", value)
- }
-
- /**
- * @see -serialwarn
- */
- var serialWarn: Boolean = false
- set(value) {
- addBoolean("serialwarn", value)
- }
-
- /**
- * @see -charset
- */
- var charSet: String = ""
- set(value) {
- addString("charset", value)
- }
-
- /**
- * @see -docencoding
- */
- var docEncoding: String = ""
- set(value) {
- addString("docencoding", value)
- }
-
- /**
- * @see -keywords
- */
- var keywords: Boolean = false
- set(value) {
- addBoolean("keywords", value)
- }
-
- /**
- * @see -tagletpath
- */
- var tagletPath: String = ""
- set(value) {
- addString("tagletpath", value)
- }
-
- /**
- * @see -docfilessubdirs
- */
- var docFilesSubDirs: Boolean = false
- set(value) {
- addBoolean("docfilessubdirs", value)
- }
-
- /**
- * @see -excludedocfilessubdir
- */
- var excludeDocFilesSubDir: String = ""
- set(value) {
- addString("excludedocfilessubdir", value)
- }
-
- /**
- * @see -noqualifiers
- */
- var noQualifiers: String = ""
- set(value) {
- addString("noqualifier", value)
- }
-
- /**
- * @see -notimestamp
- */
- var noTimestamp: Boolean = false
- set(value) {
- addBoolean("notimestamp", value)
- }
-
- /**
- * @see -nocomment
- */
- var noComment: Boolean = false
- set(value) {
- addBoolean("nocomment", value)
- }
-
- /**
- * @see -sourcetab
- */
- var sourceTab: String = ""
- set(value) {
- addString("sourcetab", value)
- }
-
- /**
- * @see -group
- */
- fun group(groupHeading: String, packagePattern: String) = addPair("group", groupHeading, packagePattern)
-
- /**
- * @see -linkoffline
- */
- fun linkOffline(extdocURL: String, packagelistLoc: String) = addPair("linkoffline", extdocURL, packagelistLoc)
-
- /**
- * @see -link
- */
- fun links(vararg links: String) = addStrings("link", *links)
-
- /**
- * @see -tag
- */
- fun tags(vararg tags: String) = addStrings("tag", *tags)
-
- /**
- * @see -taglets
- */
- fun taglets(vararg taglets: String) = addStrings("taglet", *taglets)
-}
-
-fun main(args: Array) {
- fun fromStream(ins: InputStream): List {
- val result = arrayListOf()
- val br = BufferedReader(InputStreamReader(ins))
- var line = br.readLine()
-
- while (line != null) {
- result.add(line)
- println(line)
- line = br.readLine()
- }
-
- return result
- }
-
- val config = JavadocConfig(Project())
- config.title = "This is a test."
- config.verbose = true
- config.quiet = false
- config.links("http://docs.oracle.com/javase/8/docs/api/")
- config.args.add(0, ".\\kobaltBuild\\docs\\javadoc")
- config.args.add(0, "-d")
- config.args.add(0, "javadoc")
- config.args.add(".\\modules\\wrapper\\src\\main\\java\\com\\beust\\kobalt\\wrapper\\Config.java")
- config.args.add(".\\modules\\wrapper\\src\\main\\java\\com\\beust\\kobalt\\wrapper\\Main.java")
-
- println(config.args.joinToString(" "))
-
- val pb = ProcessBuilder().command(config.args.toList())
- pb.directory(File("."))
- val proc = pb.start()
- val err = proc.waitFor(30, TimeUnit.SECONDS)
- val stdout = if (proc.inputStream.available() > 0) fromStream(proc.inputStream) else emptyList()
- val stderr = if (proc.errorStream.available() > 0) fromStream(proc.errorStream) else emptyList()
-}
\ No newline at end of file
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/kotlin/KotlinCompiler.kt b/src/main/kotlin/com/beust/kobalt/plugin/kotlin/KotlinCompiler.kt
index c1429910..5fa6af71 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/kotlin/KotlinCompiler.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/kotlin/KotlinCompiler.kt
@@ -8,12 +8,10 @@ import com.beust.kobalt.maven.dependency.FileDependency
import com.beust.kobalt.misc.*
import org.jetbrains.kotlin.cli.common.ExitCode
import org.jetbrains.kotlin.cli.common.arguments.K2JVMCompilerArguments
-import org.jetbrains.kotlin.cli.common.arguments.parseCommandLineArguments
import org.jetbrains.kotlin.cli.common.messages.CompilerMessageLocation
import org.jetbrains.kotlin.cli.common.messages.CompilerMessageSeverity
import org.jetbrains.kotlin.cli.common.messages.MessageCollector
import org.jetbrains.kotlin.cli.jvm.K2JVMCompiler
-import org.jetbrains.kotlin.config.LanguageFeature
import org.jetbrains.kotlin.config.Services
import org.jetbrains.kotlin.incremental.ICReporter
import org.jetbrains.kotlin.incremental.makeIncrementally
@@ -37,8 +35,7 @@ class KotlinCompiler @Inject constructor(
val settings: KobaltSettings,
val jvmCompiler: JvmCompiler,
val compilerUtils: CompilerUtils,
- val kobaltLog: ParallelLogger,
- val jvm: Jvm) {
+ val kobaltLog: ParallelLogger) {
val compilerAction = object: ICompilerAction {
override fun compile(project: Project?, info: CompilerActionInfo): TaskResult {
@@ -47,16 +44,14 @@ class KotlinCompiler @Inject constructor(
var filesToCompile = 0
if (! info.outputDir.path.endsWith("ript.jar")) {
// Don't display the message if compiling Build.kt
- if (info.sourceFiles.isNotEmpty()) {
- filesToCompile =
- info.sourceFiles.map(::File).map {
- if (it.isDirectory) KFiles.findRecursively(it).size else 1
- }.reduce { a, b ->
- a + b
- }
- kobaltLog.log(projectName ?: "", 1,
- " Kotlin $version compiling " + Strings.pluralizeAll(filesToCompile, "file"))
- }
+ filesToCompile =
+ info.sourceFiles.map(::File).map {
+ if (it.isDirectory) KFiles.findRecursively(it).size else 1
+ }.reduce { a, b ->
+ a + b
+ }
+ kobaltLog.log(projectName ?: "", 1,
+ " Kotlin $version compiling " + Strings.pluralizeAll(filesToCompile, "file"))
}
val cp = compilerFirst(info.dependencies.map { it.jarFile.get() })
val infoDir = info.directory
@@ -74,25 +69,35 @@ class KotlinCompiler @Inject constructor(
File(outputDir).parentFile.mkdirs()
}
val classpath = cp.joinToString(File.pathSeparator)
+ val allArgs = arrayListOf(
+ "-d", outputDir,
+ "-classpath", classpath,
+ *(info.compilerArgs.toTypedArray()),
+ *(info.sourceFiles.toTypedArray())
+ )
+
+ // Get rid of annoying and useless warning
+ if (! info.compilerArgs.contains("-no-stdlib")) {
+ allArgs.add("-no-stdlib")
+ }
// If the Kotlin compiler version in settings.xml is different from the default, we
// need to spawn a Kotlin compiler in a separate process. Otherwise, we can just invoke
// the K2JVMCompiler class directly
val actualVersion = kotlinVersion(project)
- return if (settings.kobaltCompilerSeparateProcess || actualVersion != Constants.KOTLIN_COMPILER_VERSION
- || info.compilerSeparateProcess) {
- invokeCompilerInSeparateProcess(classpath, info, actualVersion, project)
+ if (settings.kobaltCompilerSeparateProcess || actualVersion != Constants.KOTLIN_COMPILER_VERSION) {
+ return invokeCompilerInSeparateProcess(classpath, info, actualVersion, project)
} else {
- invokeCompilerDirectly(project, projectName ?: "kobalt-" + Random().nextInt(), outputDir,
+ return invokeCompilerDirectly(project, projectName ?: "kobalt-" + Random().nextInt(), outputDir,
info, classpath, filesToCompile)
}
}
private fun invokeCompilerInSeparateProcess(classpath: String, info: CompilerActionInfo,
compilerVersion: String, project: Project?): TaskResult {
- val java = jvm.javaExecutable
+ val java = JavaInfo.create(File(SystemProperties.javaBase)).javaExecutable
val compilerClasspath = compilerDep(compilerVersion).jarFile.get().path + File.pathSeparator +
compilerEmbeddableDependencies(null, compilerVersion).map { it.jarFile.get().path }
@@ -102,37 +107,24 @@ class KotlinCompiler @Inject constructor(
.filterNotNull()
.joinToString(" ")
- val infoDir = info.directory
-
- val outputDir =
- if (infoDir != null) {
- KFiles.joinDir(infoDir, info.outputDir.path)
- } else {
- info.outputDir.path
- }
-
- val xFlagsArray = xFlagsString.split(" ").toTypedArray()
+ val xFlagsArray = xFlagsString.split(" ").toTypedArray() ?: emptyArray()
val newArgs = listOf(
"-classpath", compilerClasspath,
K2JVMCompiler::class.java.name,
- *info.compilerArgs.toTypedArray(),
"-classpath", classpath,
- "-d", outputDir,
+ "-d", info.outputDir.absolutePath,
*xFlagsArray,
*info.sourceFiles.toTypedArray())
.filter { ! it.isEmpty() }
- log(2, " Invoking separate kotlinc:\n " + java!!.absolutePath + " " + newArgs.joinToString(" "))
+ log(2, " Invoking separate kotlinc:\n " + java!!.absolutePath + " " + newArgs.joinToString())
val result = NewRunCommand(RunCommandInfo().apply {
command = java.absolutePath
args = newArgs
directory = File(".")
-// // The Kotlin compiler issues warnings on stderr :-(
- useErrorStreamAsErrorIndicator = false
-// containsErrors = {
-// errors: List -> errors.any { it.contains("rror")}
-// }
+ // The Kotlin compiler issues warnings on stderr :-(
+ containsErrors = { errors: List -> errors.any { it.contains("rror")} }
}).invoke()
return TaskResult(result == 0, errorMessage = "Error while compiling")
}
@@ -143,19 +135,18 @@ class KotlinCompiler @Inject constructor(
val friends = info.friendPaths.toTypedArray()
// Collect the compiler args from kotlinCompiler{} and from settings.xml and parse them
- val args2 =
- info.compilerArgs +
- (settings.kobaltCompilerFlags?.split(" ") ?: listOf())
+ val args2 = (kotlinConfig(project)?.args ?: arrayListOf()) +
+ (settings.kobaltCompilerFlags?.split(" ") ?: listOf())
val args = K2JVMCompilerArguments()
val compiler = K2JVMCompiler()
- parseCommandLineArguments(args2, args)
+ compiler.parseArguments(args2.toTypedArray(), args)
// Override important arguments with our values
args.apply {
moduleName = projectName
destination = outputDir
classpath = classpathString
- freeArgs = sourceFiles.toMutableList()
+ freeArgs = sourceFiles
friendPaths = friends
}
@@ -179,12 +170,12 @@ class KotlinCompiler @Inject constructor(
"single-module" -> args.singleModule = true
"load-builtins-from-dependencies" -> args.loadBuiltInsFromDependencies = true
- "coroutines=enable" -> args.coroutinesState = LanguageFeature.State.ENABLED.name
- "coroutines=warn" -> args.coroutinesState = LanguageFeature.State.ENABLED_WITH_WARNING.name
- "coroutines=error" -> args.coroutinesState = LanguageFeature.State.ENABLED_WITH_ERROR.name
+ "coroutines=enable" -> args.coroutinesEnable = true
+ "coroutines=warn" -> args.coroutinesWarn = true
+ "coroutines=error" -> args.coroutinesError = true
"no-inline" -> args.noInline = true
"multi-platform" -> args.multiPlatform = true
-// "no-check-impl" -> args.noCheckImpl = true
+ "no-check-impl" -> args.noCheckImpl = true
else -> warn("Unknown Kotlin compiler flag found in config.xml: $it")
}
}
@@ -194,27 +185,13 @@ class KotlinCompiler @Inject constructor(
fun logk(level: Int, message: CharSequence) = kobaltLog.log(projectName, level, message)
- fun pluginClasspaths(args: K2JVMCompilerArguments) : String {
- var result = ""
- args.pluginClasspaths?.forEach {
- result += " -Xplugin " + it
- }
- args.pluginOptions?.let {
- result += " -P "
- result += it.joinToString(",")
- }
- return result
- }
-
- logk(2, " Invoking K2JVMCompiler with arguments: kotlinc "
+ logk(2, " Invoking K2JVMCompiler with arguments:"
+ if (args.skipMetadataVersionCheck) " -Xskip-metadata-version-check" else ""
- + " -d " + args.destination
- + " -classpath " + args.classpath
- + pluginClasspaths(args)
- + " " + sourceFiles.joinToString(" "))
- logk(2, " Additional kotlinc arguments: "
+ " -moduleName " + args.moduleName
- + " -friendPaths " + args.friendPaths?.joinToString(";"))
+ + " -d " + args.destination
+ + " -friendPaths " + args.friendPaths.joinToString(";")
+ + " -classpath " + args.classpath
+ + " " + sourceFiles.joinToString(" "))
val collector = object : MessageCollector {
override fun clear() {
throw UnsupportedOperationException("not implemented")
@@ -225,7 +202,7 @@ class KotlinCompiler @Inject constructor(
}
fun dump(location: CompilerMessageLocation?, s: String) =
- if (location?.lineContent != null) {
+ if (location != null && location.lineContent != null) {
with(location) {
"$lineContent\n$path:$line:$column $s"
}
@@ -233,13 +210,12 @@ class KotlinCompiler @Inject constructor(
s
}
- override fun report(severity: CompilerMessageSeverity, message: String,
- location: CompilerMessageLocation?) {
+ override fun report(severity: CompilerMessageSeverity,
+ message: String, location: CompilerMessageLocation) {
if (severity.isError) {
"Couldn't compile file: ${dump(location, message)}".let { fullMessage ->
- error(fullMessage)
- val ex = KobaltException(fullMessage)
- throw ex
+ System.err.println(fullMessage)
+ throw KobaltException(fullMessage)
}
} else if (severity == CompilerMessageSeverity.WARNING && KobaltLogger.LOG_LEVEL >= 2) {
warn(dump(location, message))
@@ -248,27 +224,29 @@ class KotlinCompiler @Inject constructor(
}
}
}
-//
-// System.setProperty("kotlin.incremental.compilation", "true")
-// // TODO: experimental should be removed as soon as it becomes standard
-// System.setProperty("kotlin.incremental.compilation.experimental", "true")
- return if (cliArgs.noIncrementalKotlin || Kobalt.context?.internalContext?.noIncrementalKotlin ?: false) {
- log(2, " Kotlin incremental compilation is disabled")
- val duration = benchmarkMillis {
- compiler.exec(collector, Services.Builder().build(), args)
+ System.setProperty("kotlin.incremental.compilation", "true")
+ // TODO: experimental should be removed as soon as it becomes standard
+ System.setProperty("kotlin.incremental.compilation.experimental", "true")
+
+ val result =
+ if (cliArgs.noIncrementalKotlin || Kobalt.context?.internalContext?.noIncrementalKotlin ?: false) {
+ log(2, " Kotlin incremental compilation is disabled")
+ val duration = benchmarkMillis {
+ compiler.exec(collector, Services.Builder().build(), args)
+ }
+ log(1, " Regular compilation time: ${duration.first} ms")
+ TaskResult(duration.second == ExitCode.OK)
+ } else {
+ log(1, " Kotlin incremental compilation is enabled")
+ val start = System.currentTimeMillis()
+ val duration = benchmarkMillis {
+ compileIncrementally(filesToCompile, sourceFiles, outputDir, info, args, collector)
+ }
+ log(1, " Incremental compilation time: ${duration.first} ms")
+ TaskResult()
}
- log(1, " Regular compilation time: ${duration.first} ms")
- TaskResult(duration.second == ExitCode.OK)
- } else {
- log(1, " Kotlin incremental compilation is enabled")
- //val start = System.currentTimeMillis()
- val duration = benchmarkMillis {
- compileIncrementally(filesToCompile, sourceFiles, outputDir, info, args, collector)
- }
- log(1, " Incremental compilation time: ${duration.first} ms")
- TaskResult()
- }
+ return result
}
private fun compileIncrementally(filesToCompile: Int, sourceFiles: List, outputDir: String?,
@@ -382,7 +360,8 @@ class KotlinCompiler @Inject constructor(
= dependencyManager.create("org.jetbrains" + ".kotlin:kotlin-compiler-embeddable:$version")
fun compilerEmbeddableDependencies(project: Project?, version: String): List {
- return dependencyManager.transitiveClosure(listOf(compilerDep(version)), requiredBy = project?.name ?: "")
+ val deps = dependencyManager.transitiveClosure(listOf(compilerDep(version)), requiredBy = project?.name ?: "")
+ return deps
}
/**
@@ -391,8 +370,7 @@ class KotlinCompiler @Inject constructor(
* JvmCompilerPlugin#createCompilerActionInfo instead
*/
fun compile(project: Project?, context: KobaltContext?, compileDependencies: List,
- otherClasspath: List, sourceFiles: List, outputDir: File, args: List,
- compilerSeparateProcess: Boolean) : TaskResult {
+ otherClasspath: List, sourceFiles: List, outputDir: File, args: List) : TaskResult {
val executor = executors.newExecutor("KotlinCompiler", 10)
@@ -415,15 +393,13 @@ class KotlinCompiler @Inject constructor(
if (project != null) {
listOf(KFiles.joinDir(project.directory, project.buildDirectory, KFiles.CLASSES_DIR))
} else {
- emptyList()
+ emptyList()
}
val info = CompilerActionInfo(project?.directory, dependencies, sourceFiles, listOf("kt"), outputDir, args,
- friendPaths, context?.internalContext?.forceRecompile ?: false, compilerSeparateProcess)
+ friendPaths, context?.internalContext?.forceRecompile ?: false)
- val compilerFlags =
- if (context != null) compilerUtils.sourceCompilerFlags(project, context, info)
- else emptyList()
- return jvmCompiler.doCompile(project, context, compilerAction, info, compilerFlags)
+ return jvmCompiler.doCompile(project, context, compilerAction, info,
+ if (context != null) compilerUtils.sourceCompilerFlags(project, context, info) else emptyList())
}
}
@@ -434,7 +410,6 @@ class KConfiguration @Inject constructor(val compiler: KotlinCompiler){
var output: File by Delegates.notNull()
val args = arrayListOf()
var noIncrementalKotlin = false
- var compilerSeparateProcess = false
fun sourceFiles(s: String) = source.add(s)
@@ -449,8 +424,7 @@ class KConfiguration @Inject constructor(val compiler: KotlinCompiler){
fun compile(project: Project? = null, context: KobaltContext? = null) : TaskResult {
val saved = context?.internalContext?.noIncrementalKotlin ?: false
if (context != null) context.internalContext.noIncrementalKotlin = noIncrementalKotlin
- val result = compiler.compile(project, context, dependencies, classpath, source, output, args,
- compilerSeparateProcess)
+ val result = compiler.compile(project, context, dependencies, classpath, source, output, args)
if (context != null) context.internalContext.noIncrementalKotlin = saved
return result
}
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/kotlin/KotlinPlugin.kt b/src/main/kotlin/com/beust/kobalt/plugin/kotlin/KotlinPlugin.kt
index 886f3537..220be8a7 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/kotlin/KotlinPlugin.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/kotlin/KotlinPlugin.kt
@@ -83,7 +83,6 @@ class KotlinPlugin @Inject constructor(val executors: KobaltExecutors, val depen
sourceFiles(info.sourceFiles)
compilerArgs(info.compilerArgs)
output = info.outputDir
- compilerSeparateProcess = info.compilerSeparateProcess
}.compile(project, context)
}
@@ -99,10 +98,9 @@ class KotlinPlugin @Inject constructor(val executors: KobaltExecutors, val depen
// IClasspathContributor
override fun classpathEntriesFor(project: Project?, context: KobaltContext): List =
- if (project == null ||
- context.pluginInfo.plugins.any { it is KotlinPlugin && it.settings.kobaltCompilerVersion == null }) {
+ if (project == null || accept(project)) {
// All Kotlin projects automatically get the Kotlin runtime added to their class path
- listOf(kotlinJarFiles.stdlib)
+ listOf(kotlinJarFiles.stdlib, kotlinJarFiles.runtime)
.map { FileDependency(it.absolutePath) }
} else {
emptyList()
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/osgi/OsgiPlugin.kt b/src/main/kotlin/com/beust/kobalt/plugin/osgi/OsgiPlugin.kt
deleted file mode 100644
index 83ae5228..00000000
--- a/src/main/kotlin/com/beust/kobalt/plugin/osgi/OsgiPlugin.kt
+++ /dev/null
@@ -1,118 +0,0 @@
-package com.beust.kobalt.plugin.osgi
-
-import aQute.bnd.osgi.Analyzer
-import com.beust.kobalt.TaskResult
-import com.beust.kobalt.api.*
-import com.beust.kobalt.api.annotation.Directive
-import com.beust.kobalt.archive.Archives
-import com.beust.kobalt.archive.MetaArchive
-import com.beust.kobalt.maven.DependencyManager
-import com.beust.kobalt.misc.KFiles
-import com.beust.kobalt.plugin.packaging.PackagingPlugin
-import com.google.common.reflect.ClassPath
-import com.google.inject.Inject
-import com.google.inject.Singleton
-import java.io.ByteArrayOutputStream
-import java.io.File
-import java.net.URLClassLoader
-import java.nio.file.*
-import java.time.LocalDate
-import java.time.format.DateTimeFormatter
-import java.util.jar.JarFile
-
-/**
- * Generate OSGi attributes in the MANIFEST.MF if an osgi{} directive was found in the project.
- */
-@Singleton
-class OsgiPlugin @Inject constructor(val configActor: ConfigActor, val taskContributor: TaskContributor,
- val dependencyManager: DependencyManager)
- : BasePlugin(), ITaskContributor by taskContributor, IConfigActor by configActor {
- companion object {
- const val PLUGIN_NAME = "Osgi"
- }
- override val name: String = PLUGIN_NAME
-
- override fun apply(project: Project, context: KobaltContext) {
- super.apply(project, context)
-
- configurationFor(project)?.let { config ->
- taskContributor.addTask(this, project, "generateOsgiManifest",
- description = "Generate the OSGi information in the manifest",
- group = "build",
- alwaysRunAfter = listOf(PackagingPlugin.TASK_ASSEMBLE),
- runTask = { generateManifest(project, context) })
- }
- }
-
- private fun generateManifest(project: Project, context: KobaltContext): TaskResult {
- val jarName = project.projectProperties.get(Archives.JAR_NAME) as String
- val jarFile = File(KFiles.libsDir(project), jarName)
- val cp = ClassPath.from(URLClassLoader(arrayOf(jarFile.toURI().toURL()), null))
-
- val packages = cp.allClasses.map { it.packageName }.distinct()
- val exportPackageLine = packages.map {
- it + ";version=\"" + project.version + "\""
- }.joinToString(",")
-
- val toFile = Files.createTempFile(null, ".jar")
- val analyzer = Analyzer().apply {
- jar = aQute.bnd.osgi.Jar(jarName)
- val dependencies = project.compileDependencies + project.compileRuntimeDependencies
- dependencyManager.calculateDependencies(project, context, passedDependencies = dependencies).forEach {
- addClasspath(it.jarFile.get())
- }
- setProperty("Build-Date", LocalDate.now().format(DateTimeFormatter.ofPattern("y-MM-dd")))
- setProperty(Analyzer.BUNDLE_VERSION, project.version)
- setProperty(Analyzer.BUNDLE_NAME, project.group + "." + project.artifactId)
- setProperty(Analyzer.BUNDLE_DESCRIPTION, project.description)
- setProperty(Analyzer.IMPORT_PACKAGE, "*")
- setProperty(Analyzer.EXPORT_PACKAGE, exportPackageLine)
- project.pom?.let { pom ->
- if (pom.licenses.any()) {
- setProperty(Analyzer.BUNDLE_LICENSE, pom.licenses[0].url)
- }
- }
- }
-
- analyzer.calcManifest().let { manifest ->
- val lines2 = ByteArrayOutputStream().use { baos ->
- manifest.write(baos)
- String(baos.toByteArray())
- }
-
- context.logger.log(project.name, 2, " Generated manifest:\n$lines2")
-
- //
- // Update or create META-INF/MANIFEST.MF
- //
- KFiles.copy(Paths.get(jarFile.toURI()), Paths.get(toFile.toUri()))
-
- val fileSystem = FileSystems.newFileSystem(toFile, null)
- fileSystem.use { fs ->
- JarFile(jarFile).use { jf ->
- val mf = jf.getEntry(MetaArchive.MANIFEST_MF)
- if (mf == null) {
- Files.createDirectories(fs.getPath("META-INF/"))
- }
- val jarManifest = fs.getPath(MetaArchive.MANIFEST_MF)
- Files.write(jarManifest, listOf(lines2),
- if (mf != null) StandardOpenOption.APPEND else StandardOpenOption.CREATE)
- }
- }
- Files.copy(Paths.get(toFile.toUri()), Paths.get(jarFile.toURI()), StandardCopyOption.REPLACE_EXISTING)
- return TaskResult()
- }
- }
-}
-
-class OsgiConfig
-
-@Directive
-fun Project.osgi(init: OsgiConfig.() -> Unit) {
- OsgiConfig().let {
- it.init()
- (Kobalt.findPlugin(OsgiPlugin.PLUGIN_NAME) as OsgiPlugin).addConfiguration(this, it)
- }
-}
-
-
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/packaging/PackagingPlugin.kt b/src/main/kotlin/com/beust/kobalt/plugin/packaging/PackagingPlugin.kt
index b7871c90..e4a79c70 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/packaging/PackagingPlugin.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/packaging/PackagingPlugin.kt
@@ -26,9 +26,9 @@ class PackagingPlugin @Inject constructor(val dependencyManager : DependencyMana
val executors: KobaltExecutors, val jarGenerator: JarGenerator, val warGenerator: WarGenerator,
val zipGenerator: ZipGenerator, val taskContributor: TaskContributor,
val kobaltLog: ParallelLogger,
- val pomFactory: PomGenerator.IFactory, val configActor: ConfigsActor)
- : BasePlugin(), ITaskContributor by taskContributor, IIncrementalAssemblyContributor,
- IConfigsActor by configActor {
+ val pomFactory: PomGenerator.IFactory, val configActor: ConfigActor)
+ : BasePlugin(), ITaskContributor, IIncrementalAssemblyContributor,
+ IConfigActor by configActor {
companion object {
const val PLUGIN_NAME = "Packaging"
@@ -41,6 +41,7 @@ class PackagingPlugin @Inject constructor(val dependencyManager : DependencyMana
const val PACKAGES = "packages"
const val TASK_ASSEMBLE: String = "assemble"
+ const val TASK_INSTALL: String = "install"
}
override val name = PLUGIN_NAME
@@ -55,20 +56,9 @@ class PackagingPlugin @Inject constructor(val dependencyManager : DependencyMana
taskContributor.addVariantTasks(this, project, context, "assemble", group = "build",
dependsOn = listOf("compile"),
runTask = { doTaskAssemble(project) })
-
- configurationFor(project)?.let { configs ->
- configs.forEach { config ->
- taskContributor.addTask(this, project, config.taskName,
- description = "Install to \"" + config.target + "\"",
- group = "build",
- dependsOn = listOf(PackagingPlugin.TASK_ASSEMBLE),
- runTask = { taskInstall(project, context, config) })
- taskContributor.addVariantTasks(this, project, context, config.taskName,
- dependsOn = listOf("assemble"),
- runTask = { taskInstall(project, context, config) })
- }
- }
-
+ taskContributor.addVariantTasks(this, project, context, "install",
+ dependsOn = listOf("assemble"),
+ runTask = { taskInstall(project) })
}
override fun assemble(project: Project, context: KobaltContext) : IncrementalTaskInfo {
@@ -105,7 +95,7 @@ class PackagingPlugin @Inject constructor(val dependencyManager : DependencyMana
val outputFile = jarGenerator.fullArchiveName(project, context, it.name)
outputFiles.add(outputFile)
allIncludedFiles.addAll(files)
- zipToFiles[outputFile.name] = files
+ zipToFiles[it.name] = files
}
}
}
@@ -148,7 +138,9 @@ class PackagingPlugin @Inject constructor(val dependencyManager : DependencyMana
Pair(packageConfig.zips, zipGenerator)
)
- pairs.forEach { (zips, generator) ->
+ pairs.forEach { pair ->
+ val zips = pair.first
+ val generator = pair.second
zips.forEach {
generator.generateArchive(packageConfig.project, context, it,
findFiles(generator, it))
@@ -194,7 +186,31 @@ class PackagingPlugin @Inject constructor(val dependencyManager : DependencyMana
packages.add(p)
}
- private fun taskInstall(project: Project, context: KobaltContext, config: InstallConfig) : TaskResult {
+// @Task(name = "generateOsgiManifest", alwaysRunAfter = arrayOf(TASK_ASSEMBLE))
+// fun generateManifest(project: Project): TaskResult {
+// val analyzer = Analyzer().apply {
+// jar = aQute.bnd.osgi.Jar(project.projectProperties.get(Archives.JAR_NAME) as String)
+// val dependencies = project.compileDependencies + project.compileRuntimeDependencies
+// dependencyManager.calculateDependencies(project, context, passedDependencies = dependencies).forEach {
+// addClasspath(it.jarFile.get())
+// }
+// setProperty(Analyzer.BUNDLE_VERSION, project.version)
+// setProperty(Analyzer.BUNDLE_NAME, project.group)
+// setProperty(Analyzer.BUNDLE_DESCRIPTION, project.description)
+// setProperty(Analyzer.IMPORT_PACKAGE, "*")
+// setProperty(Analyzer.EXPORT_PACKAGE, "*;-noimport:=false;version=" + project.version)
+// }
+//
+// val manifest = analyzer.calcManifest()
+// manifest.write(System.out)
+// return TaskResult()
+// }
+
+
+ @Task(name = PackagingPlugin.TASK_INSTALL, description = "Install the artifacts",
+ dependsOn = arrayOf(PackagingPlugin.TASK_ASSEMBLE))
+ fun taskInstall(project: Project) : TaskResult {
+ val config = configurationFor(project) ?: InstallConfig()
val buildDir = project.projectProperties.getString(LIBS_DIR)
val buildDirFile = File(buildDir)
if (buildDirFile.exists()) {
@@ -225,6 +241,9 @@ class PackagingPlugin @Inject constructor(val dependencyManager : DependencyMana
return TaskResult()
}
+
+ //ITaskContributor
+ override fun tasksFor(project: Project, context: KobaltContext): List = taskContributor.dynamicTasks
}
@Directive
@@ -235,7 +254,7 @@ fun Project.install(init: InstallConfig.() -> Unit) {
}
}
-class InstallConfig(var target : String = "libs", var taskName : String = "install") : IncludeFromTo()
+class InstallConfig(var target : String = "libs") : IncludeFromTo()
@Directive
fun Project.assemble(init: PackageConfig.(p: Project) -> Unit): PackageConfig = let {
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/publish/BintrayApi.kt b/src/main/kotlin/com/beust/kobalt/plugin/publish/BintrayApi.kt
index 1a80ff0e..878d0e1c 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/publish/BintrayApi.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/publish/BintrayApi.kt
@@ -15,7 +15,6 @@ import com.google.gson.Gson
import com.google.gson.JsonArray
import com.google.gson.JsonObject
import com.google.gson.TypeAdapter
-import com.google.gson.annotations.SerializedName
import com.google.gson.reflect.TypeToken
import com.google.inject.assistedinject.Assisted
import okhttp3.*
@@ -63,7 +62,7 @@ class BintrayApi @Inject constructor(val http: Http,
@Path("publish") publish: Int,
@Body file: File): Call
- class UpdateVersion(val desc: String?, @SerializedName("vcs_tag") val vcsTag: String?)
+ class UpdateVersion(val desc: String?, val vcsTag: String?)
@PATCH("/packages/{owner}/maven/{repo}/versions/{version}")
fun updateVersion(@Path("owner") owner: String,
@@ -80,12 +79,12 @@ class BintrayApi @Inject constructor(val http: Http,
// level = HttpLoggingInterceptor.Level.BASIC
// })
builder.interceptors().add(Interceptor { chain ->
- val original = chain.request()
+ val original = chain.request();
chain.proceed(original.newBuilder()
.header("Authorization", Credentials.basic(username, password))
.method(original.method(), original.body())
- .build())
+ .build());
})
val okHttpClient = builder.build()
@@ -97,29 +96,25 @@ class BintrayApi @Inject constructor(val http: Http,
.create(Api::class.java)
}
- fun validatePackage(project: Project, config: BintrayConfig) {
- val pkgName = config.name ?: project.name
- val execute = service.getPackage(org ?: username!!, pkgName).execute()
+ fun validatePackage(project: Project) {
+ val execute = service.getPackage(org ?: username!!, project.name).execute()
- if (execute.errorBody()?.string()?.contains("'$pkgName' was not found") == true) {
+ if (execute.errorBody()?.string()?.contains("'${project.name}' was not found") ?: false) {
warn("Package does not exist on bintray. Creating now.")
- val result = service.createPackage(org ?: username!!, buildPackageInfo(project, config))
+ val result = service.createPackage(org ?: username!!, buildPackageInfo(project))
.execute()
if (result.errorBody() != null) {
- throw KobaltException("Error while creating package:\n" + result.errorBody()!!.string())
+ throw KobaltException("Error while creating package:\n" + result.errorBody().string())
}
}
}
- private fun buildPackageInfo(project: Project, config: BintrayConfig): JsonObject {
- val jsonObject = JsonObject().apply {
- addNonNull("name", config.name ?: project.name)
- addNonNull("desc",
- if (project.description.isNotBlank()) project.description else project.pom?.description)
- addNonNull("vcs_url", project.pom?.scm?.url)
- addNonNull("website_url", project.url ?: project.pom?.url)
- addNonNull("issue_tracker_url", config.issueTrackerUrl)
- }
+ private fun buildPackageInfo(project: Project): JsonObject {
+ val jsonObject = JsonObject()
+ jsonObject.addNonNull("name", project.name)
+ jsonObject.addNonNull("desc", project.description)
+ jsonObject.addNonNull("vcs_url", project.pom?.scm?.url)
+ jsonObject.addNonNull("website_url", project.url)
val licenses = JsonArray()
project.pom?.licenses?.forEach {
licenses.add(it.name)
@@ -129,7 +124,7 @@ class BintrayApi @Inject constructor(val http: Http,
}
fun uploadMaven(project: Project, files: List, config: BintrayConfig): TaskResult {
- validatePackage(project, config)
+ validatePackage(project)
return upload(project, files, config, generateMd5 = true)
}
@@ -163,13 +158,13 @@ class BintrayApi @Inject constructor(val http: Http,
fun dots(total: Int, list: List, file: File? = null): String {
val spaces: String = Array(total - list.size, { " " }).joinToString("")
- return "|" + list.joinToString("") { if (it) "." else "X" } + spaces +
+ return "|" + list.map { if (it) "." else "X" }.joinToString("") + spaces +
(if (file != null) "| [ $file ]" else "|")
}
val results = arrayListOf()
val owner = org ?: username!!
- val repo = config.name ?: project.name
+ val repo = project.name
val group = project.group!!.replace('.', '/')
val artifact = project.artifactId!!
val version = project.version!!
@@ -208,7 +203,7 @@ class BintrayApi @Inject constructor(val http: Http,
return TaskResult()
} else {
- error(" Errors while uploading:\n" + errorMessages.joinToString("\n") { " $it" })
+ error(" Errors while uploading:\n" + errorMessages.map { " $it" }.joinToString("\n"))
return TaskResult(false, errorMessage = errorMessages.joinToString("\n"))
}
} else {
@@ -221,7 +216,7 @@ class BintrayApi @Inject constructor(val http: Http,
fun JsonObject.addNonNull(name: String, value: String?) {
if (value != null) {
- addProperty(name, value)
+ addProperty(name, value);
}
}
@@ -236,16 +231,20 @@ class ConverterFactory : Converter.Factory() {
override fun requestBodyConverter(type: Type, parameterAnnotations: Array,
methodAnnotations: Array,
retrofit: Retrofit?): Converter<*, RequestBody>? {
- return if (type.typeName == File::class.java.name) FileBodyConverter()
- else GsonBodyConverter()
+ val result =
+ if (type.typeName == File::class.java.name) FileBodyConverter()
+ else GsonBodyConverter()
+ return result
}
}
class GsonResponseBodyConverter(private val gson: Gson, private val adapter: TypeAdapter) : Converter {
override fun convert(value: ResponseBody): Any {
val jsonReader = gson.newJsonReader(value.charStream())
- value.use {
+ try {
return adapter.read(jsonReader)
+ } finally {
+ value.close()
}
}
}
diff --git a/src/main/kotlin/com/beust/kobalt/plugin/publish/PublishPlugin.kt b/src/main/kotlin/com/beust/kobalt/plugin/publish/PublishPlugin.kt
index c5878368..f5b1e4d0 100644
--- a/src/main/kotlin/com/beust/kobalt/plugin/publish/PublishPlugin.kt
+++ b/src/main/kotlin/com/beust/kobalt/plugin/publish/PublishPlugin.kt
@@ -47,7 +47,7 @@ class PublishPlugin @Inject constructor(val files: KFiles, val factory: PomGener
private fun autoGitTag(project: Project, uploadResult: TaskResult, config: AutoGitTagConfig?) : TaskResult {
if (config != null) {
with(config) {
- return git.maybeTagRelease(project, uploadResult, enabled, annotated, push, tag, message)
+ return git.maybeTagRelease(project, uploadResult, enabled, annotated, tag, message)
}
} else {
return TaskResult()
@@ -117,7 +117,7 @@ class PublishPlugin @Inject constructor(val files: KFiles, val factory: PomGener
val docUrl = DocUrl.PUBLISH_PLUGIN_URL
val user = localProperties.get(PROPERTY_BINTRAY_USER, docUrl)
val password = localProperties.get(PROPERTY_BINTRAY_PASSWORD, docUrl)
- val org = localProperties.getNoThrows(PROPERTY_BINTRAY_ORG)
+ val org = localProperties.getNoThrows(PROPERTY_BINTRAY_ORG, docUrl)
val jcenter = bintrayFactory.create(user, password, org)
var success = false
@@ -222,9 +222,6 @@ data class AutoGitTagConfig(val project: Project) {
@Directive
var annotated: Boolean = false
- @Directive
- var push: Boolean = true
-
@Directive
var tag : String = project.version!!
@@ -271,18 +268,9 @@ data class BintrayConfig(val project: Project) {
files.add(Pair(filePath, url))
}
- /**
- * The package name on Bintray which is not always the project name.
- */
- @Directive
- var name: String? = null
-
@Directive
var description: String? = null
- @Directive
- var issueTrackerUrl: String? = null
-
@Directive
var vcsTag: String? = null
}
diff --git a/src/main/resources/META-INF/kobalt-core-plugin.xml b/src/main/resources/META-INF/kobalt-core-plugin.xml
index 57354ff2..fbcca6c6 100644
--- a/src/main/resources/META-INF/kobalt-core-plugin.xml
+++ b/src/main/resources/META-INF/kobalt-core-plugin.xml
@@ -15,7 +15,6 @@
com.beust.kobalt.plugin.groovy.GroovyPlugin
com.beust.kobalt.internal.JvmCompilerPlugin
com.beust.kobalt.internal.BuildListeners
- com.beust.kobalt.plugin.osgi.OsgiPlugin
com.beust.kobalt.app.Templates
diff --git a/src/main/resources/kobalt.properties b/src/main/resources/kobalt.properties
index 0d568d3c..bd5e50a2 100644
--- a/src/main/resources/kobalt.properties
+++ b/src/main/resources/kobalt.properties
@@ -1 +1 @@
-kobalt.version=1.0.122
+kobalt.version=1.0.65
diff --git a/src/main/resources/templates/idea/KotlinJavaRuntime.xml b/src/main/resources/templates/idea/KotlinJavaRuntime.xml
index 3792609b..c630c0b8 100644
--- a/src/main/resources/templates/idea/KotlinJavaRuntime.xml
+++ b/src/main/resources/templates/idea/KotlinJavaRuntime.xml
@@ -1,12 +1,12 @@
-
+
-
+
\ No newline at end of file
diff --git a/src/test/kotlin/com/beust/kobalt/BaseTest.kt b/src/test/kotlin/com/beust/kobalt/BaseTest.kt
index 3930f318..51bbcf5e 100644
--- a/src/test/kotlin/com/beust/kobalt/BaseTest.kt
+++ b/src/test/kotlin/com/beust/kobalt/BaseTest.kt
@@ -9,7 +9,6 @@ import com.beust.kobalt.internal.KobaltPluginXml
import com.beust.kobalt.internal.PluginInfo
import com.beust.kobalt.internal.build.SingleFileBuildSources
import com.beust.kobalt.misc.KFiles
-import com.beust.kobalt.misc.KobaltLogger
import com.beust.kobalt.misc.log
import org.testng.annotations.BeforeClass
import org.testng.annotations.Guice
@@ -122,9 +121,6 @@ open class BaseTest(val compilerFactory: BuildFileCompiler.IFactory? = null) {
val main = Kobalt.INJECTOR.getInstance(Main::class.java)
val args = Args()
val jc = JCommander(args).apply { parse(*commandLine) }
-
- KobaltLogger.setLogLevel(args)
-
args.buildFile = KFiles.fixSlashes(project.file.absolutePath) + "/kobalt/src/Build.kt"
val result = Main.launchMain(main, jc, args, arrayOf("assemble"))
return LaunchProjectResult(project, result)
diff --git a/src/test/kotlin/com/beust/kobalt/VerifyKobaltZipTest.kt b/src/test/kotlin/com/beust/kobalt/VerifyKobaltZipTest.kt
index d0439725..c15e95d2 100644
--- a/src/test/kotlin/com/beust/kobalt/VerifyKobaltZipTest.kt
+++ b/src/test/kotlin/com/beust/kobalt/VerifyKobaltZipTest.kt
@@ -3,7 +3,6 @@ package com.beust.kobalt
import com.beust.kobalt.misc.KFiles
import com.beust.kobalt.misc.kobaltLog
import com.beust.kobalt.misc.warn
-import org.assertj.core.api.Assertions.assertThat
import org.testng.annotations.Test
import java.io.File
import java.io.FileInputStream
@@ -39,7 +38,6 @@ class VerifyKobaltZipTest : KobaltTest() {
val stream = JarInputStream(FileInputStream(zipFilePath))
var entry = stream.nextEntry
while (entry != null) {
- assertThat(entry.name).doesNotContain("\\")
if (! entry.name.startsWith(root)) {
throw AssertionError("Entries in the zip file should be under the directory $root")
}
@@ -67,7 +65,7 @@ class VerifyKobaltZipTest : KobaltTest() {
} else if (entry.name.endsWith("kobalt-wrapper.jar")) {
val ins = zipFile.getInputStream(entry)
foundWrapperJar = true
- assertExistence(ins, listOf("kobalt.properties", "com/beust/kobalt/wrapper/Main.class"))
+ assertExistence(ins, listOf("kobalt.properties"))
}
entry = stream.nextEntry
}
diff --git a/src/test/kotlin/com/beust/kobalt/internal/KotlinCompilerVersionTest.kt b/src/test/kotlin/com/beust/kobalt/internal/KotlinCompilerVersionTest.kt
deleted file mode 100644
index 21eb6edc..00000000
--- a/src/test/kotlin/com/beust/kobalt/internal/KotlinCompilerVersionTest.kt
+++ /dev/null
@@ -1,58 +0,0 @@
-package com.beust.kobalt.internal
-
-import com.beust.kobalt.BaseTest
-import com.beust.kobalt.BuildFile
-import com.beust.kobalt.ProjectFile
-import com.beust.kobalt.ProjectInfo
-import com.beust.kobalt.misc.KFiles
-import org.assertj.core.api.Assertions.assertThat
-import org.testng.annotations.Test
-import java.io.File
-
-class KotlinCompilerVersionTest : BaseTest() {
-
- @Test
- fun shouldCompileWithExternalKotlin() {
- val projectInfo = ProjectInfo(
- BuildFile(
- listOf("com.beust.kobalt.plugin.packaging.*", "com.beust.kobalt.plugin.kotlin.kotlinCompiler"),
- """
- kotlinCompiler {
- version = "1.2.60"
- }
- assemble{ jar{} }
- """
- ),
- listOf(
- ProjectFile("src/main/kotlin/A.kt", "val a = Bob()"),
- ProjectFile("src/main/kotlin/Bob.java", "class Bob { }")
- )
- )
-
- val result = launchProject(projectInfo, arrayOf("assemble", "--log", "2"))
-
- val project = result.projectDescription
- val jarFile = File(KFiles.joinDir(project.file.absolutePath, "kobaltBuild/libs", project.name + "-"
- + project.version + ".jar"))
-
- assertThat(jarFile).exists()
- }
-
- @Test
- fun shouldFailWhenKotlinVersionDoesNotExist() {
- val projectInfo = ProjectInfo(
- BuildFile(
- listOf("com.beust.kobalt.plugin.packaging.*", "com.beust.kobalt.plugin.kotlin.kotlinCompiler"),
- """
- kotlinCompiler { version = "1.1.20" }
- assemble{ jar{} }
- """
- ),
- listOf(ProjectFile("src/main/kotlin/A.kt", "val a = \"foo\""))
- )
-
- val result = launchProject(projectInfo, arrayOf("assemble", "--log", "2"))
-
- assertThat(result.result).isEqualTo(1)
- }
-}
diff --git a/src/test/kotlin/com/beust/kobalt/misc/MavenResolverTest.kt b/src/test/kotlin/com/beust/kobalt/misc/MavenResolverTest.kt
index 4cee6077..5b1c3458 100644
--- a/src/test/kotlin/com/beust/kobalt/misc/MavenResolverTest.kt
+++ b/src/test/kotlin/com/beust/kobalt/misc/MavenResolverTest.kt
@@ -1,6 +1,5 @@
package com.beust.kobalt.misc
-import com.beust.kobalt.Args
import com.beust.kobalt.BaseTest
import com.beust.kobalt.internal.KobaltSettings
import com.beust.kobalt.internal.KobaltSettingsXml
@@ -96,7 +95,7 @@ class MavenResolverTest : BaseTest() {
private fun resolve(id: String): List {
val system = Booter.newRepositorySystem()
val session = Booter.newRepositorySystemSession(system,
- localRepo.localRepo, KobaltSettings(KobaltSettingsXml()), Args(), EventBus())
+ localRepo.localRepo, KobaltSettings(KobaltSettingsXml()), EventBus())
val artifact = DefaultArtifact(id)
val collectRequest = CollectRequest().apply {