diff --git a/.gitignore b/.gitignore
index a680191b..881a3193 100644
--- a/.gitignore
+++ b/.gitignore
@@ -2,14 +2,13 @@
annotations
.idea/*
*.iml
-nonBuildScript
+buildScript
kobaltBuild
local.properties
classes
libs
.kobalt/
+./build/
out
.DS_Store
lib/kotlin-*
-build
-.history
diff --git a/README.md b/README.md
index d5d7cbe0..e8db3ef6 100644
--- a/README.md
+++ b/README.md
@@ -1,14 +1,11 @@
-# Kobalt
-
-[
](https://teamcity.jetbrains.com/project.html?projectId=OpenSourceProjects_Kobalt&tab=projectOverview)
-
+# Kobalt [](https://travis-ci.org/cbeust/kobalt)
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/dist/kobaltw b/dist/kobaltw
index 333738df..a8df4bb9 100755
--- a/dist/kobaltw
+++ b/dist/kobaltw
@@ -1,11 +1,2 @@
#!/usr/bin/env sh
-
-case "$(uname)" in
- CYGWIN*) DIRNAME=$(cygpath -d "$(dirname "$(readlink -f "$0")")");;
- Darwin*) DIRNAME=$(dirname "$(readlink "$0")");;
- *) DIRNAME=$(dirname "$(readlink -f "$0")");;
-esac
-if [ "$DIRNAME" = "." ]; then
- DIRNAME="$(dirname "$0")"
-fi
-java -jar "${DIRNAME}/../kobalt/wrapper/kobalt-wrapper.jar" $*
\ No newline at end of file
+java -jar "`dirname "$0"`/../kobalt/wrapper/kobalt-wrapper.jar" $*
\ No newline at end of file
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..99949300 100644
--- a/kobalt/src/Build.kt
+++ b/kobalt/src/Build.kt
@@ -1,14 +1,15 @@
-
-import com.beust.kobalt.*
+import com.beust.kobalt.TaskResult
import com.beust.kobalt.api.Project
import com.beust.kobalt.api.annotation.Task
+import com.beust.kobalt.homeDir
import com.beust.kobalt.plugin.application.application
import com.beust.kobalt.plugin.java.javaCompiler
import com.beust.kobalt.plugin.kotlin.kotlinCompiler
import com.beust.kobalt.plugin.packaging.assemble
-import com.beust.kobalt.plugin.publish.autoGitTag
import com.beust.kobalt.plugin.publish.bintray
import com.beust.kobalt.plugin.publish.github
+import com.beust.kobalt.project
+import com.beust.kobalt.test
import org.apache.maven.model.Developer
import org.apache.maven.model.License
import org.apache.maven.model.Model
@@ -17,31 +18,17 @@ import java.io.File
import java.nio.file.Files
import java.nio.file.Paths
import java.nio.file.StandardCopyOption
-import java.util.zip.ZipEntry
-import java.util.zip.ZipOutputStream
-
-val bs = buildScript {
- repos("https://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.0"
val aether = "1.0.2.v20150114"
- val testng = "6.12"
- val jcommander = "1.72"
-
- // JUnit 5
- val junit = "4.12"
- val junitPlatform = "1.1.0"
- val junitJupiter = "5.1.0"
}
fun mavenResolver(vararg m: String)
@@ -64,7 +51,6 @@ val wrapper = project {
}
assemble {
- jar { }
jar {
name = projectName + ".jar"
manifest {
@@ -76,13 +62,6 @@ val wrapper = project {
application {
mainClass = "com.beust.kobalt.wrapper.Main"
}
-
- bintray {
- publish = true
- sign = true
- }
-
- pom = createPom(name, "Wrapper for Kobalt")
}
val kobaltPluginApi = project {
@@ -92,42 +71,45 @@ 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")
+ pom = Model().apply {
+ name = project.name
+ description = "A build system in Kotlin"
+ url = "http://beust.com/kobalt"
+ licenses = listOf(License().apply {
+ name = "Apache 2.0"
+ url = "http://www.apache .org/licenses/LICENSE-2.0"
+ })
+ scm = Scm().apply {
+ url = "http://github.com/cbeust/kobalt"
+ connection = "https://github.com/cbeust/kobalt.git"
+ developerConnection = "git@github.com:cbeust/kobalt.git"
+ }
+ developers = listOf(Developer().apply {
+ name = "Cedric Beust"
+ email = "cedric@beust.com"
+ })
+ }
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}",
- "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",
-
- // Java 9
- "javax.xml.bind:jaxb-api:2.3.0"
+ "org.apache.maven:maven-aether-provider:3.3.9"
)
exclude(*aether("impl", "spi", "util", "api"))
}
@@ -142,8 +124,12 @@ val kobaltPluginApi = project {
}
}
+// install {
+// libDir = "lib-test"
+// }
+
kotlinCompiler {
- args("nowarn")
+ args("-nowarn")
}
bintray {
@@ -162,32 +148,24 @@ val kobaltApp = project(kobaltPluginApi, wrapper) {
compile("org.jetbrains.kotlin:kotlin-compiler-embeddable:${Versions.kotlin}")
// Used by the main app
- compile(
- "org.jetbrains.kotlin:kotlin-stdlib:${Versions.kotlin}",
- "com.github.spullara.mustache.java:compiler:0.9.5",
+ compile("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}",
@@ -201,9 +179,8 @@ 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",
+ compile("org.testng:testng:6.10",
+ "org.assertj:assertj-core:3.4.1",
*mavenResolver("util")
)
}
@@ -217,27 +194,17 @@ val kobaltApp = project(kobaltPluginApi, wrapper) {
}
zip {
val dir = "kobalt-$version"
- val files = listOf(
- "dist", "$dir/bin", "kobaltw",
- "dist", "$dir/bin", "kobaltw.bat",
- "$buildDirectory/libs", "$dir/kobalt/wrapper", "$projectName-$version.jar",
- "modules/wrapper/$buildDirectory/libs", "$dir/kobalt/wrapper", "$projectName-wrapper.jar")
-
- (0 .. files.size - 1 step 3).forEach { i ->
- include(from(files[i]), to(files[i + 1]), files[i + 2])
- }
-
- // Package the sources
- val currentDir = Paths.get(".").toAbsolutePath().normalize().toString()
- zipFolders("$currentDir/$buildDirectory/libs/all-sources/$projectName-$version-sources.jar",
- "$currentDir/$directory/src/main/kotlin",
- "$currentDir/${kobaltPluginApi.directory}/src/main/kotlin")
- include(from("$buildDirectory/libs/all-sources"), to("$dir/kobalt/wrapper"), "$projectName-$version-sources.jar")
+ include(from("dist"), to("$dir/bin"), "kobaltw")
+ include(from("dist"), to("$dir/bin"), "kobaltw.bat")
+ include(from("$buildDirectory/libs"), to("$dir/kobalt/wrapper"),
+ "$projectName-$version.jar")
+ include(from("modules/wrapper/$buildDirectory/libs"), to("$dir/kobalt/wrapper"),
+ "$projectName-wrapper.jar")
}
}
kotlinCompiler {
- args("nowarn")
+ args("-nowarn")
}
bintray {
@@ -246,37 +213,12 @@ val kobaltApp = project(kobaltPluginApi, wrapper) {
github {
file("$buildDirectory/libs/$name-$version.zip", "$name/$version/$name-$version.zip")
+ autoGitTag = true
}
test {
args("-log", "2", "src/test/resources/testng.xml")
}
-
- autoGitTag {
- enabled = true
- }
-}
-
-fun zipFolders(zipFilePath: String, vararg foldersPath: String) {
- val zip = Paths.get(zipFilePath)
- Files.deleteIfExists(zip)
- Files.createDirectories(zip.parent)
- val zipPath = Files.createFile(zip)
- ZipOutputStream(Files.newOutputStream(zipPath)).use {
- foldersPath.map {Paths.get(it)}.forEach { folderPath ->
- Files.walk(folderPath)
- .filter { path -> !Files.isDirectory(path) }
- .forEach { path ->
- val zipEntry = ZipEntry(folderPath.relativize(path).toString())
- try {
- it.putNextEntry(zipEntry)
- Files.copy(path, it)
- it.closeEntry()
- } catch (e: Exception) {
- }
- }
- }
- }
}
fun readVersion() : String {
@@ -296,31 +238,9 @@ fun taskCopyVersionForWrapper(project: Project) : TaskResult {
File(toString).mkdirs()
val from = Paths.get("src/main/resources/kobalt.properties")
val to = Paths.get("$toString/kobalt.properties")
- // Only copy if necessary so we don't break incremental compilation
- if (! to.toFile().exists() || (from.toFile().readLines() != to.toFile().readLines())) {
- Files.copy(from,
- to,
- StandardCopyOption.REPLACE_EXISTING)
- }
+ Files.copy(from,
+ to,
+ StandardCopyOption.REPLACE_EXISTING)
}
return TaskResult()
}
-
-fun createPom(projectName: String, projectDescription: String) = Model().apply {
- name = projectName
- description = projectDescription
- url = "https://beust.com/kobalt"
- licenses = listOf(License().apply {
- name = "Apache-2.0"
- url = "https://www.apache.org/licenses/LICENSE-2.0"
- })
- scm = Scm().apply {
- url = "https://github.com/cbeust/kobalt"
- connection = "https://github.com/cbeust/kobalt.git"
- developerConnection = "git@github.com:cbeust/kobalt.git"
- }
- developers = listOf(Developer().apply {
- name = "Cedric Beust"
- email = "cedric@beust.com"
- })
-}
diff --git a/kobalt/wrapper/kobalt-wrapper.jar b/kobalt/wrapper/kobalt-wrapper.jar
index 848fb463..c84458fa 100644
Binary files a/kobalt/wrapper/kobalt-wrapper.jar and b/kobalt/wrapper/kobalt-wrapper.jar differ
diff --git a/kobalt/wrapper/kobalt-wrapper.properties b/kobalt/wrapper/kobalt-wrapper.properties
index 0ca8045f..0e4c481d 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=0.940
\ No newline at end of file
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/ArchiveGenerator.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/ArchiveGenerator.kt
deleted file mode 100644
index 8158c642..00000000
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/ArchiveGenerator.kt
+++ /dev/null
@@ -1,21 +0,0 @@
-package com.beust.kobalt
-
-import com.beust.kobalt.api.KobaltContext
-import com.beust.kobalt.api.Project
-import com.beust.kobalt.archive.Zip
-import com.beust.kobalt.misc.KFiles
-import java.io.File
-
-interface ArchiveGenerator {
- fun findIncludedFiles(project: Project, context: KobaltContext, zip: Zip) : List
- val suffix: String
- fun generateArchive(project: Project, context: KobaltContext, zip: Zip, files: List) : File
-
- fun fullArchiveName(project: Project, context: KobaltContext, archiveName: String?) : File {
- val fullArchiveName = context.variant.archiveName(project, archiveName, suffix)
- val archiveDir = File(KFiles.libsDir(project))
- val result = File(archiveDir.path, fullArchiveName)
- return result
- }
-
-}
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..b2b7ec97 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
@@ -7,7 +7,7 @@ class Args {
var targets: List = arrayListOf()
@Parameter(names = arrayOf("-bf", "--buildFile"), description = "The build file")
- var buildFile: String? = "kobalt/src/Build.kt"
+ var buildFile: String? = null
@Parameter(names = arrayOf("--checkVersions"), description = "Check if there are any newer versions of the " +
"dependencies")
@@ -22,10 +22,6 @@ class Args {
@Parameter(names = arrayOf("--download"), description = "Force a download from the downloadUrl in the wrapper")
var download: Boolean = false
- @Parameter(names = arrayOf("--downloadSources"),
- description = "Force a download of sources and javadocs when resolving dependencies")
- var downloadSources: Boolean = false
-
@Parameter(names = arrayOf("--dryRun"), description = "Display all the tasks that will get run without " +
"actually running them")
var dryRun: Boolean = false
@@ -47,7 +43,7 @@ class Args {
var listTemplates: Boolean = false
@Parameter(names = arrayOf("--log"), description = "Define the log level " +
- "(${Constants.LOG_QUIET_LEVEL}-${Constants.LOG_MAX_LEVEL})")
+ "(${Constants.LOG_DEFAULT_LEVEL}-${Constants.LOG_MAX_LEVEL})")
var log: Int = Constants.LOG_DEFAULT_LEVEL
@Parameter(names = arrayOf("--logTags"),
@@ -61,8 +57,8 @@ 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("--parallel"), description = "Build all the projects in parallel whenever possible")
+ var parallel: Boolean = true
@Parameter(names = arrayOf("--plugins"), description = "Comma-separated list of plug-in Maven id's")
var pluginIds: String? = null
@@ -86,14 +82,7 @@ class Args {
@Parameter(names = arrayOf("--projectInfo"), description = "Display information about the current projects")
var projectInfo: Boolean = false
- @Parameter(names = arrayOf("--noIncrementalKotlin"), description = "Disable incremental Kotlin compilation")
- var noIncrementalKotlin: Boolean = false
-
- companion object {
- const val SEQUENTIAL = "--sequential"
- }
-
- @Parameter(names = arrayOf(Args.SEQUENTIAL), description = "Build all the projects in sequence")
+ @Parameter(names = arrayOf("--sequential"), description = "Build all the projects in sequence")
var sequential: Boolean = false
@Parameter(names = arrayOf("--server"), description = "Run in server mode")
@@ -104,8 +93,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/AsciiArt.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/AsciiArt.kt
index e138fabc..df506b9f 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/AsciiArt.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/AsciiArt.kt
@@ -17,16 +17,16 @@ class AsciiArt {
companion object {
private val BANNERS = arrayOf(
" __ __ __ __ __ \n" +
- " / //_/ ____ / /_ ____ _ / / / /_\n" +
- " / ,< / __ \\ / __ \\ / __ `/ / / / __/\n" +
- " / /| | / /_/ / / /_/ // /_/ / / / / /_ \n" +
- " /_/ |_| \\____/ /_.___/ \\__,_/ /_/ \\__/ ",
+ " / //_/ ____ / /_ ____ _ / / / /_\n" +
+ " / ,< / __ \\ / __ \\ / __ `/ / / / __/\n" +
+ " / /| | / /_/ / / /_/ // /_/ / / / / /_ \n" +
+ " /_/ |_| \\____/ /_.___/ \\__,_/ /_/ \\__/ ",
" _ __ _ _ _ \n" +
- " | |/ / ___ | |__ __ _ | | | |_ \n" +
- " | ' / / _ \\ | '_ \\ / _` | | | | __|\n" +
- " | . \\ | (_) | | |_) | | (_| | | | | |_ \n" +
- " |_|\\_\\ \\___/ |_.__/ \\__,_| |_| \\__| "
+ " | |/ / ___ | |__ __ _ | | | |_ \n" +
+ " | ' / / _ \\ | '_ \\ / _` | | | | __|\n" +
+ " | . \\ | (_) | | |_) | | (_| | | | | |_ \n" +
+ " |_|\\_\\ \\___/ |_.__/ \\__,_| |_| \\__| "
)
val banner : String get() = BANNERS[Random().nextInt(BANNERS.size)]
@@ -85,7 +85,7 @@ class AsciiArt {
}
fun logBox(s: String, bl: String = bottomLeft, br: String = bottomRight, indent: Int = 0)
- = logBox(listOf(s), bl, br, indent)
+ = logBox(listOf(s), bl, br, indent)
fun fill(n: Int) = buildString { repeat(n, { append(" ")})}.toString()
@@ -105,7 +105,7 @@ class AsciiArt {
const val CYAN = "\u001B[36m"
const val WHITE = "\u001B[37m"
- fun wrap(s: CharSequence, color: String) = color + s + RESET
+ private fun wrap(s: CharSequence, color: String) = color + s + RESET
private fun blue(s: CharSequence) = wrap(s, BLUE)
private fun red(s: CharSequence) = wrap(s, RED)
private fun yellow(s: CharSequence) = wrap(s, YELLOW)
@@ -141,18 +141,18 @@ class AsciiTable {
fun build() : String {
val formattedHeaders =
- headers.mapIndexed { index, s ->
- val s2 = col(widths[index], s)
- s2
- }.joinToString(vb)
+ headers.mapIndexed { index, s ->
+ val s2 = col(widths[index], s)
+ s2
+ }.joinToString(vb)
val result = StringBuffer().apply {
append(AsciiArt.logBox(formattedHeaders, AsciiArt.bottomLeft2, AsciiArt.bottomRight2))
append("\n")
}
var lineLength = 0
- rows.forEachIndexed { _, row ->
+ rows.forEachIndexed { index, row ->
val formattedRow = row.mapIndexed { i, s -> col(widths[i], s) }.joinToString(vb)
- val line = "$vb $formattedRow $vb"
+ val line = vb + " " + formattedRow + " " + vb
result.append(line).append("\n")
lineLength = line.length
}
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..3d75614e 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
@@ -27,17 +27,8 @@ class BuildScriptConfig {
@Directive
fun buildFileClasspath(vararg bfc: String) = newBuildFileClasspath(*bfc)
- /** Options passed to Kobalt */
- @Directive
- fun kobaltOptions(vararg options: String) = Kobalt.addKobaltOptions(options)
-
- /** Where to find additional build files */
- @Directive
- fun buildSourceDirs(vararg dirs: String) = Kobalt.addBuildSourceDirs(dirs)
-
- // The following settings modify the compiler used to compile the build file, which regular users should
- // probably never need to do. Projects should use kotlinCompiler { compilerVersion } to configure the
- // Kotin compiler for their source files.
+ // The following settings modify the compiler used to compile the build file.
+ // Projects should use kotlinCompiler { compilerVersion } to configure the Kotin compiler for their source files.
var kobaltCompilerVersion : String? = null
var kobaltCompilerRepo: String? = null
var kobaltCompilerFlags: String? = null
@@ -74,18 +65,7 @@ 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 username: String? = null, var password: String? = null) {
fun hasAuth() : Boolean {
return (! username.isNullOrBlank()) && (! password.isNullOrBlank())
}
@@ -116,7 +96,6 @@ fun buildFileClasspath(vararg deps: String) {
}
fun newBuildFileClasspath(vararg deps: String) {
- //FIXME newBuildFileClasspath called twice
deps.forEach { Kobalt.addBuildFileClasspath(it) }
}
@@ -126,7 +105,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)
@@ -143,3 +122,4 @@ fun localMaven() : String {
}
return result.toURI().toString()
}
+
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..f6a8ea98 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
@@ -3,19 +3,20 @@ package com.beust.kobalt
import com.beust.kobalt.misc.KFiles
object Constants {
- const val LOG_QUIET_LEVEL = 0
const val LOG_DEFAULT_LEVEL = 1
const val LOG_MAX_LEVEL = 3
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.0"
- internal val DEFAULT_REPOS = listOf(
+ internal val DEFAULT_REPOS = listOf(
// "https://maven-central.storage.googleapis.com/",
- HostConfig("https://repo1.maven.org/maven2/", "Maven"),
- HostConfig("https://jcenter.bintray.com/", "JCenter")
-// "https://repository.jetbrains.com/all/", // <-- contains snapshots
+ "http://repo1.maven.org/maven2/",
+ "https://jcenter.bintray.com/",
+// "http://repository.jetbrains.com/all/", // <-- contains snapshots
+ "https://dl.bintray.com/kotlin/kotlin-eap",
+ "https://dl.bintray.com/kotlin/kotlin-eap-1.1"
// snapshots
// "https://oss.sonatype.org/content/repositories/snapshots/"
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Directives.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Directives.kt
index 93d9434c..f665f5d2 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Directives.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Directives.kt
@@ -4,8 +4,6 @@ import com.beust.kobalt.api.Kobalt
import com.beust.kobalt.api.Project
import com.beust.kobalt.api.annotation.Directive
import com.beust.kobalt.internal.JvmCompilerPlugin
-import kotlin.properties.ReadWriteProperty
-import kotlin.reflect.KProperty
@Directive
fun project(vararg projects: Project, init: Project.() -> Unit): Project {
@@ -21,19 +19,4 @@ fun buildScript(init: BuildScriptConfig.() -> Unit): BuildScriptConfig {
val buildScriptConfig = BuildScriptConfig().apply { init() }
BUILD_SCRIPT_CONFIG = buildScriptConfig
return buildScriptConfig
-}
-
-@Directive
-fun profile(): ReadWriteProperty {
- val result = object: ReadWriteProperty {
- var value: Boolean = false
- override operator fun getValue(thisRef: Nothing?, property: KProperty<*>): Boolean {
- return value
- }
-
- override operator fun setValue(thisRef: Nothing?, property: KProperty<*>, value: Boolean) {
- this.value = value
- }
- }
- return result
-}
+}
\ No newline at end of file
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/FileSpec.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/FileSpec.kt
index 1eb409f4..715c4221 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/FileSpec.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/FileSpec.kt
@@ -28,15 +28,15 @@ sealed class IFileSpec {
private fun isIncluded(includeMatchers: Glob, excludes: List, rel: Path) : Boolean {
excludes.forEach {
if (it.matches(rel)) {
- kobaltLog(3, " Excluding ${rel.toFile()}")
+ kobaltLog(3, "Excluding ${rel.toFile()}")
return false
}
}
if (includeMatchers.matches(rel)) {
- kobaltLog(3, " Including ${rel.toFile().path}")
+ kobaltLog(3, "Including ${rel.toFile().path}")
return true
}
- kobaltLog(2, " Excluding ${rel.toFile()} (not matching any include pattern")
+ kobaltLog(2, "Excluding ${rel.toFile()} (not matching any include pattern")
return false
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/IncludeFromTo.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/IncludeFromTo.kt
deleted file mode 100644
index ea189851..00000000
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/IncludeFromTo.kt
+++ /dev/null
@@ -1,43 +0,0 @@
-package com.beust.kobalt
-
-import com.beust.kobalt.api.annotation.Directive
-import java.io.File
-
-/**
- * Base classes for directives that support install(from,to) (e.g. install{} or jar{}).
- */
-open class IncludeFromTo {
- /**
- * Prefix path to be removed from the zip file. For example, if you add "build/lib/a.jar" to the zip
- * file and the excludePrefix is "build/lib", then "a.jar" will be added at the root of the zip file.
- */
- val includedFiles = arrayListOf()
-
- @Directive
- fun from(s: String) = From(s)
-
- @Directive
- fun to(s: String) = To(s)
-
- @Directive
- fun copy(from: From, to: To) {
- val dir = File(from.path).absoluteFile.parentFile
- includedFiles.add(IncludedFile(from(dir.absolutePath), to, listOf(IFileSpec.FileSpec(from.path))))
- }
-
- @Directive
- fun include(vararg files: String) {
- includedFiles.add(IncludedFile(files.map { IFileSpec.FileSpec(it) }))
- }
-
- @Directive
- fun include(from: From, to: To, vararg specs: String) {
- includedFiles.add(IncludedFile(from, to, specs.map { IFileSpec.FileSpec(it) }))
- }
-
- @Directive
- fun include(from: From, to: To, vararg specs: IFileSpec.GlobSpec) {
- includedFiles.add(IncludedFile(from, to, listOf(*specs)))
- }
-}
-
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/IncludedFile.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/IncludedFile.kt
deleted file mode 100644
index 46dea15e..00000000
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/IncludedFile.kt
+++ /dev/null
@@ -1,44 +0,0 @@
-package com.beust.kobalt
-
-import com.beust.kobalt.misc.KFiles
-import com.beust.kobalt.misc.toString
-import java.io.File
-import java.nio.file.Paths
-
-class IncludedFile(val fromOriginal: From, val toOriginal: To, val specs: List,
- val expandJarFiles: Boolean = false) {
- constructor(specs: List, expandJarFiles: Boolean = false) : this(From(""), To(""), specs, expandJarFiles)
- fun from(s: String) = File(if (fromOriginal.isCurrentDir()) s else KFiles.joinDir(from, s))
- val from: String get() = fromOriginal.path.replace("\\", "/")
- fun to(s: String) = File(if (toOriginal.isCurrentDir()) s else KFiles.joinDir(to, s))
- val to: String get() = toOriginal.path.replace("\\", "/")
- override fun toString() = toString("IncludedFile",
- "files - ", specs.map { it.toString() },
- "from", from,
- "to", to)
-
- fun allFromFiles(directory: String? = null): List {
- val result = arrayListOf()
- specs.forEach { spec ->
-// val fullDir = if (directory == null) from else KFiles.joinDir(directory, from)
- spec.toFiles(directory, from).forEach { source ->
- result.add(if (source.isAbsolute) source else File(source.path))
- }
- }
- return result.map { Paths.get(it.path).normalize().toFile()}
- }
-}
-
-open class Direction(open val p: String) {
- override fun toString() = path
- fun isCurrentDir() = path == "./"
-
- val path: String get() =
- if (p.isEmpty()) "./"
- else if (p.startsWith("/") || p.endsWith("/")) p
- else p + "/"
-}
-
-class From(override val p: String) : Direction(p)
-
-class To(override val p: String) : Direction(p)
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..aeef361c 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,22 +3,21 @@ 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.archive.Jar
import com.beust.kobalt.maven.DependencyManager
import com.beust.kobalt.maven.aether.Scope
-import com.beust.kobalt.misc.KFiles
-import com.beust.kobalt.misc.kobaltLog
+import com.beust.kobalt.misc.*
import com.google.inject.Inject
import java.io.File
import java.io.FileInputStream
+import java.io.OutputStream
import java.nio.file.Paths
+import java.util.jar.JarOutputStream
import java.util.jar.Manifest
-class JarGenerator @Inject constructor(val dependencyManager: DependencyManager) : ArchiveGenerator {
+class JarGenerator @Inject constructor(val dependencyManager: DependencyManager) {
companion object {
- fun findIncludedFiles(directory: String, files: List, excludes: List,
- throwOnError: Boolean = true)
+ fun findIncludedFiles(directory: String, files: List, excludes: List)
: List {
val result = arrayListOf()
files.forEach { includedFile ->
@@ -28,7 +27,7 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
if (File(directory, fromPath).exists()) {
spec.toFiles(directory, fromPath).forEach { file ->
val fullFile = File(KFiles.joinDir(directory, fromPath, file.path))
- if (! fullFile.exists() && throwOnError) {
+ if (! fullFile.exists()) {
throw AssertionError("File should exist: $fullFile")
}
@@ -41,7 +40,7 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
}
} else {
- kobaltLog(2, " Directory $fromPath doesn't exist, not including it in the jar")
+ kobaltLog(2, "Directory $fromPath doesn't exist, not including it in the jar")
}
}
if (includedSpecs.size > 0) {
@@ -53,9 +52,7 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
}
}
- override val suffix = ".jar"
-
- override fun findIncludedFiles(project: Project, context: KobaltContext, zip: Zip) : List {
+ fun findIncludedFiles(project: Project, context: KobaltContext, jar: Jar) : List {
//
// Add all the applicable files for the current project
//
@@ -63,7 +60,7 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
val result = arrayListOf()
val classesDir = KFiles.makeDir(buildDir.path, "classes")
- if (zip.includedFiles.isEmpty()) {
+ if (jar.includedFiles.isEmpty()) {
// If no includes were specified, assume the user wants a simple jar file made of the
// classes of the project, so we specify a From("build/classes/"), To("") and
// a list of files containing everything under it
@@ -73,7 +70,7 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
// Class files
val files = KFiles.findRecursively(classesDir).map { File(relClassesDir.toFile(), it) }
val filesNotExcluded : List = files.filter {
- ! KFiles.Companion.isExcluded(KFiles.joinDir(project.directory, it.path), zip.excludes)
+ ! KFiles.Companion.isExcluded(KFiles.joinDir(project.directory, it.path), jar.excludes)
}
val fileSpecs = arrayListOf()
filesNotExcluded.forEach {
@@ -89,14 +86,16 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
//
// The user specified an include, just use it verbatim
//
- val includedFiles = findIncludedFiles(project.directory, zip.includedFiles, zip.excludes, false)
+ val includedFiles = findIncludedFiles(project.directory, jar.includedFiles, jar.excludes)
result.addAll(includedFiles)
}
//
// If fatJar is true, add all the transitive dependencies as well: compile, runtime and dependent projects
//
- if (zip.fatJar) {
+ if (jar.fatJar) {
+ context.logger.log(project.name, 2, "Finding included files for fat jar")
+
val seen = hashSetOf()
@Suppress("UNCHECKED_CAST")
val allDependencies = project.compileDependencies + project.compileRuntimeDependencies +
@@ -111,7 +110,7 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
}.forEach { file : File ->
if (! seen.contains(file.path)) {
seen.add(file.path)
- if (! KFiles.Companion.isExcluded(file, zip.excludes)) {
+ if (! KFiles.Companion.isExcluded(file, jar.excludes)) {
result.add(IncludedFile(specs = arrayListOf(IFileSpec.FileSpec(file.absolutePath)),
expandJarFiles = true))
}
@@ -122,18 +121,19 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
return result
}
- override fun generateArchive(project: Project, context: KobaltContext, zip: Zip,
- includedFiles: List) : File {
+ fun generateJar(project: Project, context: KobaltContext, jar: Jar) : File {
+ val includedFiles = findIncludedFiles(project, context, jar)
+
//
// Generate the manifest
// If manifest attributes were specified in the build file, use those to generateAndSave the manifest. Otherwise,
// try to find a META-INF/MANIFEST.MF and use that one if we find any. Otherwise, use the default manifest.
//
val manifest =
- if (zip.attributes.size > 1) {
- context.logger.log(project.name, 2, "Creating MANIFEST.MF from " + zip.attributes.size + " attributes")
+ if (jar.attributes.size > 1) {
+ context.logger.log(project.name, 2, "Creating MANIFEST.MF from " + jar.attributes.size + " attributes")
Manifest().apply {
- zip.attributes.forEach { attribute ->
+ jar.attributes.forEach { attribute ->
mainAttributes.putValue(attribute.first, attribute.second)
}
}
@@ -142,7 +142,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,12 +151,14 @@ class JarGenerator @Inject constructor(val dependencyManager: DependencyManager)
context.logger.log(project.name, 2, "Including MANIFEST.MF file $manifestFile")
Manifest(FileInputStream(manifestFile))
} else {
- null
+ Manifest()
}
}
- return Archives.generateArchive(project, context, zip.name, ".jar", includedFiles,
- true /* expandJarFiles */, manifest)
+ val jarFactory = { os: OutputStream -> JarOutputStream(os, manifest) }
+
+ return Archives.generateArchive(project, context, jar.name, ".jar", includedFiles,
+ true /* expandJarFiles */, jarFactory)
}
}
\ No newline at end of file
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/Plugins.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Plugins.kt
index 0102dd8b..914ddbaa 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Plugins.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/Plugins.kt
@@ -28,6 +28,7 @@ class Plugins @Inject constructor (val taskManagerProvider : Provider()
-// @Inject
-// lateinit var pluginInfo: PluginInfo
-
fun installPlugins(dependencies: List, scriptClassLoader: ClassLoader) {
val executor = executors.newExecutor("Plugins", 5)
dependencies.forEach {
@@ -193,8 +191,6 @@ class Plugins @Inject constructor (val taskManagerProvider : Provider>) {
@@ -81,12 +85,10 @@ class ResolveDependency @Inject constructor(
else leftMiddle
val indent = level * increment
for(i in 0..indent - 2) {
- if (!KobaltLogger.isQuiet) {
- if (i == 0 || ((i + 1) % increment == 0)) print(vertical)
- else print(" ")
- }
+ if (i == 0 || ((i + 1) % increment == 0)) print(vertical)
+ else print(" ")
}
- kobaltLog(1, left + " " + dep.id + (if (dep.optional) " (optional)" else ""))
+ println(left + " " + dep.id + (if (dep.optional) " (optional)" else ""))
display(node.children)
}
}
@@ -102,12 +104,7 @@ class ResolveDependency @Inject constructor(
kobaltLog(2, "Found dependency ${dep.dep.id} level: ${dep.level}")
result.add(node)
seen.add(it.id)
- try {
- node.addChildren(findChildren(node, seen))
- } catch(ex: Exception) {
- if (! it.optional) warn("Couldn't resolve " + node)
- // else don't warn about missing optional dependencies
- }
+ node.addChildren(findChildren(node, seen))
}
}
kobaltLog(2, "Children for ${root.value.dep.id}: ${result.size}")
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/TaskResult.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/TaskResult.kt
index 241bc045..4d6a45f3 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/TaskResult.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/TaskResult.kt
@@ -1,8 +1,3 @@
package com.beust.kobalt
-class TestResult(val success: Boolean, val shortMessage: String? = null, val longMessage: String? = null)
-
-open class TaskResult(val success: Boolean = true,
- val testResult: TestResult? = null,
- val errorMessage: String? = null
-)
+open public class TaskResult(val success: Boolean = true, val errorMessage: String? = null)
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..1ef6b8aa 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
@@ -29,7 +29,7 @@ class Variant(val initialProductFlavor: ProductFlavorConfig? = null,
/**
* for {internal, release}, return [internalRelease, internal, release]
*/
- fun allDirectories(): List {
+ fun allDirectories(project: Project): List {
return arrayListOf().apply {
add(toCamelcaseDir())
add(productFlavor.name)
@@ -88,7 +88,7 @@ class Variant(val initialProductFlavor: ProductFlavorConfig? = null,
result.add(dir)
}
- result.addAll(allDirectories()
+ result.addAll(allDirectories(project)
.map { File(KFiles.joinDir("src", it, suffix)) }
.filter(File::exists))
@@ -113,8 +113,8 @@ class Variant(val initialProductFlavor: ProductFlavorConfig? = null,
if (isDefault) {
archiveName ?: project.name + "-" + project.version + suffix
} else {
- val base = archiveName?.substring(0, archiveName.length - suffix.length)
- ?: project.name + "-" + project.version
+ val base = if (archiveName != null) archiveName.substring(0, archiveName.length - suffix.length)
+ else project.name + "-" + project.version
val flavor = if (productFlavor.name.isEmpty()) "" else "-" + productFlavor.name
val type = if (buildType.name.isEmpty()) "" else "-" + buildType.name
val result: String = base + flavor + type + suffix
@@ -124,16 +124,18 @@ class Variant(val initialProductFlavor: ProductFlavorConfig? = null,
return result
}
+ val shortArchiveName = if (isDefault) "" else "-" + productFlavor.name + "-" + buildType.name
+
var generatedSourceDirectory: File? = null
private fun findBuildTypeBuildConfig(project: Project, variant: Variant?) : BuildConfig? {
val buildTypeName = variant?.buildType?.name
- return project.buildTypes[buildTypeName]?.buildConfig
+ return project.buildTypes[buildTypeName]?.buildConfig ?: null
}
private fun findProductFlavorBuildConfig(project: Project, variant: Variant?) : BuildConfig? {
val buildTypeName = variant?.productFlavor?.name
- return project.productFlavors[buildTypeName]?.buildConfig
+ return project.productFlavors[buildTypeName]?.buildConfig ?: null
}
/**
@@ -162,8 +164,7 @@ class Variant(val initialProductFlavor: ProductFlavorConfig? = null,
?: throw KobaltException(
"packageName needs to be defined on the project in order to generateAndSave BuildConfig")
- val contributor = ActorUtils.selectAffinityActor(project, context,
- context.pluginInfo.buildConfigContributors)
+ 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"))
@@ -221,7 +222,7 @@ class Variant(val initialProductFlavor: ProductFlavorConfig? = null,
}
fun toCamelcaseDir() : String {
- fun lci(s : String) = if (s.isEmpty() || s.length == 1) s else s[0].toLowerCase() + s.substring(1)
+ fun lci(s : String) = if (s.length == 0 || s.length == 1) s else s[0].toLowerCase() + s.substring(1)
return lci(productFlavor.name) + buildType.name.capitalize()
}
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..f0be2eb5 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
@@ -11,6 +11,4 @@ data class CompilerActionInfo(val directory: String?,
val suffixesBeingCompiled: List,
val outputDir: File,
val compilerArgs: List,
- val friendPaths: List,
- val forceRecompile: Boolean,
- val compilerSeparateProcess: Boolean = false)
+ val friendPaths: List)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/DependencyHolder.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/DependencyHolder.kt
index e1195ca3..a561cd9f 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/DependencyHolder.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/DependencyHolder.kt
@@ -13,7 +13,6 @@ interface IDependencyHolder {
val compileDependencies : ArrayList
val optionalDependencies : ArrayList
val compileProvidedDependencies : ArrayList
- val compileOnlyDependencies : ArrayList
val compileRuntimeDependencies : ArrayList
val excludedDependencies : ArrayList
val nativeDependencies : ArrayList
@@ -30,7 +29,6 @@ open class DependencyHolder : IDependencyHolder {
override val compileDependencies : ArrayList = arrayListOf()
override val optionalDependencies : ArrayList = arrayListOf()
override val compileProvidedDependencies : ArrayList = arrayListOf()
- override val compileOnlyDependencies : ArrayList = arrayListOf()
override val compileRuntimeDependencies : ArrayList = arrayListOf()
override val excludedDependencies : ArrayList = arrayListOf()
override val nativeDependencies : ArrayList = arrayListOf()
@@ -39,7 +37,7 @@ open class DependencyHolder : IDependencyHolder {
override fun dependencies(init: Dependencies.() -> Unit) : Dependencies {
dependencies = Dependencies(project, compileDependencies, optionalDependencies, compileProvidedDependencies,
- compileOnlyDependencies, compileRuntimeDependencies, excludedDependencies, nativeDependencies)
+ compileRuntimeDependencies, excludedDependencies, nativeDependencies)
dependencies!!.init()
return dependencies!!
}
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/IBuildListener.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IBuildListener.kt
index 2b0fdadb..1e53cc49 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IBuildListener.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IBuildListener.kt
@@ -4,12 +4,8 @@ package com.beust.kobalt.api
* Plug-ins that listen to build events.
*/
interface IBuildListener : IListener {
-
- class TaskEndInfo(val success: Boolean, val shortMessage: String? = null,
- val longMessage: String? = null)
-
fun taskStart(project: Project, context: KobaltContext, taskName: String) {}
- fun taskEnd(project: Project, context: KobaltContext, taskName: String, info: TaskEndInfo) {}
+ fun taskEnd(project: Project, context: KobaltContext, taskName: String, success: Boolean) {}
fun projectStart(project: Project, context: KobaltContext) {}
fun projectEnd(project: Project, context: KobaltContext, status: ProjectBuildStatus) {}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IClasspathDependency.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IClasspathDependency.kt
index 527e6f13..a24344ad 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IClasspathDependency.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IClasspathDependency.kt
@@ -36,6 +36,4 @@ interface IClasspathDependency {
/** Used to only keep the most recent version for an artifact if no version was specified */
val shortId: String
-
- val excluded: ArrayList
}
\ No newline at end of file
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/ICompilerContributor.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/ICompilerContributor.kt
index b6ce8fd2..7882cfd0 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/ICompilerContributor.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/ICompilerContributor.kt
@@ -1,6 +1,7 @@
package com.beust.kobalt.api
import com.beust.kobalt.TaskResult
+import com.beust.kobalt.misc.warn
interface ICompilerDescription : Comparable {
/**
@@ -57,12 +58,10 @@ class CompilerDescription(override val name: String, override val sourceDirecto
if (info.sourceFiles.isNotEmpty()) {
compiler.compile(project, context, info)
} else {
- context.logger.log(project.name, 2, "$name couldn't find any source files to compile")
+ warn("Couldn't find any source files to compile")
TaskResult()
}
return result
}
-
- override fun toString() = name + " compiler"
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IDependencyManager.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IDependencyManager.kt
index 3a66f980..ce1778aa 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IDependencyManager.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/IDependencyManager.kt
@@ -1,11 +1,8 @@
package com.beust.kobalt.api
-import com.beust.kobalt.maven.aether.Filters.EXCLUDE_OPTIONAL_FILTER
-import com.beust.kobalt.maven.aether.KobaltMavenResolver
+import com.beust.kobalt.maven.aether.Filters
import com.beust.kobalt.maven.aether.Scope
-import com.beust.kobalt.misc.kobaltLog
import org.eclipse.aether.graph.DependencyFilter
-import org.eclipse.aether.graph.DependencyNode
/**
* Manage the creation of dependencies and also provide dependencies for projects.
@@ -29,7 +26,7 @@ interface IDependencyManager {
/**
* @return the source dependencies for this project, including the contributors.
*/
- fun dependencies(project: Project, context: KobaltContext, scopes: List): List
+ fun dependencies(project: Project, context: KobaltContext): List
/**
* @return the test dependencies for this project, including the contributors.
@@ -41,48 +38,7 @@ interface IDependencyManager {
* allDependencies is typically either compileDependencies or testDependencies
*/
fun calculateDependencies(project: Project?, context: KobaltContext,
- dependencyFilter: DependencyFilter =
- createDependencyFilter(project, project?.compileDependencies ?: emptyList()),
+ dependencyFilter: DependencyFilter = Filters.EXCLUDE_OPTIONAL_FILTER,
scopes: List = listOf(Scope.COMPILE),
vararg passedDependencies: List): List
-
- /**
- * Create an Aether dependency filter that uses the dependency configuration included in each
- * IClasspathDependency.
- */
- fun createDependencyFilter(project: Project?, dependencies: List) : DependencyFilter {
- return DependencyFilter { p0, p1 ->
- fun isNodeExcluded(node: DependencyNode, passedDep: IClasspathDependency) : Boolean {
- val dep = create(KobaltMavenResolver.artifactToId(node.artifact))
- return passedDep.excluded.any { ex -> ex.isExcluded(dep)}
- }
- fun isDepExcluded(node: DependencyNode, excluded: List?) : Boolean {
- val dep = create(KobaltMavenResolver.artifactToId(node.artifact))
- return excluded?.map { it.id }?.contains(dep.id) ?: false
- }
-
- val accept = dependencies.isEmpty() || dependencies.any {
- // Is this dependency excluded?
- val isExcluded = isNodeExcluded(p0, it) || isDepExcluded(p0, project?.excludedDependencies)
-
- // Is the parent dependency excluded?
- val isParentExcluded =
- if (p1.any()) {
- isNodeExcluded(p1[0], it) || isDepExcluded(p1[0], project?.excludedDependencies)
- } else {
- false
- }
-
- // Only accept if no exclusions were found
- ! isExcluded && ! isParentExcluded
- }
-
- if (! accept) {
- kobaltLog(2, "Excluding $p0")
- }
-
- if (accept) EXCLUDE_OPTIONAL_FILTER.accept(p0, p1)
- else accept
- }
- }
}
\ No newline at end of file
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..83621451 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
@@ -23,10 +23,9 @@ class DynamicTask(override val plugin: IPlugin, override val name: String, overr
override fun call(): TaskResult2 {
val taskResult = closure.invoke(project)
- return TaskResult2(taskResult.success, errorMessage = taskResult.errorMessage, value = this)
+ return TaskResult2(taskResult.success, taskResult.errorMessage, 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..49b82050 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
@@ -5,7 +5,6 @@ import com.beust.kobalt.HostConfig
import com.beust.kobalt.Plugins
import com.beust.kobalt.internal.PluginInfo
import com.beust.kobalt.maven.DependencyManager
-import com.beust.kobalt.maven.aether.KobaltMavenResolver
import com.google.inject.Guice
import com.google.inject.Injector
import com.google.inject.Module
@@ -36,12 +35,12 @@ class Kobalt {
*/
val repos : Set
get() {
- val settingsRepos = Kobalt.context?.settings?.defaultRepos?.map { HostConfig(it) } ?: emptyList()
+ val settingsRepos = Kobalt.context?.settings?.defaultRepos ?: emptyList()
// Repos from in the settings
val result = ArrayList(
(if (settingsRepos.isEmpty()) Constants.DEFAULT_REPOS
else settingsRepos)
- )
+ .map { HostConfig(it) })
// Repo from in the settings
Kobalt.context?.settings?.kobaltCompilerRepo?.let {
@@ -56,9 +55,6 @@ class Kobalt {
// Repos from the build file
result.addAll(reposFromBuildFiles)
- result.forEach {
- KobaltMavenResolver.initAuthentication(it)
- }
return result.toHashSet()
}
@@ -122,20 +118,5 @@ class Kobalt {
get() = Duration.parse( kobaltProperties.getProperty(PROPERTY_KOBALT_VERSION_CHECK_TIMEOUT) ?: "P1D")
fun findPlugin(name: String) = Plugins.findPlugin(name)
-
- val optionsFromBuild = arrayListOf()
- fun addKobaltOptions(options: Array) {
- optionsFromBuild.addAll(options)
- }
-
- val buildSourceDirs = arrayListOf()
- fun addBuildSourceDirs(dirs: Array) {
- buildSourceDirs.addAll(dirs)
- }
-
- fun cleanUp() {
- buildSourceDirs.clear()
- buildFileClasspath.clear()
- }
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/KobaltContext.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/KobaltContext.kt
index b7e5ace8..983c5961 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/KobaltContext.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/KobaltContext.kt
@@ -105,12 +105,4 @@ class InternalContext {
* The absolute directory of the current project.
*/
var absoluteDir: File? = null
-
- /**
- * If true, will force a recompile of the files even if using the incremental compile
- */
- var forceRecompile: Boolean = false
-
- var noIncrementalKotlin: Boolean = false
-
}
\ No newline at end of file
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/Project.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/Project.kt
index e54e30ec..5e45e7cb 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/Project.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/api/Project.kt
@@ -3,7 +3,6 @@ package com.beust.kobalt.api
import com.beust.kobalt.TestConfig
import com.beust.kobalt.api.annotation.Directive
import com.beust.kobalt.maven.DependencyManager
-import com.beust.kobalt.maven.aether.AetherDependency
import com.beust.kobalt.maven.aether.KobaltMavenResolver
import com.beust.kobalt.misc.KFiles
import com.beust.kobalt.misc.kobaltLog
@@ -12,7 +11,6 @@ import java.io.File
import java.util.*
import java.util.concurrent.Future
import java.util.concurrent.FutureTask
-import java.util.regex.Pattern
open class Project(
@Directive open var name: String = "",
@@ -26,7 +24,6 @@ open class Project(
@Directive open var url: String? = null,
@Directive open var pom: Model? = null,
@Directive open var dependsOn: ArrayList = arrayListOf(),
- @Directive open var testsDependOn: ArrayList = arrayListOf(),
@Directive open var packageName: String? = group)
: IBuildConfig, IDependencyHolder by DependencyHolder() {
@@ -34,15 +31,13 @@ open class Project(
this.project = this
}
- fun allProjectDependedOn() = project.dependsOn + project.testsDependOn
-
class ProjectExtra(project: Project) {
var isDirty = false
/**
* @return true if any of the projects we depend on is dirty.
*/
- fun dependsOnDirtyProjects(project: Project) = project.allProjectDependedOn().any { it.projectExtra.isDirty }
+ fun dependsOnDirtyProjects(project: Project) = project.dependsOn.any { it.projectExtra.isDirty }
}
/**
@@ -91,8 +86,7 @@ open class Project(
@Directive
fun dependenciesTest(init: Dependencies.() -> Unit) : Dependencies {
dependencies = Dependencies(this, testDependencies, arrayListOf(),
- testProvidedDependencies, compileOnlyDependencies, compileRuntimeDependencies,
- excludedDependencies, nativeDependencies)
+ testProvidedDependencies, compileRuntimeDependencies, excludedDependencies, nativeDependencies)
dependencies!!.init()
return dependencies!!
}
@@ -100,9 +94,6 @@ open class Project(
val testDependencies : ArrayList = arrayListOf()
val testProvidedDependencies : ArrayList = arrayListOf()
- fun testsDependOn(vararg projects: Project) = testsDependOn.addAll(projects)
- fun dependsOn(vararg projects: Project) = dependsOn.addAll(projects)
-
/** Used to disambiguate various name properties */
@Directive
val projectName: String get() = name
@@ -129,18 +120,6 @@ open class Project(
return result
}
- class Dep(val file: File, val id: String)
-
- /**
- * @return a list of the transitive dependencies (absolute paths to jar files) for the given dependencies.
- * Can be used for example as `collect(compileDependencies)`.
- */
- @Directive
- fun collect(dependencies: List) : List {
- return (Kobalt.context?.dependencyManager?.transitiveClosure(dependencies) ?: emptyList())
- .map { Dep(it.jarFile.get(), it.id) }
- }
-
override fun toString() = "[Project $name]"
}
@@ -155,7 +134,6 @@ class Dependencies(val project: Project,
val dependencies: ArrayList,
val optionalDependencies: ArrayList,
val providedDependencies: ArrayList,
- val compileOnlyDependencies: ArrayList,
val runtimeDependencies: ArrayList,
val excludedDependencies: ArrayList,
val nativeDependencies: ArrayList) {
@@ -167,7 +145,7 @@ class Dependencies(val project: Project,
* future tasks receive a get(), the repos will be correct.
*/
private fun addToDependencies(project: Project, dependencies: ArrayList,
- dep: Array, optional: Boolean = false, excludeConfig: ExcludeConfig? = null): List>
+ dep: Array, optional: Boolean = false): List>
= with(dep.map {
val resolved =
if (KobaltMavenResolver.isRangeVersion(it)) {
@@ -182,73 +160,12 @@ class Dependencies(val project: Project,
DependencyManager.create(resolved, optional, project.directory)
}) {
dependencies.addAll(this)
- if (excludeConfig != null) {
- this.forEach { it.excluded.add(excludeConfig) }
- }
-
this.map { FutureTask { it.jarFile.get() } }
}
@Directive
fun compile(vararg dep: String) = addToDependencies(project, dependencies, dep)
- class ExcludeConfig {
- val ids = arrayListOf()
-
- @Directive
- fun exclude(vararg passedIds: String) = ids.addAll(passedIds)
-
- class ArtifactConfig(
- var groupId: String? = null,
- var artifactId: String? = null,
- var version: String? = null
- )
-
- val artifacts = arrayListOf()
-
- @Directive
- fun exclude(groupId: String? = null, artifactId: String? = null, version: String? = null)
- = artifacts.add(ArtifactConfig(groupId, artifactId, version))
-
- fun match(pattern: String?, id: String) : Boolean {
- return pattern == null || Pattern.compile(pattern).matcher(id).matches()
- }
-
- /**
- * @return true if the dependency is excluded with any of the exclude() directives. The matches
- * are performed by a regular expression match against the dependency.
- */
- fun isExcluded(dep: IClasspathDependency) : Boolean {
- // Straight id match
- var result = ids.any { match(it, dep.id) }
-
- // Match on any combination of (groupId, artifactId, version)
- if (! result && dep.isMaven) {
- val mavenDep = dep as AetherDependency
- val artifact = mavenDep.artifact
- result = artifacts.any {
- val match1 = it.groupId == null || match(it.groupId, artifact.groupId)
- val match2 = it.artifactId == null || match(it.artifactId, artifact.artifactId)
- val match3 = it.version == null || match(it.version, artifact.version)
- match1 && match2 && match3
- }
- }
-
- return result
- }
- }
-
- @Directive
- fun compile(dep: String, init: ExcludeConfig.() -> Unit) {
- val excludeConfig = ExcludeConfig().apply {
- init()
- }
- addToDependencies(project, dependencies, arrayOf(dep), excludeConfig = excludeConfig)
- }
-
- @Directive
- fun compileOnly(vararg dep: String) = addToDependencies(project, compileOnlyDependencies, dep)
-
@Directive
fun compileOptional(vararg dep: String) {
addToDependencies(project, optionalDependencies, dep, optional = true)
@@ -258,6 +175,7 @@ class Dependencies(val project: Project,
@Directive
fun provided(vararg dep: String) {
addToDependencies(project, providedDependencies, dep)
+ addToDependencies(project, dependencies, dep)
}
@Directive
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..2c72c7b6 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
@@ -1,24 +1,25 @@
package com.beust.kobalt.archive
-import com.beust.kobalt.*
+import com.beust.kobalt.Features
+import com.beust.kobalt.IFileSpec
import com.beust.kobalt.api.KobaltContext
import com.beust.kobalt.api.Project
import com.beust.kobalt.api.annotation.ExportedProjectProperty
-import com.beust.kobalt.misc.JarUtils
-import com.beust.kobalt.misc.KFiles
-import com.beust.kobalt.misc.kobaltLog
+import com.beust.kobalt.misc.*
import java.io.File
+import java.io.FileOutputStream
+import java.io.OutputStream
import java.util.*
+import java.util.zip.ZipOutputStream
class Archives {
companion object {
@ExportedProjectProperty(doc = "The name of the jar file", type = "String")
const val JAR_NAME = "jarName"
- @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}"
+ private val DEFAULT_STREAM_FACTORY = { os : OutputStream -> ZipOutputStream(os) }
+
+ fun defaultArchiveName(project: Project) = project.name + "-" + project.version
fun generateArchive(project: Project,
context: KobaltContext,
@@ -26,15 +27,15 @@ class Archives {
suffix: String,
includedFiles: List,
expandJarFiles : Boolean = false,
- manifest: java.util.jar.Manifest? = null) : File {
+ outputStreamFactory: (OutputStream) -> ZipOutputStream = DEFAULT_STREAM_FACTORY) : File {
val fullArchiveName = context.variant.archiveName(project, archiveName, suffix)
val archiveDir = File(KFiles.libsDir(project))
val result = File(archiveDir.path, fullArchiveName)
context.logger.log(project.name, 3, "Creating $result")
if (! Features.USE_TIMESTAMPS || isOutdated(project.directory, includedFiles, result)) {
try {
- MetaArchive(result, manifest).use { metaArchive ->
- JarUtils.addFiles(project.directory, includedFiles, metaArchive, expandJarFiles)
+ outputStreamFactory(FileOutputStream(result)).use {
+ JarUtils.addFiles(project.directory, includedFiles, it, expandJarFiles)
context.logger.log(project.name, 2, "Added ${includedFiles.size} files to $result")
context.logger.log(project.name, 1, " Created $result")
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Jar.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Jar.kt
index d5086cbd..f8a47848 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Jar.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Jar.kt
@@ -8,7 +8,7 @@ import com.beust.kobalt.api.annotation.Directive
*/
open class Jar(override val project: Project,
override var name : String = Archives.defaultArchiveName(project) + ".jar",
- override var fatJar: Boolean = false) : Zip(project, name, fatJar), AttributeHolder {
+ var fatJar: Boolean = false) : Zip(project, name), AttributeHolder {
@Directive
fun manifest(init: Manifest.(p: Manifest) -> Unit) : Manifest {
val m = Manifest(this)
@@ -18,7 +18,7 @@ open class Jar(override val project: Project,
// Need to specify the version or attributes will just be dropped
@Directive
- override val attributes = arrayListOf(Pair("Manifest-Version", "1.0"))
+ val attributes = arrayListOf(Pair("Manifest-Version", "1.0"))
override fun addAttribute(k: String, v: String) {
attributes.add(Pair(k, v))
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
deleted file mode 100644
index c217c83e..00000000
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/MetaArchive.kt
+++ /dev/null
@@ -1,125 +0,0 @@
-package com.beust.kobalt.archive
-
-import com.beust.kobalt.Glob
-import com.beust.kobalt.misc.KFiles
-import org.apache.commons.compress.archivers.ArchiveEntry
-import org.apache.commons.compress.archivers.zip.ZipArchiveEntry
-import org.apache.commons.compress.archivers.zip.ZipArchiveOutputStream
-import java.io.Closeable
-import java.io.File
-import java.io.FileInputStream
-import java.io.FileOutputStream
-import java.util.jar.Manifest
-import org.apache.commons.compress.archivers.zip.ZipFile as ApacheZipFile
-
-/**
- * Abstraction of a zip/jar/war archive that automatically manages the addition of expanded jar files.
- * 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 {
- 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)
- ZipArchiveEntry(actualPath).let { entry ->
- maybeCreateParentDirectories(File(actualPath))
- maybeAddEntry(entry) {
- addEntry(entry, inputStream)
- }
- }
- }
- }
-
- 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
- for (entry in jarEntries) {
- maybeAddEntry(entry) {
- zos.addRawArchiveEntry(entry, jar.getRawInputStream(entry))
- }
- }
- }
- }
-
-
-
- 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
- }
-
- override fun close() = zos.close()
-
- private fun addEntry(entry: ArchiveEntry, inputStream: FileInputStream?) {
- zos.putArchiveEntry(entry)
- 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)
- }
- }
-}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/War.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/War.kt
index 978f21bf..295a1987 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/War.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/War.kt
@@ -6,7 +6,7 @@ import com.beust.kobalt.glob
class War(override val project: Project, override var name: String = Archives.defaultArchiveName(project) + ".war")
: Jar(project, name), AttributeHolder {
init {
- include(from("src/main/webapp"), to(""), glob("**"))
+ include(from("src/main/webapp"),to(""), glob("**"))
include(from("kobaltBuild/classes"), to("WEB-INF/classes"), glob("**"))
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Zip.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Zip.kt
index 41957218..61237291 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Zip.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/archive/Zip.kt
@@ -1,13 +1,22 @@
package com.beust.kobalt.archive
-import com.beust.kobalt.*
+import com.beust.kobalt.Glob
+import com.beust.kobalt.IFileSpec
import com.beust.kobalt.api.Project
import com.beust.kobalt.api.annotation.Directive
+import com.beust.kobalt.misc.From
+import com.beust.kobalt.misc.IncludedFile
+import com.beust.kobalt.misc.To
-open class Zip(open val project: Project, open var name: String = Archives.defaultArchiveName(project) + ".zip",
- open var fatJar: Boolean = false): AttributeHolder, IncludeFromTo() {
+open class Zip(open val project: Project, open var name: String = Archives.defaultArchiveName(project) + ".zip") {
val excludes = arrayListOf()
+ @Directive
+ fun from(s: String) = From(s)
+
+ @Directive
+ fun to(s: String) = To(s)
+
@Directive
fun exclude(vararg files: String) {
files.forEach { excludes.add(Glob(it)) }
@@ -19,9 +28,26 @@ open class Zip(open val project: Project, open var name: String = Archives.defau
}
@Directive
- open val attributes = arrayListOf(Pair("Manifest-Version", "1.0"))
-
- override fun addAttribute(k: String, v: String) {
- attributes.add(Pair(k, v))
+ fun include(vararg files: String) {
+ includedFiles.add(IncludedFile(files.map { IFileSpec.FileSpec(it) }))
}
+
+ @Directive
+ fun include(from: From, to: To, vararg specs: String) {
+ includedFiles.add(IncludedFile(from, to, specs.map { IFileSpec.FileSpec(it) }))
+ }
+
+ @Directive
+ fun include(from: From, to: To, vararg specs: IFileSpec.GlobSpec) {
+ includedFiles.add(IncludedFile(from, to, listOf(*specs)))
+ }
+
+ /**
+ * Prefix path to be removed from the zip file. For example, if you add "build/lib/a.jar" to the zip
+ * file and the excludePrefix is "build/lib", then "a.jar" will be added at the root of the zip file.
+ */
+ val includedFiles = arrayListOf()
+
}
+
+
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ActorUtils.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ActorUtils.kt
index e9b315a5..42aac9e2 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ActorUtils.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ActorUtils.kt
@@ -1,6 +1,7 @@
package com.beust.kobalt.internal
import com.beust.kobalt.api.IProjectAffinity
+import com.beust.kobalt.api.ISimpleAffinity
import com.beust.kobalt.api.KobaltContext
import com.beust.kobalt.api.Project
@@ -10,13 +11,19 @@ class ActorUtils {
* Return the plug-in actor with the highest affinity.
*/
fun selectAffinityActor(project: Project, context: KobaltContext, actors: List)
- = actors.maxBy { it.affinity(project, context) }
+ = actors.maxBy { it.affinity(project, context) }
/**
* Return all the plug-in actors with a non zero affinity sorted from the highest to the lowest.
*/
fun selectAffinityActors(project: Project, context: KobaltContext, actors: List)
= actors.filter { it.affinity(project, context) > 0 }
- .sortedByDescending { it.affinity(project, context) }
+ .sortedByDescending { it.affinity(project, context) }
+
+ /**
+ * Return the plug-in actor with the highest affinity.
+ */
+ fun , A> selectAffinityActor(actors: List, arg: A) = actors.maxBy { it.affinity(arg) }
}
+
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/BaseProjectRunner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/BaseProjectRunner.kt
index 963255bd..2dc77ca0 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/BaseProjectRunner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/BaseProjectRunner.kt
@@ -1,7 +1,5 @@
package com.beust.kobalt.internal
-import com.beust.kobalt.TestResult
-import com.beust.kobalt.api.IBuildListener
import com.beust.kobalt.api.KobaltContext
import com.beust.kobalt.api.Project
import com.beust.kobalt.api.ProjectBuildStatus
@@ -27,14 +25,9 @@ abstract class BaseProjectRunner {
}
fun runBuildListenersForTask(project: Project, context: KobaltContext, taskName: String, start: Boolean,
- success: Boolean = false, testResult: TestResult? = null) {
+ success: Boolean = false) {
context.pluginInfo.buildListeners.forEach {
- if (start) {
- it.taskStart(project, context, taskName)
- } else {
- val info = IBuildListener.TaskEndInfo(success, testResult?.shortMessage, testResult?.longMessage)
- it.taskEnd(project, context, taskName, info)
- }
+ if (start) it.taskStart(project, context, taskName) else it.taskEnd(project, context, taskName, success)
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/BuildListeners.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/BuildListeners.kt
index 58d8eed8..1a8781a5 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/BuildListeners.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/BuildListeners.kt
@@ -11,8 +11,7 @@ import java.util.concurrent.ConcurrentHashMap
*/
class BuildListeners : IBuildListener, IBuildReportContributor {
class ProfilerInfo(val taskName: String, val durationMillis: Long)
- class ProjectInfo(val projectName: String, var durationMillis: Long = 0,
- var shortMessage: String? = null, var longMessage: String? = null)
+ class ProjectInfo(val projectName: String, var durationMillis: Long = 0)
private val startTimes = ConcurrentHashMap()
private val timings = arrayListOf()
@@ -30,21 +29,18 @@ class BuildListeners : IBuildListener, IBuildReportContributor {
}
// IBuildListener
- override fun taskEnd(project: Project, context: KobaltContext, taskName: String, info: IBuildListener.TaskEndInfo) {
- val success = info.success
+ override fun taskEnd(project: Project, context: KobaltContext, taskName: String, success: Boolean) {
if (! success) hasFailures = true
startTimes[taskName]?.let {
val taskTime = System.currentTimeMillis() - it
timings.add(ProfilerInfo(taskName, taskTime))
projectInfos[project.name]?.let {
- it.durationMillis += taskTime
- if (info.shortMessage != null && it.shortMessage == null) it.shortMessage = info.shortMessage
- if (info.longMessage != null && it.longMessage == null) it.longMessage = info.longMessage
+ it.durationMillis += taskTime.toLong()
}
}
}
- private val projectStatuses = arrayListOf>()
+ private val projectStatuses = arrayListOf>()
// IBuildListener
override fun projectStart(project: Project, context: KobaltContext) {
@@ -53,9 +49,7 @@ class BuildListeners : IBuildListener, IBuildReportContributor {
// IBuildListener
override fun projectEnd(project: Project, context: KobaltContext, status: ProjectBuildStatus) {
- val shortMessage = projectInfos[project.name]?.shortMessage
- val statusText = status.toString() + (if (shortMessage != null) " ($shortMessage)" else "")
- projectStatuses.add(Pair(project, statusText))
+ projectStatuses.add(Pair(project, status))
}
// IBuildReportContributor
@@ -76,15 +70,10 @@ class BuildListeners : IBuildListener, IBuildReportContributor {
}
- // Calculate the longest short message so we can create a column long enough to contain it
- val width = 12 + (projectInfos.values.map { it.shortMessage?.length ?: 0 }.maxBy { it } ?: 0)
-
fun col1(s: String) = String.format(" %1\$-30s", s)
- fun col2(s: String) = String.format(" %1\$-${width}s", s)
+ fun col2(s: String) = String.format(" %1\$-13s", s)
fun col3(s: String) = String.format(" %1\$-8s", s)
-
-
// Only print the build report if there is more than one project and at least one of them failed
if (timings.any()) {
// if (timings.size > 1 && hasFailures) {
@@ -94,7 +83,7 @@ class BuildListeners : IBuildListener, IBuildReportContributor {
table.append(AsciiArt.logBox(listOf(line), AsciiArt.bottomLeft2, AsciiArt.bottomRight2, indent = 10) + "\n")
projectStatuses.forEach { pair ->
val projectName = pair.first.name
- val cl = listOf(col1(projectName), col2(pair.second),
+ val cl = listOf(col1(projectName), col2(pair.second.toString()),
col3(formatMillisLeft(projectInfos[projectName]!!.durationMillis, 8)))
.joinToString(AsciiArt.verticalBar)
table.append(" " + AsciiArt.verticalBar + " " + cl + " " + AsciiArt.verticalBar + "\n")
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/CompilerUtils.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/CompilerUtils.kt
index 758a10e9..a340662b 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/CompilerUtils.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/CompilerUtils.kt
@@ -30,7 +30,7 @@ class CompilerUtils @Inject constructor(val files: KFiles, val dependencyManager
}
val sourceFiles = KFiles.findSourceFiles(project.directory,
contributedSourceDirs.map { it.path }, compiler.sourceSuffixes)
- if (sourceFiles.isNotEmpty()) {
+ if (sourceFiles.size > 0) {
// TODO: createCompilerActionInfo recalculates the source files, only compute them
// once and pass them
val info = createCompilerActionInfo(project, context, compiler, isTest,
@@ -70,12 +70,7 @@ class CompilerUtils @Inject constructor(val files: KFiles, val dependencyManager
copyResources(project, context, SourceSet.of(isTest))
val fullClasspath = dependencyManager.calculateDependencies(project, context,
- scopes = if (isTest) {
- listOf(Scope.COMPILE, Scope.COMPILEONLY, Scope.TEST)
- } else {
- listOf(Scope.COMPILE, Scope.COMPILEONLY)
- })
-
+ scopes = listOf(Scope.COMPILE, Scope.TEST))
File(project.directory, buildDirectory.path).mkdirs()
@@ -124,8 +119,7 @@ class CompilerUtils @Inject constructor(val files: KFiles, val dependencyManager
// depending on the compiler's ability, sourceFiles can actually contain a list of directories
// instead of individual source files.
val projectDirectory = File(project.directory)
- val sourceFiles =
- if (compiler.canCompileDirectories) {
+ val sourceFiles = if (compiler.canCompileDirectories) {
allSourceDirectories.map { File(projectDirectory, it.path).path }
} else {
files.findRecursively(projectDirectory, allSourceDirectories,
@@ -173,7 +167,7 @@ class CompilerUtils @Inject constructor(val files: KFiles, val dependencyManager
// Finally, alter the info with the compiler interceptors before returning it
val initialActionInfo = CompilerActionInfo(projectDirectory.path, classpath, allSources,
sourceSuffixes, buildDirectory, emptyList() /* the flags will be provided by flag contributors */,
- emptyList(), context.internalContext.forceRecompile)
+ emptyList())
val result = context.pluginInfo.compilerInterceptors.fold(initialActionInfo, { ai, interceptor ->
interceptor.intercept(project, context, ai)
})
@@ -201,7 +195,7 @@ class CompilerUtils @Inject constructor(val files: KFiles, val dependencyManager
.filter(File::exists)
.forEach {
context.logger.log(project.name, 2, "Copying from $it to $absOutputDir")
- KFiles.copyRecursively(it, absOutputDir, replaceExisting = true)
+ KFiles.copyRecursively(it, absOutputDir, deleteFirst = false)
}
} else {
context.logger.log(project.name, 2, "No resources to copy for $sourceSet")
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/DynamicGraph.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/DynamicGraph.kt
index a3e26afd..2b1f3c2f 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/DynamicGraph.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/DynamicGraph.kt
@@ -1,14 +1,18 @@
package com.beust.kobalt.internal
-import com.beust.kobalt.*
-import com.beust.kobalt.misc.*
+import com.beust.kobalt.AsciiTable
+import com.beust.kobalt.KobaltException
+import com.beust.kobalt.TaskResult
+import com.beust.kobalt.misc.NamedThreadFactory
+import com.beust.kobalt.misc.error
+import com.beust.kobalt.misc.kobaltLog
+import com.beust.kobalt.misc.warn
import com.google.common.collect.HashMultimap
import java.lang.reflect.InvocationTargetException
import java.util.*
import java.util.concurrent.*
-open class TaskResult2(success: Boolean, testResult: TestResult? = null,
- errorMessage: String? = null, val value: T) : TaskResult(success, testResult, errorMessage) {
+open class TaskResult2(success: Boolean, errorMessage: String?, val value: T) : TaskResult(success, errorMessage) {
override fun toString() = com.beust.kobalt.misc.toString("TaskResult", "value", value, "success", success)
}
@@ -299,14 +303,14 @@ class DynamicGraphExecutor(val graph : DynamicGraph, val factory: IThreadW
duration = " (" + ((hl.timestamp - start) / 1000)
.toInt().toString() + ")"
} else {
- kobaltLog(1, "DONOTCOMMIT")
+ println("DONOTCOMMIT")
}
}
return hl.name + duration
}
historyLog.forEach { hl ->
- kobaltLog(1, "CURRENT LOG: " + currentLog + " HISTORY LINE: " + hl)
+ println("CURRENT LOG: " + currentLog + " HISTORY LINE: " + hl)
if (hl.start) {
projectStart[hl.name] = hl.timestamp
}
@@ -314,10 +318,10 @@ class DynamicGraphExecutor(val graph : DynamicGraph, val factory: IThreadW
currentLog = CompressedLog(hl.timestamp, hashMapOf(hl.threadId to hl.name))
} else currentLog?.let { cl ->
if (! hl.start || hl.timestamp - cl.timestamp < 1000) {
- kobaltLog(1, " CURRENT LOG IS WITHING ONE SECOND: $hl")
+ println(" CURRENT LOG IS WITHING ONE SECOND: $hl")
cl.threadMap[hl.threadId] = toName(hl)
} else {
- kobaltLog(1, " ADDING COMPRESSED LINE $cl")
+ println(" ADDING COMPRESSED LINE $cl")
compressed.add(cl)
currentLog = CompressedLog(hl.timestamp, hashMapOf(hl.threadId to toName(hl)))
}
@@ -374,7 +378,7 @@ class DynamicGraphExecutor(val graph : DynamicGraph, val factory: IThreadW
return table
}
- kobaltLog(1, displayRegularLog(table).build())
+ println(displayRegularLog(table).build())
}
}
@@ -394,7 +398,7 @@ fun main(argv: Array) {
object: IWorker {
override fun call(): TaskResult2? {
kobaltLog(1, " Running worker $it")
- return TaskResult2(true, value = it)
+ return TaskResult2(true, null, it)
}
override val priority: Int get() = 0
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..2dcea900 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.*
@@ -16,27 +15,14 @@ abstract class GenericTestRunner: ITestRunnerContributor {
abstract val dependencyName : String
abstract val mainClass: String
abstract val annotationPackage: String
- abstract val runnerName: String
- 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
- open fun onFinish(project: Project) {}
-
- 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 {
- val tr = runTests(project, context, classpath, configName)
- return TaskResult(tr.success, testResult = tr)
- }
+ classpath: List)
+ = TaskResult(runTests(project, context, classpath, configName))
override fun affinity(project: Project, context: KobaltContext) : Int {
val result =
@@ -69,7 +55,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 })
}
/**
@@ -108,20 +94,17 @@ abstract class GenericTestRunner: ITestRunnerContributor {
/**
* @return true if all the tests passed
*/
- open fun runTests(project: Project, context: KobaltContext, classpath: List,
- configName: String) : TestResult {
+ fun runTests(project: Project, context: KobaltContext, classpath: List,
+ configName: String) : Boolean {
var result = false
- 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 +120,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")
@@ -146,16 +134,7 @@ abstract class GenericTestRunner: ITestRunnerContributor {
} else {
throw KobaltException("Couldn't find a test configuration named \"$configName\"")
}
-
- 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)
+ return result
}
/*
@@ -163,14 +142,13 @@ abstract class GenericTestRunner: ITestRunnerContributor {
*/
@VisibleForTesting
fun calculateAllJvmArgs(project: Project, context: KobaltContext,
- testConfig: TestConfig, classpath: List, pluginInfo: IPluginInfo) : List {
- val fullClasspath = classpath.map { it.jarFile.get().absolutePath } + extraClasspath
+ testConfig: TestConfig, classpath: List, pluginInfo: IPluginInfo) : List {
// Default JVM args
val jvmFlags = arrayListOf().apply {
addAll(testConfig.jvmArgs)
add("-ea")
add("-classpath")
- add(fullClasspath.joinToString(File.pathSeparator))
+ add(classpath.map { it.jarFile.get().absolutePath }.joinToString(File.pathSeparator))
}
// JVM flags from the contributors
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
deleted file mode 100644
index 2e9b534c..00000000
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/JUnit5Runner.kt
+++ /dev/null
@@ -1,152 +0,0 @@
-package com.beust.kobalt.internal
-
-import com.beust.jcommander.JCommander
-import com.beust.jcommander.Parameter
-import com.beust.kobalt.TestConfig
-import com.beust.kobalt.api.IAffinity
-import com.beust.kobalt.api.IClasspathDependency
-import com.beust.kobalt.api.KobaltContext
-import com.beust.kobalt.api.Project
-import com.beust.kobalt.misc.KFiles
-import com.beust.kobalt.misc.KobaltLogger
-import com.google.inject.Inject
-import org.junit.platform.engine.TestExecutionResult
-import org.junit.platform.engine.discovery.DiscoverySelectors
-import org.junit.platform.engine.reporting.ReportEntry
-import org.junit.platform.engine.support.descriptor.MethodSource
-import org.junit.platform.launcher.LauncherDiscoveryRequest
-import org.junit.platform.launcher.TestExecutionListener
-import org.junit.platform.launcher.TestIdentifier
-import org.junit.platform.launcher.TestPlan
-import org.junit.platform.launcher.core.LauncherDiscoveryRequestBuilder
-import org.junit.platform.launcher.core.LauncherFactory
-import java.io.File
-import java.nio.file.Paths
-
-/**
- * Runner for JUnit 5 tests. This class also contains a main() entry point since JUnit 5 no longer supplies one.
- */
-class JUnit5Runner @Inject constructor(kFiles: KFiles) : GenericTestRunner() {
-
- override val dependencyName = "jupiter"
- override val annotationPackage = "org.junit.jupiter.api"
- override val mainClass = "com.beust.kobalt.internal.JUnit5RunnerKt"
- override val runnerName = "JUnit 5"
-
- 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
- else 0
- return result
-
- }
-
- override fun args(project: Project, context: KobaltContext, classpath: List, testConfig: TestConfig): List {
- val testClassDir = KFiles.joinDir(project.buildDirectory, KFiles.TEST_CLASSES_DIR)
- val classDir = KFiles.joinDir(project.buildDirectory, KFiles.CLASSES_DIR)
- val args = listOf("--testClassDir", testClassDir,
- "--classDir", classDir,
- "--log", KobaltLogger.LOG_LEVEL.toString())
- return args
- }
-
- override val extraClasspath = kFiles.kobaltJar
-}
-
-private class Args {
- @Parameter(names = arrayOf("--log"))
- var log: Int = 1
-
- @Parameter(names = arrayOf("--testClassDir"))
- var testClassDir: String = "kobaltBuild/test-classes"
-
- @Parameter(names = arrayOf("--classDir"))
- var classDir: String = "kobaltBuild/classes"
-}
-
-fun main(argv: Array) {
- val args = Args()
- val jc = JCommander(args)
- jc.parse(*argv)
-
- val testClassDir = File(args.testClassDir).absolutePath
- val classDir = File(args.classDir).absolutePath
- val request : LauncherDiscoveryRequest = LauncherDiscoveryRequestBuilder()
- .selectors(DiscoverySelectors.selectClasspathRoots(setOf(
- Paths.get(testClassDir),
- Paths.get(classDir)
- )))
- .selectors(DiscoverySelectors.selectDirectory(testClassDir))
- .build()
-
- fun testName(id: TestIdentifier) : String? {
- val result =
- if (id.source.isPresent) {
- val source = id.source.get()
- if (source is MethodSource) {
- source.className + "." + source.methodName
- } else {
- null
- }
- } else {
- null
- }
- return result
- }
-
- var passed = 0
- var failed = 0
- var skipped = 0
- var aborted = 0
-
- fun log(level: Int, s: String) {
- if (level <= args.log) println(s)
- }
-
- val listener = object: TestExecutionListener {
- override fun executionFinished(testIdentifier: TestIdentifier, testExecutionResult: TestExecutionResult) {
- val testName = testName(testIdentifier)
- if (testName != null) {
- when(testExecutionResult.status) {
- TestExecutionResult.Status.FAILED -> {
- log(1, "FAILED: $testName, reason: " + testExecutionResult.throwable.get().toString())
- failed++
- }
- TestExecutionResult.Status.ABORTED -> {
- log(1, "ABORTED: $testName, reason: " + testExecutionResult.throwable.get().toString())
- aborted++
- }
- TestExecutionResult.Status.SUCCESSFUL -> {
- log(2, "PASSED: $testName")
- passed++
- } else -> {
-
- }
- }
- }
- }
-
- override fun executionSkipped(testIdentifier: TestIdentifier, reason: String) {
- testName(testIdentifier)?.let {
- log(1, "Skipping $it because $reason")
- skipped++
- }
- }
-
- override fun executionStarted(testIdentifier: TestIdentifier) {
- testName(testIdentifier)?.let {
- log(2, "Starting $it")
- }
- }
-
- override fun testPlanExecutionStarted(testPlan: TestPlan?) {}
- override fun dynamicTestRegistered(testIdentifier: TestIdentifier?) {}
- override fun reportingEntryPublished(testIdentifier: TestIdentifier?, entry: ReportEntry?) {}
- override fun testPlanExecutionFinished(testPlan: TestPlan?) {}
- }
-
- LauncherFactory.create().execute(request, listener)
-
- log(1, "TEST RESULTS: $passed PASSED, $failed FAILED, $skipped SKIPPED, $aborted ABORTED")
-}
\ No newline at end of file
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..eec22afd 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,29 +4,16 @@ 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() {
override val mainClass = "org.junit.runner.JUnitCore"
+
override val annotationPackage = "org.junit"
+
override val dependencyName = "junit"
- override val runnerName = "JUnit 4"
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..25294934 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
@@ -23,11 +23,12 @@ class JvmCompiler @Inject constructor(val dependencyManager: DependencyManager)
flags: List): TaskResult {
// Dependencies
- val allDependencies = (info.dependencies + dependencyManager.calculateDependencies(project, context!!,
- passedDependencies = info.dependencies))
+ val allDependencies = (info.dependencies
+ + dependencyManager.calculateDependencies(project, context!!, passedDependencies = info.dependencies))
.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..c27e26bb 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,
@@ -86,11 +88,10 @@ open class JvmCompilerPlugin @Inject constructor(
if (testContributor != null && testContributor.affinity(project, context) > 0) {
// val td1 = dependencyManager.testDependencies(project, context)
val testDependencies = dependencyManager.calculateDependencies(project, context,
- dependencyFilter = dependencyManager.createDependencyFilter(project, project.testDependencies),
scopes = listOf(Scope.TEST))
val compileDependencies = dependencyManager.calculateDependencies(project, context,
- scopes = listOf(Scope.COMPILE, Scope.COMPILEONLY))
- val allDependencies = (testDependencies + compileDependencies).distinct()
+ scopes = listOf(Scope.COMPILE))
+ val allDependencies = (compileDependencies + testDependencies).toHashSet()
return testContributor.run(project, context, configName, allDependencies.toList())
} else {
context.logger.log(project.name, 2,
@@ -157,10 +158,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 +171,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 +181,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 +220,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/KobaltSettingsXml.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KobaltSettingsXml.kt
index 2eb5374c..387c8a59 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KobaltSettingsXml.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/KobaltSettingsXml.kt
@@ -25,7 +25,7 @@ class KobaltSettingsXml {
@XmlElement(name = "localMavenRepo") @JvmField
var localMavenRepo: String = homeDir(KFiles.KOBALT_DOT_DIR, "localMavenRepo")
- @XmlElement(name = "defaultRepos") @JvmField
+ @XmlElement(name = "defaulRepos") @JvmField
var defaultRepos: DefaultReposXml? = null
@XmlElement(name = "proxies") @JvmField
@@ -42,9 +42,6 @@ class KobaltSettingsXml {
@XmlElement(name = "kobaltCompilerSeparateProcess") @JvmField
var kobaltCompilerSeparateProcess: Boolean = false
-
- @XmlElement(name = "autoUpdate") @JvmField
- var autoUpdate: Boolean = false
}
class ProxiesXml {
@@ -88,11 +85,6 @@ class KobaltSettings @Inject constructor(val xmlFile: KobaltSettingsXml) {
*/
val localMavenRepo = KFiles.makeDir(xmlFile.localMavenRepo)
- /**
- * If true, Kobalt will automatically update itself if a new version is found.
- */
- val autoUpdate = xmlFile.autoUpdate
-
/**
* If true, the Kotlin compiler will always be launched in a separate JVM, even if the requested
* version is the same as the internal version.
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..90c5d354 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,21 +1,16 @@
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.
*/
class KotlinTestRunner : JUnitRunner() {
override val dependencyName = "io.kotlintest"
- override val runnerName = "Kotlin Test"
/**
* 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/ParallelLogger.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ParallelLogger.kt
index 519a94c9..afaa7e21 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ParallelLogger.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ParallelLogger.kt
@@ -2,7 +2,9 @@ package com.beust.kobalt.internal
import com.beust.kobalt.Args
import com.beust.kobalt.KobaltException
-import com.beust.kobalt.misc.*
+import com.beust.kobalt.misc.kobaltError
+import com.beust.kobalt.misc.kobaltLog
+import com.beust.kobalt.misc.kobaltWarn
import com.google.inject.Inject
import com.google.inject.Singleton
import java.util.*
@@ -65,9 +67,9 @@ class ParallelLogger @Inject constructor(val args: Args) : ILogger {
}
private fun debug(s: CharSequence) {
- if (args.log >= 3) {
+ if (args.log >= 2) {
val time = System.currentTimeMillis() - startTime!!
- kobaltLog(1, " ### [$time] $s")
+ println(" ### [$time] $s")
}
}
@@ -125,6 +127,6 @@ class ParallelLogger @Inject constructor(val args: Args) : ILogger {
runningProjects.forEach {
emptyProjectLog(it)
}
- kobaltLog(1, "")
+ println("")
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ParallelProjectRunner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ParallelProjectRunner.kt
index d98f0d8a..7041c402 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ParallelProjectRunner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/ParallelProjectRunner.kt
@@ -54,12 +54,12 @@ class ParallelProjectRunner(val tasksByNames: (Project) -> ListMultimap ListMultimap ListMultimap().apply {
projects.forEach { project ->
addNode(ProjectTask(project, args.dryRun))
- project.allProjectDependedOn().forEach {
+ project.dependsOn.forEach {
addEdge(ProjectTask(project, args.dryRun), ProjectTask(it, args.dryRun))
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/SequentialProjectRunner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/SequentialProjectRunner.kt
index ec99b723..1f13626c 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/SequentialProjectRunner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/SequentialProjectRunner.kt
@@ -39,7 +39,7 @@ class SequentialProjectRunner(val tasksByNames: (Project) -> ListMultimap 0) {
klog(2, "Marking project $projectName as skipped")
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/SpekRunner.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/SpekRunner.kt
index 0c1ddad6..2129a315 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/SpekRunner.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/SpekRunner.kt
@@ -6,6 +6,5 @@ package com.beust.kobalt.internal
*/
class SpekRunner : JUnitRunner() {
override val dependencyName = "org.jetbrains.spek"
- override val runnerName = "Spek"
}
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..2139326c 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
@@ -17,7 +17,7 @@ import javax.inject.Singleton
@Singleton
class TaskManager @Inject constructor(val args: Args,
val incrementalManagerFactory: IncrementalManager.IFactory,
- val kobaltLog: ParallelLogger) {
+ val pluginInfo: PluginInfo, val kobaltLog: ParallelLogger) {
private val dependsOn = TreeMultimap.create()
private val reverseDependsOn = TreeMultimap.create()
private val runBefore = TreeMultimap.create()
@@ -80,9 +80,6 @@ class TaskManager @Inject constructor(val args: Args,
}
}
-// @Inject
-// lateinit var pluginInfo: PluginInfo
-
fun runTargets(passedTaskNames: List, allProjects: List): RunTargetResult {
// Check whether tasks passed at command line exist
passedTaskNames.forEach {
@@ -90,7 +87,6 @@ class TaskManager @Inject constructor(val args: Args,
throw KobaltException("Unknown task: $it")
}
- val pluginInfo = Kobalt.INJECTOR.getInstance(PluginInfo::class.java)
var taskInfos = calculateDependentTaskNames(passedTaskNames, allProjects)
// Remove non existing tasks (e.g. dynamic task defined for a single project)
@@ -149,7 +145,7 @@ class TaskManager @Inject constructor(val args: Args,
val topological = Topological().apply {
projects.forEach { project ->
addNode(project)
- project.allProjectDependedOn().forEach {
+ project.dependsOn.forEach {
addEdge(project, it)
}
}
@@ -164,7 +160,7 @@ class TaskManager @Inject constructor(val args: Args,
return result
} else {
val rootProject = projects.find { it.name == ti.project }!!
- val allProjects = DynamicGraph.transitiveClosure(rootProject, Project::allProjectDependedOn)
+ val allProjects = DynamicGraph.transitiveClosure(rootProject, { p -> p.dependsOn })
val sortedProjects = sortProjectsTopologically(allProjects)
val sortedMaps = sortedProjects.map { TaskInfo(it.name, "compile")}
val result = sortedMaps.subList(0, sortedMaps.size - 1) + listOf(ti)
@@ -272,8 +268,7 @@ class TaskManager @Inject constructor(val args: Args,
object : BasePluginTask(plugin, name, description, group, project) {
override fun call(): TaskResult2 {
val taskResult = task(project)
- return TaskResult2(taskResult.success, errorMessage = taskResult.errorMessage, value = this,
- testResult = taskResult.testResult)
+ return TaskResult2(taskResult.success, taskResult.errorMessage, this)
}
})
dependsOn.forEach { dependsOn(it, name) }
@@ -320,11 +315,9 @@ 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])
+ return TaskResult2(success, errorMessages.joinToString("\n"), tasks[0])
}
// override val timeOut : Long = 10000
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..008f2291 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
@@ -1,53 +1,28 @@
package com.beust.kobalt.internal
-import com.beust.kobalt.AsciiArt
import com.beust.kobalt.TestConfig
-import com.beust.kobalt.TestResult
import com.beust.kobalt.api.IClasspathDependency
import com.beust.kobalt.api.KobaltContext
import com.beust.kobalt.api.Project
-import com.beust.kobalt.maven.aether.AetherDependency
-import com.beust.kobalt.misc.*
-import org.testng.remote.RemoteArgs
-import org.testng.remote.strprotocol.JsonMessageSender
-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 com.beust.kobalt.misc.KFiles
+import com.beust.kobalt.misc.warn
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() {
override val mainClass = "org.testng.TestNG"
- override val dependencyName = "testng"
- 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")
+ override val dependencyName = "testng"
+
+ override val annotationPackage = "org.testng"
+
+ fun defaultOutput(project: Project) = KFiles.joinDir(project.buildDirectory, "test-output")
override fun args(project: Project, context: KobaltContext, classpath: List,
testConfig: TestConfig) = arrayListOf().apply {
-
- if (KobaltLogger.isQuiet) {
- add("-log")
- add("0")
- }
-
- 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))
+ var addOutput = true
+ testConfig.testArgs.forEach { arg ->
+ if (arg == "-d") addOutput = false
}
if (testConfig.testArgs.size == 0) {
@@ -57,212 +32,27 @@ class TestNgRunner : GenericTestRunner() {
add(testngXml.absolutePath)
} else {
val testClasses = findTestClasses(project, context, testConfig)
- if (testClasses.isNotEmpty()) {
+ if (testClasses.size > 0) {
+ if (addOutput) {
+ add("-d")
+ add(defaultOutput(project))
+ }
addAll(testConfig.testArgs)
add("-testclass")
add(testClasses.joinToString(","))
} else {
- if (!testConfig.isDefault) warn("Couldn't find any test classes for ${project.name}")
+ if (! testConfig.isDefault) warn("Couldn't find any test classes for ${project.name}")
// else do nothing: since the user didn't specify an explicit test{} directive, not finding
// any test sources is not a problem
}
}
} else {
+ if (addOutput) {
+ add("-d")
+ add(defaultOutput(project))
+ }
addAll(testConfig.testArgs)
}
}
-
- /**
- * Extract test results from testng-results.xml and initialize shortMessage.
- */
- override fun onFinish(project: Project) {
- File(defaultOutput(project), "testng-results.xml").let { file ->
- val ins = InputSource(FileReader(file))
- val doc = DocumentBuilderFactory.newInstance().newDocumentBuilder().parse(ins)
-
- val root = doc.documentElement
- 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) {
- "failed" -> failed = Integer.parseInt(attribute.value)
- "skipped" -> skipped = Integer.parseInt(attribute.value)
- "passed" -> passed = Integer.parseInt(attribute.value)
- }
- }
-
- if (failed == 0) {
- shortMessage = "$passed tests"
- } else if (failed > 0) {
- shortMessage = "$failed failed" + (if (skipped > 0) ", $skipped skipped" else "") + " tests"
- longMessage = "Failed tests:\n " + failedMethods.joinToString("\n ")
- }
- }
- }
-
- val VERSION_6_10 = StringVersion("6.10")
-
- fun _runTests(project: Project, context: KobaltContext, classpath: List,
-// override fun runTests(project: Project, context: KobaltContext, classpath: List,
- configName: String): TestResult {
-
- val testConfig = project.testConfigs.firstOrNull { it.name == configName }
-
- if (testConfig != null) {
- context.logger.log(project.name, 1, "Running enhanced TestNG runner")
-
- val testngDependency = (project.testDependencies.filter { it.id.contains("testng") }
- .firstOrNull() as AetherDependency).version
- val versions = findRemoteRunnerVersion(testngDependency)
- val useOldRunner = System.getProperty("testng.oldRunner") != null
- val result =
- if (versions != null && ! useOldRunner) {
- context.logger.log(project.name, 1, "Modern TestNG, displaying colors")
- displayPrettyColors(project, context, classpath, testConfig, versions)
- } else {
- context.logger.log(project.name, 1, "Older TestNG ($testngDependency), using the old runner")
- super.runTests(project, context, classpath, configName)
- }
- return result
- } else {
- return TestResult(true)
- }
- }
-
- private fun findRemoteRunnerVersion(testngVersion: String) : Pair? {
- val tng = StringVersion(testngVersion)
- val result =
- if (tng >= VERSION_6_10) Pair(testngVersion, "testng-remote6_10")
- else if (tng >= StringVersion("6.9.10")) Pair("6.9.10", "testng-remote6_9_10")
- else if (tng >= StringVersion("6.9.7")) Pair("6.9.7", "testng-remote6_9_7")
- else if (tng >= StringVersion("6.5.1")) Pair("6.5.1", "testng-remote6_5_0")
- else if (tng >= StringVersion("6.0")) Pair("6.0", "testng-remote6_0")
- else null
- return result
- }
-
- private fun displayPrettyColors(project: Project, context: KobaltContext,
- classpath: List, testConfig: TestConfig, versions: Pair)
- : TestResult {
- val port = 2345
-// launchRemoteServer(project, context, classpath, testConfig, versions, port)
-
- val mh = MessageHub(JsonMessageSender("localhost", port, true))
- mh.setDebug(true)
- mh.initReceiver()
- val passed = arrayListOf()
-
- data class FailedTest(val method: String, val cls: String, val stackTrace: String)
-
- val failed = arrayListOf()
- val skipped = arrayListOf()
-
- fun d(n: Int, color: String)
- = AsciiArt.wrap(String.format("%4d", n), color)
-
- fun red(s: String) = AsciiArt.wrap(s, AsciiArt.RED)
- fun green(s: String) = AsciiArt.wrap(s, AsciiArt.GREEN)
- fun yellow(s: String) = AsciiArt.wrap(s, AsciiArt.YELLOW)
-
- try {
- var message = mh.receiveMessage()
- kobaltLog(1, "")
- kobaltLog(1, green("PASSED") + " | " + red("FAILED") + " | " + yellow("SKIPPED"))
- while (message != null) {
- message = mh.receiveMessage()
- if (message is TestResultMessage) {
- when (message.result) {
- MessageHelper.PASSED_TEST -> passed.add(message.name)
- MessageHelper.FAILED_TEST -> failed.add(FailedTest(message.testClass,
- message.method, message.stackTrace))
- MessageHelper.SKIPPED_TEST -> skipped.add(message.name)
- }
- }
- if (!KobaltLogger.isQuiet) {
- print("\r " + d(passed.size, AsciiArt.GREEN)
- + " | " + d(failed.size, AsciiArt.RED)
- + " | " + d(skipped.size, AsciiArt.YELLOW))
- }
- }
- } catch(ex: IOException) {
- kobaltLog(1, "Exception: ${ex.message}")
- }
- kobaltLog(1, "\nPassed: " + passed.size + ", Failed: " + failed.size + ", Skipped: " + skipped.size)
- failed.forEach {
- val top = it.stackTrace.substring(0, it.stackTrace.indexOf("\n"))
- kobaltLog(1, " " + it.cls + "." + it.method + "\n " + top)
- }
- return TestResult(failed.isEmpty() && skipped.isEmpty())
- }
-
- fun launchRemoteServer(project: Project, context: KobaltContext, classpath: List,
- testConfig: TestConfig, versions: Pair, port: Int) {
- val testngVersion = versions.first
- val remoteRunnerVersion = versions.second
- val dep = with(context.dependencyManager) {
- val jf = create("org.testng.testng-remote:testng-remote:1.3.0")
- val tr = create("org.testng.testng-remote:$remoteRunnerVersion:1.3.0")
- val testng = create("org.testng:testng:6.11")
- transitiveClosure(kotlin.collections.listOf(jf, tr /*, testng */))
- }
-
- val cp = (classpath + dep).distinct().map { it.jarFile.get() }
- .joinToString(File.pathSeparator)
- val calculatedArgs = args(project, context, classpath, testConfig)
-
- val jvmArgs = arrayListOf("-classpath", cp)
- if (testConfig.jvmArgs.any()) {
- jvmArgs.addAll(testConfig.jvmArgs)
- }
- val remoteArgs = listOf(
- "org.testng.remote.RemoteTestNG",
- "-serport", port.toString(),
- "-version", testngVersion,
- "-dontexit",
- RemoteArgs.PROTOCOL,
- "json")
-
- val passedArgs = jvmArgs + remoteArgs + calculatedArgs
-
- Thread {
- runCommand {
- command = "java"
- directory = File(project.directory)
- args = passedArgs
- }
- }.start()
-
-// Thread {
-// val args2 = arrayOf("-serport", port.toString(), "-dontexit", RemoteArgs.PROTOCOL, "json",
-// "-version", "6.10",
-// "src/test/resources/testng.xml")
-// RemoteTestNG.main(args2)
-// }.start()
- }
-}
-
-fun main(args: Array) {
- fun d(n: Int, color: String)
- = AsciiArt.wrap(String.format("%4d", n), color)
-
- if (!KobaltLogger.isQuiet) {
- println("PASSED | FAILED | SKIPPED")
- repeat(20) { i ->
- print("\r " + d(i, AsciiArt.GREEN) + " | " + d(i * 2, AsciiArt.RED) + " | " + d(i, AsciiArt.YELLOW))
- Thread.sleep(500)
- }
- println("")
- }
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/build/BuildFile.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/build/BuildFile.kt
index a2eb91e9..b860f446 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/build/BuildFile.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/build/BuildFile.kt
@@ -1,8 +1,10 @@
package com.beust.kobalt.internal.build
+import com.beust.kobalt.misc.KFiles
import java.io.File
import java.nio.file.Files
import java.nio.file.Path
+import java.nio.file.attribute.BasicFileAttributes
/**
* Sometimes, build files are moved to temporary files, so we give them a specific name for clarity.
* @param path is the path where that file was moved, @param realPath is where the actual file is.
@@ -10,5 +12,23 @@ import java.nio.file.Path
class BuildFile(val path: Path, val name: String, val realPath: Path = path) {
fun exists() : Boolean = Files.exists(path)
+ val lastModified : Long
+ get() = Files.readAttributes(realPath, BasicFileAttributes::class.java).lastModifiedTime().toMillis()
+
val directory : File get() = path.toFile().parentFile
+
+ /**
+ * @return the .kobalt directory where this build file will be compiled.
+ */
+ val dotKobaltDir: File get() = File(directory.parentFile.parentFile, KFiles.KOBALT_DOT_DIR).apply {
+ mkdirs()
+ }
+
+ /**
+ * @return the absolute directory of this project's location, assuming the build file is in
+ * $project/kobalt/src/Build.kt.
+ */
+ val absoluteDir : File? get() {
+ return path.parent?.parent?.parent?.toFile()
+ }
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/build/BuildSources.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/build/BuildSources.kt
deleted file mode 100644
index 78425f18..00000000
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/build/BuildSources.kt
+++ /dev/null
@@ -1,61 +0,0 @@
-package com.beust.kobalt.internal.build
-
-import com.beust.kobalt.homeDir
-import java.io.File
-import java.nio.file.*
-import java.nio.file.attribute.BasicFileAttributes
-
-/**
- * The abstraction to represent a directory that contains source files. @param{root} is typically
- * the root of the project and build files are searched under root/kobalt/src/ *kt.
- */
-interface IBuildSources {
- fun findSourceFiles() : List
- val root: File
- fun exists(): Boolean
-}
-
-class SingleFileBuildSources(val file: File) : IBuildSources {
- override fun exists() = file.exists()
- override fun findSourceFiles() = listOf(file)
- override val root: File = file.parentFile.parentFile.parentFile
- override fun toString() : String = file.path
-}
-
-class BuildSources(val file: File = File("")) : IBuildSources {
-
- override val root = file
-
- override fun findSourceFiles() : List {
- return findBuildFiles(listOf(file))
- }
-
- override fun exists() = findSourceFiles().isNotEmpty()
-
- override fun toString() = "{BuildSources " + findSourceFiles().joinToString(", ") + "}"
-
- fun findBuildFiles(roots: List) : List {
- val result = arrayListOf()
- roots.forEach { file ->
- Files.walkFileTree(Paths.get(file.path), object : SimpleFileVisitor() {
- override fun preVisitDirectory(dir: Path?, attrs: BasicFileAttributes?): FileVisitResult {
- if (dir != null) {
- val path = dir.toFile()
- if (path.name == "src" && path.parentFile.name == "kobalt") {
- val sources = path.listFiles().filter { it.name.endsWith(".kt") }
- result.addAll(sources)
- }
- }
-
- return FileVisitResult.CONTINUE
- }
- })
- }
- return result
- }
-}
-
-fun main(args: Array) {
- val sources = BuildSources(File(homeDir("kotlin/kobalt"))).findSourceFiles()
- println("sources: " + sources)
-}
\ No newline at end of file
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/remote/GetDependenciesCommand.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/remote/GetDependenciesCommand.kt
new file mode 100644
index 00000000..7422c493
--- /dev/null
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/internal/remote/GetDependenciesCommand.kt
@@ -0,0 +1,14 @@
+package com.beust.kobalt.internal.remote
+
+import com.beust.kobalt.Constants
+import java.io.PrintWriter
+import java.net.Socket
+
+fun main(argv: Array) {
+ Socket("localhost", 1234).use { socket ->
+ (PrintWriter(socket.outputStream, true)).use { out ->
+ out.println("""{ "name" : "getDependencies", "buildFile":
+ "/Users/beust/kotlin/kobalt/kobalt/src/${Constants.BUILD_FILE_NAME}"}""")
+ }
+ }
+}
\ No newline at end of file
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/DependencyManager.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/DependencyManager.kt
index ff2d9fd9..d5b4cd2b 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/DependencyManager.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/DependencyManager.kt
@@ -70,14 +70,12 @@ class DependencyManager @Inject constructor(val executors: KobaltExecutors,
/**
* @return the source dependencies for this project, including the contributors.
*/
- override fun dependencies(project: Project, context: KobaltContext, scopes: List)
- = privateDependencies(project, context, listOf(Scope.COMPILE))
+ override fun dependencies(project: Project, context: KobaltContext) = dependencies(project, context, false)
/**
* @return the test dependencies for this project, including the contributors.
*/
- override fun testDependencies(project: Project, context: KobaltContext)
- = privateDependencies(project, context, listOf(Scope.COMPILE, Scope.TEST))
+ override fun testDependencies(project: Project, context: KobaltContext) = dependencies(project, context, true)
/**
* Transitive dependencies for the compilation of this project.
@@ -106,10 +104,6 @@ class DependencyManager @Inject constructor(val executors: KobaltExecutors,
val result = arrayListOf().apply {
if (scopes.contains(Scope.COMPILE)) {
addAll(project.compileDependencies)
- addAll(project.compileProvidedDependencies)
- }
- if (scopes.contains(Scope.COMPILEONLY)) {
- addAll(project.compileOnlyDependencies)
}
if (scopes.contains(Scope.RUNTIME)) {
addAll(project.compileRuntimeDependencies)
@@ -143,14 +137,8 @@ class DependencyManager @Inject constructor(val executors: KobaltExecutors,
* Should probably make exclusion more generic (full on string) or allow exclusion to be specified
* formally by groupId or artifactId.
*/
- fun isDependencyExcluded(dep: IClasspathDependency, excluded: List): Boolean {
- excluded.any { excluded -> dep.id == excluded.id }.let { result ->
- if (result) {
- context.logger.log(project?.name ?: "", 2, " Excluding dependency $dep")
- }
- return result
- }
- }
+ fun isDependencyExcluded(dep: IClasspathDependency, excluded: List)
+ = excluded.any { excluded -> dep.id.startsWith(excluded.id) }
// Dependencies get reordered by transitiveClosure() but since we just added a bunch of new ones,
// we need to reorder them again in case we're adding dependencies that are already present
@@ -160,7 +148,7 @@ class DependencyManager @Inject constructor(val executors: KobaltExecutors,
result.filter { ! isDependencyExcluded(it, project.excludedDependencies) }
} else {
result
- }.toHashSet()
+ }
val reordered = reorderDependencies(shortResult)
return reordered
}
@@ -179,14 +167,14 @@ class DependencyManager @Inject constructor(val executors: KobaltExecutors,
* TODO: This should be private, everyone should be calling calculateDependencies().
*/
fun transitiveClosure(dependencies : List,
- filter: DependencyFilter = Filters.EXCLUDE_OPTIONAL_FILTER,
+ dependencyFilter: DependencyFilter? = null,
requiredBy: String? = null): List {
val result = arrayListOf()
- dependencies.forEach { dependency ->
- result.add(dependency)
- if (dependency.isMaven) {
- val resolved = resolver.resolveToIds(dependency.id, null, filter).map { create(it) }
- result.addAll(resolved)
+ dependencies.forEach {
+ result.add(it)
+ if (it.isMaven) {
+ val resolved = resolver.resolveToIds(it.id, null, dependencyFilter)
+ result.addAll(resolved.map { create(it) })
}
}
val reordered = reorderDependencies(result)
@@ -232,45 +220,30 @@ class DependencyManager @Inject constructor(val executors: KobaltExecutors,
}
}
- val isTest = scopes.contains(Scope.TEST)
-
project.dependsOn.forEach { p ->
maybeAddClassDir(KFiles.joinDir(p.directory, p.classesDir(context)))
+ val isTest = scopes.contains(Scope.TEST)
if (isTest) maybeAddClassDir(KFiles.makeOutputTestDir(project).path)
val otherDependencies = calculateDependencies(p, context, dependencyFilter, scopes)
result.addAll(otherDependencies)
- }
- if (isTest) {
- project.testsDependOn.forEach { p ->
- val otherDependencies = calculateDependencies(p, context, dependencyFilter, scopes)
- result.addAll(otherDependencies)
- }
}
return result
}
}
- private fun privateDependencies(project: Project, context: KobaltContext, passedScopes: List)
+ private fun dependencies(project: Project, context: KobaltContext, isTest: Boolean)
: List {
- val isTest = passedScopes.contains(Scope.TEST)
val transitive = hashSetOf()
with(project) {
val scopeFilters : ArrayList = arrayListOf(Scope.COMPILE)
context.variant.let { variant ->
- val deps: ArrayList> =
- if (passedScopes.contains(Scope.COMPILE)) {
- arrayListOf(compileDependencies, compileProvidedDependencies,
- variant.buildType.compileDependencies,
- variant.buildType.compileProvidedDependencies,
- variant.productFlavor.compileDependencies,
- variant.productFlavor.compileProvidedDependencies)
- } else if (passedScopes.contains(Scope.RUNTIME)) {
- arrayListOf(compileRuntimeDependencies)
- } else {
- arrayListOf(arrayListOf())
- }
- val runtimeDeps = arrayListOf(compileRuntimeDependencies)
+ val deps = arrayListOf(compileDependencies, compileProvidedDependencies,
+ variant.buildType.compileDependencies,
+ variant.buildType.compileProvidedDependencies,
+ variant.productFlavor.compileDependencies,
+ variant.productFlavor.compileProvidedDependencies
+ )
if (isTest) {
deps.add(testDependencies)
deps.add(testProvidedDependencies)
@@ -279,9 +252,9 @@ class DependencyManager @Inject constructor(val executors: KobaltExecutors,
val filter =
if (isTest) OrDependencyFilter(Filters.COMPILE_FILTER, Filters.TEST_FILTER)
else Filters.COMPILE_FILTER
- runtimeDeps.filter { it.any() }.forEach {
+ deps.filter { it.any() }.forEach {
transitive.addAll(calculateDependencies(project, context, filter,
- passedScopes, // scopes = Scope.toScopes(isTest),
+ scopes = Scope.toScopes(isTest),
passedDependencies = it))
}
}
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/Kurl.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Kurl.kt
index 909c18c5..6b9c0a62 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Kurl.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Kurl.kt
@@ -1,8 +1,9 @@
package com.beust.kobalt.maven
import com.beust.kobalt.HostConfig
-import com.beust.kobalt.maven.aether.KobaltMavenResolver
+import com.beust.kobalt.KobaltException
import com.beust.kobalt.maven.dependency.FileDependency
+import com.beust.kobalt.misc.LocalProperties
import java.io.*
import java.net.HttpURLConnection
import java.net.URL
@@ -20,7 +21,27 @@ class Kurl(val hostInfo: HostConfig) {
}
init {
- KobaltMavenResolver.initAuthentication(hostInfo)
+ // See if the URL needs to be authenticated. Look in local.properties for keys
+ // of the format authUrl..user=xxx and authUrl..password=xxx
+ val properties = LocalProperties().localProperties
+ val host = java.net.URL(hostInfo.url).host
+ properties.entries.forEach {
+ val key = it.key.toString()
+ if (key == "$KEY.$host.$VALUE_USER") {
+ hostInfo.username = properties.getProperty(key)
+ } else if (key == "$KEY.$host.$VALUE_PASSWORD") {
+ hostInfo.password = properties.getProperty(key)
+ }
+ }
+ fun error(s1: String, s2: String) {
+ throw KobaltException("Found \"$s1\" but not \"$s2\" in local.properties for $KEY.$host",
+ docUrl = "http://beust.com/kobalt/documentation/index.html#maven-repos-authenticated")
+ }
+ if (! hostInfo.username.isNullOrBlank() && hostInfo.password.isNullOrBlank()) {
+ error("username", "password")
+ } else if(hostInfo.username.isNullOrBlank() && ! hostInfo.password.isNullOrBlank()) {
+ error("password", "username")
+ }
}
override fun toString() = hostInfo.toString()
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/LocalRepo.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/LocalRepo.kt
index 35f8c50a..21d36172 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/LocalRepo.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/LocalRepo.kt
@@ -1,8 +1,11 @@
package com.beust.kobalt.maven
import com.beust.kobalt.internal.KobaltSettings
+import com.beust.kobalt.misc.KFiles
+import com.beust.kobalt.misc.Versions
import com.google.inject.Inject
import java.io.File
+import java.util.*
import javax.inject.Singleton
@Singleton
@@ -10,7 +13,42 @@ open class LocalRepo @Inject constructor(val kobaltSettings: KobaltSettings) {
val localRepo: File
get() = kobaltSettings.localCache
- fun toFullPath(path: String): String = File(localRepo, path).absolutePath
+ fun existsPom(d: LocalDep, v: String) : Boolean {
+ return File(d.toAbsolutePomFile(v)).exists()
+ }
+
+ fun existsJar(d: LocalDep, v: String) : Boolean {
+ return File(d.toAbsoluteJarFilePath(v)).exists()
+ }
+
+ /**
+ * If the dependency is local, return the correct version for it
+ */
+ fun findLocalVersion(groupId: String, artifactId: String, packaging: String? = null) : String? {
+ // No version: look at all the directories under group/artifactId, pick the latest and see
+ // if it contains a maven and jar file
+ val dir = toFullPath(KFiles.joinDir(groupId.replace(".", File.separator), artifactId))
+ val files = File(dir).listFiles()
+
+ if (files != null) {
+ val directories = files.filter { it.isDirectory }
+ if (directories.size > 0) {
+ Collections.sort(directories, { f1, f2 ->
+ val v1 = Versions.toLongVersion(f1.name)
+ val v2 = Versions.toLongVersion(f2.name)
+ v2.compareTo(v1) // we want the most recent at position 0
+ })
+ val result = directories[0].name
+ val newDep = LocalDep(MavenId.create(groupId, artifactId, packaging, null, result), this)
+ if (existsPom(newDep, result) && existsJar(newDep, result)) {
+ return result
+ }
+ }
+ }
+ return null
+ }
+
+ fun toFullPath(path: String) = File(localRepo, path).absolutePath
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/MavenId.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/MavenId.kt
index 13fff154..21201f99 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/MavenId.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/MavenId.kt
@@ -17,12 +17,8 @@ class MavenId private constructor(val groupId: String, val artifactId: String, v
val classifier: String?, val version: String?) {
companion object {
- fun isMavenId(id: String) = if (id.startsWith("file://")) {
- false
- } else {
- with(id.split(':')) {
- size >= 3 && size <= 5
- }
+ fun isMavenId(id: String) = with(id.split(':')) {
+ size >= 3 && size <= 5
}
fun isRangedVersion(s: String): Boolean {
@@ -36,14 +32,14 @@ class MavenId private constructor(val groupId: String, val artifactId: String, v
MavenId(groupId, artifactId, extension, classifier, version)
}
- fun toMavenId(id: String) = if (id.endsWith(":")) id + "(0,]" else id
+ fun toKobaltId(id: String) = if (id.endsWith(":")) id + "(0,]" else id
/**
* The main entry point to create Maven Id's. Id's created by this function
* will run through IMavenIdInterceptors.
*/
fun create(originalId: String) : MavenId {
- val id = toMavenId(originalId)
+ val id = toKobaltId(originalId)
var originalMavenId = createNoInterceptors(id)
var interceptedMavenId = originalMavenId
val interceptors = Kobalt.context?.pluginInfo?.mavenIdInterceptors
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Md5.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Md5.kt
index efa34944..bc5f2fef 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Md5.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Md5.kt
@@ -31,13 +31,13 @@ class Md5 {
var fileCount = 0
filesOrDirectories.filter(File::exists).forEach { file ->
if (file.isFile) {
- kobaltLog(3, " Calculating checksum of $file")
+ kobaltLog(2, " Calculating checksum of $file")
val bytes = toBytes(file)
md5.update(bytes, 0, bytes.size)
fileCount++
} else {
val files = KFiles.findRecursively(file) // , { f -> f.endsWith("java")})
- kobaltLog(3, " Calculating checksum of ${files.size} files in $file")
+ kobaltLog(2, " Calculating checksum of ${files.size} files in $file")
files.map {
File(file, it)
}.filter {
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Pom2.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Pom2.kt
index 879f6d51..d7457529 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Pom2.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/Pom2.kt
@@ -1,12 +1,13 @@
package com.beust.kobalt.maven
-import com.beust.kobalt.misc.kobaltLog
import org.w3c.dom.Element
import org.xml.sax.InputSource
import java.io.File
import java.io.FileReader
import javax.xml.bind.JAXBContext
-import javax.xml.bind.annotation.*
+import javax.xml.bind.annotation.XmlAnyElement
+import javax.xml.bind.annotation.XmlElement
+import javax.xml.bind.annotation.XmlRootElement
import javax.xml.parsers.SAXParserFactory
import javax.xml.transform.sax.SAXSource
@@ -146,7 +147,7 @@ class Dependency {
private fun expandVariable(s: String, pom: Pom2) : String {
val variable = extractVariable(s)
if (variable != null) {
- kobaltLog(2, "Expanding variable $variable")
+ println("Expanding variable $variable")
val value = pom.pomProject.propertyValue(variable)
return s
} else {
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/PomGenerator.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/PomGenerator.kt
index 79c5e4b8..6d666726 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/PomGenerator.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/PomGenerator.kt
@@ -23,10 +23,6 @@ class PomGenerator @Inject constructor(@Assisted val project: Project) {
* Generate the POM file and save it.
*/
fun generateAndSave() {
- requireNotNull(project.version, { "version is mandatory on project ${project.name}" })
- requireNotNull(project.group, { "group is mandatory on project ${project.name}" })
- requireNotNull(project.artifactId, { "artifactId is mandatory on project ${project.name}" })
-
val buildDir = KFiles.makeDir(project.directory, project.buildDirectory)
val outputDir = KFiles.makeDir(buildDir.path, "libs")
val NO_CLASSIFIER = null
@@ -42,6 +38,10 @@ class PomGenerator @Inject constructor(@Assisted val project: Project) {
* @return the text content of the POM file.
*/
fun generate() : String {
+ requireNotNull(project.version, { "version mandatory on project ${project.name}" })
+ requireNotNull(project.group, { "group mandatory on project ${project.name}" })
+ requireNotNull(project.artifactId, { "artifactId mandatory on project ${project.name}" })
+
val pom = (project.pom ?: Model()).apply {
// Make sure the pom has reasonable default values
if (name == null) name = project.name
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/AetherDependency.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/AetherDependency.kt
index 825a8ae8..7ec9bfe0 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/AetherDependency.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/AetherDependency.kt
@@ -1,19 +1,18 @@
package com.beust.kobalt.maven.aether
-import com.beust.kobalt.Args
-import com.beust.kobalt.api.Dependencies
import com.beust.kobalt.api.IClasspathDependency
import com.beust.kobalt.api.Kobalt
import com.beust.kobalt.maven.CompletedFuture
-import com.beust.kobalt.misc.StringVersion
+import com.beust.kobalt.maven.LocalDep
+import com.beust.kobalt.maven.LocalRepo
+import com.beust.kobalt.maven.MavenId
+import com.beust.kobalt.misc.Versions
import com.beust.kobalt.misc.warn
import org.eclipse.aether.artifact.Artifact
-import org.eclipse.aether.artifact.DefaultArtifact
-import org.eclipse.aether.resolution.DependencyResolutionException
import java.io.File
import java.util.concurrent.Future
-class AetherDependency(val artifact: Artifact, override val optional: Boolean = false, val args: Args? = null)
+class AetherDependency(val artifact: Artifact, override val optional: Boolean = false)
: IClasspathDependency, Comparable {
val aether: KobaltMavenResolver get() = Kobalt.INJECTOR.getInstance(KobaltMavenResolver::class.java)
@@ -26,29 +25,18 @@ class AetherDependency(val artifact: Artifact, override val optional: Boolean =
private fun toId(a: Artifact) = a.toString()
override val jarFile: Future
- get() {
- resolveSourcesIfNeeded()
- return if (artifact.file != null) {
- CompletedFuture(artifact.file)
- } else {
- val td = aether.resolve(artifact)
- CompletedFuture(td.root.artifact.file)
- }
- }
-
- private fun resolveSourcesIfNeeded() {
- if (args?.downloadSources ?: false) {
- listOf(artifact.toSourcesArtifact(), artifact.toJavaDocArtifact()).forEach { artifact ->
- if (artifact.file == null) {
- try {
- aether.resolve(artifact)
- } catch(e: DependencyResolutionException) {
- // Ignore
- }
- }
+ get() = if (artifact.file != null) {
+ CompletedFuture(artifact.file)
+ } else {
+ val localRepo = Kobalt.INJECTOR.getInstance(LocalRepo::class.java)
+ val file = File(LocalDep(MavenId.create(id), localRepo).toAbsoluteJarFilePath(version))
+ if (file.exists()) {
+ CompletedFuture(file)
+ } else {
+ val td = aether.resolve(artifact, null)
+ CompletedFuture(td.root.artifact.file)
}
}
- }
override fun toMavenDependencies(scope: String?) : org.apache.maven.model.Dependency {
val passedScope = scope
@@ -77,10 +65,9 @@ class AetherDependency(val artifact: Artifact, override val optional: Boolean =
override val shortId = artifact.groupId + ":" + artifact.artifactId + ":" + artifact.classifier
- override val excluded = arrayListOf()
-
override fun compareTo(other: AetherDependency): Int {
- return StringVersion(artifact.version).compareTo(StringVersion(other.artifact.version))
+ return Versions.toLongVersion(artifact.version).compareTo(Versions.toLongVersion(
+ other.artifact.version))
}
override fun hashCode() = id.hashCode()
@@ -88,7 +75,4 @@ class AetherDependency(val artifact: Artifact, override val optional: Boolean =
override fun equals(other: Any?) = if (other is AetherDependency) other.id == id else false
override fun toString() = id
-
- fun Artifact.toSourcesArtifact() = DefaultArtifact(groupId, artifactId, "sources", extension, version)
- fun Artifact.toJavaDocArtifact() = DefaultArtifact(groupId, artifactId, "javadoc", extension, version)
}
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/ConsoleRepositoryListener.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/ConsoleRepositoryListener.kt
index fdbdbac7..eb1fe8c7 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/ConsoleRepositoryListener.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/ConsoleRepositoryListener.kt
@@ -16,6 +16,12 @@ class ConsoleRepositoryListener @JvmOverloads constructor(out: PrintStream? = nu
val LOG_LEVEL = 4
}
+ private val out: PrintStream
+
+ init {
+ this.out = out ?: System.out
+ }
+
override fun artifactDeployed(event: RepositoryEvent?) {
kobaltLog(LOG_LEVEL, "Deployed " + event!!.artifact + " to " + event.repository)
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Filters.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Filters.kt
index 0a661c2c..6af9cb27 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Filters.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Filters.kt
@@ -1,8 +1,6 @@
package com.beust.kobalt.maven.aether
-import com.beust.kobalt.misc.kobaltLog
import org.eclipse.aether.graph.DependencyFilter
-import org.eclipse.aether.graph.DependencyNode
import org.eclipse.aether.util.artifact.JavaScopes
object Filters {
@@ -11,15 +9,7 @@ object Filters {
}
val TEST_FILTER = DependencyFilter { p0, p1 -> p0.dependency.scope == JavaScopes.TEST }
- val EXCLUDE_OPTIONAL_FILTER = object: DependencyFilter {
- override fun accept(p0: DependencyNode, p1: MutableList): Boolean {
- val result = p0.dependency != null && ! p0.dependency.optional
- if (! result) {
- kobaltLog(3, "Excluding from optional filter: $p0")
- }
- return result
- }
-
- override fun toString() = "EXCLUDE_OPTIONAL_FILTER"
+ val EXCLUDE_OPTIONAL_FILTER = DependencyFilter { p0, p1 ->
+ p0.dependency != null && ! p0.dependency.optional
}
}
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..69192c20 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
@@ -1,15 +1,10 @@
package com.beust.kobalt.maven.aether
-import com.beust.kobalt.Args
-import com.beust.kobalt.HostConfig
-import com.beust.kobalt.KobaltException
import com.beust.kobalt.api.Kobalt
import com.beust.kobalt.internal.KobaltSettings
import com.beust.kobalt.internal.getProxy
-import com.beust.kobalt.maven.Kurl
import com.beust.kobalt.maven.LocalRepo
import com.beust.kobalt.maven.MavenId
-import com.beust.kobalt.misc.LocalProperties
import com.google.common.eventbus.EventBus
import com.google.inject.Inject
import org.eclipse.aether.artifact.Artifact
@@ -24,11 +19,8 @@ import org.eclipse.aether.resolution.DependencyRequest
import org.eclipse.aether.resolution.DependencyResult
import org.eclipse.aether.resolution.VersionRangeRequest
import org.eclipse.aether.resolution.VersionRangeResult
-import org.eclipse.aether.util.repository.AuthenticationBuilder
-import java.util.*
class KobaltMavenResolver @Inject constructor(val settings: KobaltSettings,
- val args: Args,
localRepo: LocalRepo, eventBus: EventBus) {
companion object {
@@ -36,87 +28,34 @@ class KobaltMavenResolver @Inject constructor(val settings: KobaltSettings,
MavenId.toId(it.groupId, it.artifactId, it.extension, it.classifier, it.version)
}
fun isRangeVersion(id: String) = id.contains(",")
-
- fun initAuthentication(hostInfo: HostConfig) {
- // See if the URL needs to be authenticated. Look in local.properties for keys
- // of the format authUrl..user=xxx and authUrl..password=xxx
- val properties = LocalProperties().localProperties
- val host = java.net.URL(hostInfo.url).host
- properties.entries.forEach {
- val key = it.key.toString()
- if (key == "${Kurl.KEY}.$host.${Kurl.VALUE_USER}") {
- hostInfo.username = properties.getProperty(key)
- } else if (key == "${Kurl.KEY}.$host.${Kurl.VALUE_PASSWORD}") {
- hostInfo.password = properties.getProperty(key)
- }
- }
- 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")
- }
- if (! hostInfo.username.isNullOrBlank() && hostInfo.password.isNullOrBlank()) {
- error("username", "password")
- } else if(hostInfo.username.isNullOrBlank() && ! hostInfo.password.isNullOrBlank()) {
- error("password", "username")
- }
-
- }
}
- fun resolveToArtifact(id: String, scope: Scope? = null,
- filter: DependencyFilter = Filters.EXCLUDE_OPTIONAL_FILTER) : Artifact
+ fun resolveToArtifact(id: String, scope: Scope? = null, filter: DependencyFilter? = null) : Artifact
= resolve(id, scope, filter).root.artifact
- fun resolve(passedId: String, scope: Scope? = null,
- filter: DependencyFilter = Filters.EXCLUDE_OPTIONAL_FILTER,
- repos: List = emptyList()): DependencyResult {
- val mavenId = MavenId.toMavenId(passedId)
- val id =
- if (isRangeVersion(mavenId)) {
- 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")
- }
- } else {
- passedId
- }
-
- val collectRequest = createCollectRequest(id, scope, repos)
- val dependencyRequest = DependencyRequest(collectRequest, filter)
+ fun resolve(id: String, scope: Scope? = null, filter: DependencyFilter? = null): DependencyResult {
+ val dependencyRequest = DependencyRequest(createCollectRequest(id, scope), filter)
val result = system.resolveDependencies(session, dependencyRequest)
- // GraphUtil.displayGraph(listOf(result.root), { it -> it.children },
- // { it: DependencyNode, indent: String -> println(indent + it.toString()) })
+
+// GraphUtil.displayGraph(listOf(result.root), { it -> it.children },
+// { it: DependencyNode, indent: String -> println(indent + it.toString()) })
return result
}
- fun resolve(artifact: Artifact, scope: Scope? = null,
- filter: DependencyFilter = Filters.EXCLUDE_OPTIONAL_FILTER)
+ fun resolve(artifact: Artifact, scope: Scope? = null, filter: DependencyFilter? = null)
= resolve(artifactToId(artifact), scope, filter)
- fun resolveToIds(id: String, scope: Scope? = null,
- filter: DependencyFilter = Filters.EXCLUDE_OPTIONAL_FILTER,
- seen: HashSet = hashSetOf()) : List {
+ fun resolveToIds(id: String, scope: Scope? = null, filter: DependencyFilter? = null) : List {
val rr = resolve(id, scope, filter)
val children =
rr.root.children.filter {
- filter.accept(DefaultDependencyNode(it.dependency), emptyList())
+ filter == null || filter.accept(DefaultDependencyNode(it.dependency), emptyList())
}.filter {
it.dependency.scope != Scope.SYSTEM.scope
}
val result = listOf(artifactToId(rr.root.artifact)) + children.flatMap {
val thisId = artifactToId(it.artifact)
- if (! seen.contains(thisId)) {
- seen.add(thisId)
- resolveToIds(thisId, scope, filter, seen)
- } else {
- emptyList()
- }
+ resolveToIds(thisId, scope, filter)
}
return result
}
@@ -129,7 +68,7 @@ class KobaltMavenResolver @Inject constructor(val settings: KobaltSettings,
directDependencies(id, scope)
}
- fun resolveRange(artifact: Artifact): VersionRangeResult? {
+ fun resolveVersion(artifact: Artifact): VersionRangeResult? {
val request = VersionRangeRequest(artifact, kobaltRepositories, null)
val result = system.resolveVersionRange(session, request)
return result
@@ -138,26 +77,16 @@ class KobaltMavenResolver @Inject constructor(val settings: KobaltSettings,
/**
* Create an IClasspathDependency from a Kobalt id.
*/
- fun create(id: String, optional: Boolean) = AetherDependency(DefaultArtifact(id), optional, args)
+ fun create(id: String, optional: Boolean) = AetherDependency(DefaultArtifact(id), optional)
private val system = Booter.newRepositorySystem()
- private val session = Booter.newRepositorySystemSession(system, localRepo.localRepo, settings, args, eventBus)
-
- private fun createRepo(hostConfig: HostConfig) : RemoteRepository {
- val builder = RemoteRepository.Builder(hostConfig.name, "default", hostConfig.url)
- if (hostConfig.hasAuth()) {
- val auth = AuthenticationBuilder()
- .addUsername(hostConfig.username)
- .addPassword(hostConfig.password)
- .build()
- builder.setAuthentication(auth)
- }
- return builder.build()
- }
+ private val session = Booter.newRepositorySystemSession(system, localRepo.localRepo, settings, eventBus)
private val kobaltRepositories: List
get() = Kobalt.repos.map {
- createRepo(it).let { repository ->
+ RemoteRepository.Builder(null, "default", it.url)
+// .setSnapshotPolicy(RepositoryPolicy(false, null, null))
+ .build().let { repository ->
val proxyConfigs = settings.proxyConfigs ?: return@map repository
RemoteRepository.Builder(repository).apply {
setProxy(proxyConfigs.getProxy(repository.protocol)?.toAetherProxy())
@@ -165,16 +94,8 @@ class KobaltMavenResolver @Inject constructor(val settings: KobaltSettings,
}
}
- private fun createRepos(repos: List) : List
- = kobaltRepositories + repos.map { createRepo(HostConfig(it)) }
-
- private fun createCollectRequest(id: String, scope: Scope? = null, repos: List = emptyList())
- = CollectRequest().apply {
- val allIds = arrayListOf(MavenId.toMavenId(id))
-
- dependencies = allIds.map { Dependency(DefaultArtifact(it), scope?.scope) }
-
- root = Dependency(DefaultArtifact(MavenId.toMavenId(id)), scope?.scope)
- repositories = createRepos(repos)
+ private fun createCollectRequest(id: String, scope: Scope? = null) = CollectRequest().apply {
+ root = Dependency(DefaultArtifact(MavenId.toKobaltId(id)), scope?.scope)
+ repositories = kobaltRepositories
}
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Scope.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Scope.kt
index 7822159e..6c18f555 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Scope.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/aether/Scope.kt
@@ -12,7 +12,6 @@ sealed class Scope(val scope: String, val dependencyLambda: (Project) -> List emptyList() })
object RUNTIME : Scope(JavaScopes.RUNTIME, Project::compileRuntimeDependencies)
object TEST : Scope(JavaScopes.TEST, Project::testDependencies)
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/dependency/FileDependency.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/dependency/FileDependency.kt
index 047754e2..a271cf9a 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/dependency/FileDependency.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/maven/dependency/FileDependency.kt
@@ -1,6 +1,5 @@
package com.beust.kobalt.maven.dependency
-import com.beust.kobalt.api.Dependencies
import com.beust.kobalt.api.IClasspathDependency
import com.beust.kobalt.maven.CompletedFuture
import org.apache.maven.model.Dependency
@@ -32,8 +31,6 @@ open class FileDependency(open val fileName: String, override val optional: Bool
override fun directDependencies() = arrayListOf()
- override val excluded = arrayListOf()
-
override fun compareTo(other: FileDependency) = fileName.compareTo(other.fileName)
override fun toString() = fileName
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/BlockExtractor.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/BlockExtractor.kt
index a854156a..f8c3d76e 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/BlockExtractor.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/BlockExtractor.kt
@@ -1,31 +1,14 @@
package com.beust.kobalt.misc
+import com.beust.kobalt.homeDir
import java.io.File
import java.util.regex.Pattern
-class Section(val start: Int, val end: Int) {
- override fun toString() = "$start-$end"
-}
+fun main(argv: Array) {
+ val lines = File(homeDir("kotlin/kobalt/kobalt/src/Build.kt")).readLines()
+ val result = BlockExtractor(Pattern.compile("val.*buildScript.*\\{"), '{', '}').extractBlock(lines)
-class IncludedBuildSourceDir(val line: Int, val dirs: List)
-
-class BuildScriptInfo(val file: File, val fullBuildFile: List, val sections: List,
- val imports: List, val topLines: List) {
- fun isInSection(lineNumber: Int): Boolean {
- sections.forEach {
- if (lineNumber >= it.start && lineNumber <= it.end) return true
- }
- return false
- }
-
- val includedBuildSourceDirs = arrayListOf()
-
- fun addBuildSourceDir(dir: IncludedBuildSourceDir) = includedBuildSourceDirs.add(dir)
-
- fun includedBuildSourceDirsForLine(line: Int): List {
- val result = includedBuildSourceDirs.find { it.line == line }?.dirs
- return result ?: emptyList()
- }
+// BlockExtractor("plugins", '(', ')').extractBlock(lines)
}
/**
@@ -33,18 +16,11 @@ class BuildScriptInfo(val file: File, val fullBuildFile: List, val secti
* e.g. buildScript { ... }.
*/
class BlockExtractor(val regexp: Pattern, val opening: Char, val closing: Char) {
- fun extractBlock(file: File, lines: List): BuildScriptInfo? {
- var currentLineNumber = 0
- // First line of the buildScript block
- var startLine = 0
- // Last line of the buildScript block
- var endLine = 0
+ fun extractBlock(lines: List): String? {
var foundKeyword = false
var foundClosing = false
var count = 0
- val buildScript = arrayListOf()
- val topLines = arrayListOf()
- val finalTopLines = arrayListOf()
+ val result = StringBuffer()
fun updateCount(line: String) {
val currentLine = StringBuffer()
@@ -57,63 +33,33 @@ class BlockExtractor(val regexp: Pattern, val opening: Char, val closing: Char)
if (count == 0) {
currentLine.append(closing).append("\n")
foundClosing = true
- endLine = currentLineNumber
}
}
if (foundKeyword && count > 0) currentLine.append(c)
}
- if (currentLine.isNotEmpty() && foundKeyword) buildScript.add(currentLine.toString())
+ if (currentLine.isNotEmpty()) result.append(currentLine.toString()).append("\n")
}
- val imports = arrayListOf()
- val sections = arrayListOf()
lines.forEach { line ->
val found = regexp.matcher(line).matches()
if (found) {
- startLine = currentLineNumber
foundKeyword = true
count = 1
- buildScript.add(line)
- finalTopLines.addAll(topLines)
+ result.append(line).append("\n")
} else {
- if (line.startsWith("import")) {
- if (isAllowedImport(line)) {
- imports.add(line)
- }
- } else {
- topLines.add(line)
- }
updateCount(line)
}
if (foundKeyword && foundClosing && count == 0) {
- sections.add(Section(startLine, endLine))
- foundKeyword = false
- foundClosing = false
- count = 0
- startLine = 0
- endLine = 0
+ return result.toString()
}
-
- currentLineNumber++
}
- if (sections.isNotEmpty()) {
- val result = (imports.distinct() + buildScript).joinToString("\n") + "\n"
-
- return BuildScriptInfo(file, lines, sections, imports, finalTopLines)
+ if (foundKeyword && foundClosing && count == 0) {
+ return result.toString()
} else {
return null
}
}
-
- companion object {
- private val allowedImports = listOf("com.beust", "java")
- private val disallowedImports = listOf("com.beust.kobalt.plugin")
-
- fun isAllowedImport(line: String) : Boolean {
- return allowedImports.any { line.contains(it) } && !disallowedImports.any { line.contains(it) }
- }
- }
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/CheckVersions.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/CheckVersions.kt
index d15e8056..f046322d 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/CheckVersions.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/CheckVersions.kt
@@ -26,14 +26,16 @@ class CheckVersions @Inject constructor(val depManager: DependencyManager,
try {
val latestDep = depManager.create(dep.shortId, false, project.directory)
val artifact = (latestDep as AetherDependency).artifact
- val rangeResult = resolver.resolveRange(artifact)
-
- if (rangeResult != null) {
- val highest = rangeResult.highestVersion?.toString()
- if (highest != null && highest != dep.id
- && StringVersion(highest) > StringVersion(dep.version)) {
- newVersions.add(artifact.groupId + ":" + artifact.artifactId + ":" + highest)
+ val versions = resolver.resolveVersion(artifact)
+ val releases = versions?.versions?.filter { !it.toString().contains("SNAP")}
+ val highest = if (releases != null && releases.any()) {
+ releases.last().toString()
+ } else {
+ versions?.highestVersion.toString()
}
+ if (highest != dep.id
+ && Versions.toLongVersion(highest) > Versions.toLongVersion(dep.version)) {
+ newVersions.add(artifact.groupId + ":" + artifact.artifactId + ":" + highest)
}
} catch(e: KobaltException) {
kobaltLog(1, " Cannot resolve ${dep.shortId}. ignoring")
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..518250a5 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,13 +6,12 @@ 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, autoGitTag: Boolean) : TaskResult {
val result =
- if (uploadResult.success && enabled) {
- val tagSuccess = tagRelease(project, annotated, push, tag, message)
+ if (uploadResult.success && autoGitTag) {
+ val tagSuccess = tagRelease(project)
if (! tagSuccess) {
- TaskResult(false, errorMessage = "Couldn't tag the project")
+ TaskResult(false, "Couldn't tag the project")
} else {
TaskResult()
}
@@ -22,28 +21,20 @@ class Git @Inject constructor() {
return result
}
- private fun tagRelease(project: Project, annotated: Boolean, push: Boolean, tag: String, message: String) : Boolean {
- val version = if (tag.isNullOrBlank()) project.version else tag
+ private fun tagRelease(project: Project) : Boolean {
val success = try {
- log(2, "Tagging this release as \"$version\"")
+ log(2, "Tagging this release as \"${project.version}\"")
val repo = org.eclipse.jgit.storage.file.FileRepositoryBuilder()
.setGitDir(File(KFiles.joinDir(project.directory, ".git")))
.readEnvironment()
.findGitDir()
.build()
val git = org.eclipse.jgit.api.Git(repo)
- // jGit library will complain and not tag if setAnnotated(false)
- var ref = if (annotated) {
- git.tag().setAnnotated(annotated).setName(version).setMessage(message).call()
- } else {
- git.tag().setName(version).setMessage(message).call()
- }
- if (push) {
- git.push().setPushTags().call()
- }
+ val ref = git.tag().setName(project.version).call()
+ git.push().setPushTags().call()
true
} catch(ex: Exception) {
- warn("Couldn't create tag ${version}: ${ex.message}", ex)
+ warn("Couldn't create tag ${project.version}: ${ex.message}", ex)
false
}
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..2eafc2e3 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
@@ -1,11 +1,8 @@
package com.beust.kobalt.misc
-import com.beust.kobalt.Args
import com.beust.kobalt.KobaltException
-import com.beust.kobalt.api.Kobalt
import com.beust.kobalt.internal.DocUrl
import com.beust.kobalt.internal.KobaltSettings
-import com.beust.kobalt.internal.build.VersionCheckTimestampFile
import com.beust.kobalt.maven.Http
import com.beust.kobalt.maven.aether.Exceptions
import com.google.gson.Gson
@@ -19,15 +16,12 @@ import retrofit2.converter.gson.GsonConverterFactory
import retrofit2.http.*
import rx.Observable
import java.io.File
-import java.time.Duration
-import java.time.Instant
import java.util.*
import java.util.concurrent.Callable
import java.util.concurrent.Future
class GithubApi2 @Inject constructor(
- val executors: KobaltExecutors, val localProperties: LocalProperties, val http: Http,
- val settings:KobaltSettings, val args: Args) {
+ val executors: KobaltExecutors, val localProperties: LocalProperties, val http: Http, val settings:KobaltSettings) {
companion object {
const val PROPERTY_ACCESS_TOKEN = "github.accessToken"
@@ -86,12 +80,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")
@@ -115,42 +109,39 @@ class GithubApi2 @Inject constructor(
val latestKobaltVersion: Future
get() {
val callable = Callable {
- var result = Kobalt.version
- if (! args.dev && Duration.ofMinutes(10L) >
- 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)
- try {
- val req =
- if (username != null && accessToken != null) {
- service.getReleases(username, "kobalt", accessToken)
- } else {
- service.getReleasesNoAuth("cbeust", "kobalt")
- }
- val ex = req.execute()
- val errorBody = ex.errorBody()
- if (errorBody != null) {
- val jsonError = JsonParser().parse(errorBody.string())
- warn("Couldn't call Github.getReleases(): $jsonError")
- } else {
- val releases = ex.body()
- if (releases != null) {
- releases.firstOrNull()?.let {
- result = try {
- listOf(it.name, it.tagName).filterNotNull().first { !it.isBlank() }
- } catch(ex: NoSuchElementException) {
- throw KobaltException("Couldn't find the latest release")
- }
- }
+ var result = "0"
+
+ 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) {
+ service.getReleases(username, "kobalt", accessToken)
} else {
- warn("Didn't receive any body in the response to GitHub.getReleases()")
+ service.getReleasesNoAuth("cbeust", "kobalt")
}
+ val ex = req.execute()
+ val errorBody = ex.errorBody()
+ if (errorBody != null) {
+ val jsonError = JsonParser().parse(errorBody.string())
+ warn("Couldn't call Github.getReleases(): $jsonError")
+ } else {
+ val releases = ex.body()
+ if (releases != null) {
+ releases.firstOrNull()?.let {
+ try {
+ result = listOf(it.name, it.tagName).filterNotNull().first { !it.isBlank() }
+ } catch(ex: NoSuchElementException) {
+ throw KobaltException("Couldn't find the latest release")
+ }
+ }
+ } else {
+ warn("Didn't receive any body in the response to GitHub.getReleases()")
}
- } catch(e: Exception) {
- kobaltLog(1, "Couldn't retrieve releases from github: " + e.message)
- Exceptions.printStackTrace(e)
+ }
+ } catch(e: Exception) {
+ kobaltLog(1, "Couldn't retrieve releases from github: " + e.message)
+ Exceptions.printStackTrace(e)
// val error = parseRetrofitError(e)
// val details = if (error.errors != null) {
// error.errors[0]
@@ -161,7 +152,6 @@ class GithubApi2 @Inject constructor(
// // using cbeust/kobalt, like above. Right now, just bailing.
// kobaltLog(2, "Couldn't retrieve releases from github, ${error.message ?: e}: "
// + details?.code + " field: " + details?.field)
- }
}
result
}
diff --git a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/Io.kt b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/Io.kt
index 8d2b0580..df5fa340 100644
--- a/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/Io.kt
+++ b/modules/kobalt-plugin-api/src/main/kotlin/com/beust/kobalt/misc/Io.kt
@@ -1,7 +1,9 @@
package com.beust.kobalt.misc
import java.io.File
-import java.nio.file.*
+import java.nio.file.Files
+import java.nio.file.Paths
+import java.nio.file.StandardCopyOption
class Io(val dryRun: Boolean = false) {
fun mkdirs(dir: String) {
@@ -45,8 +47,8 @@ class Io(val dryRun: Boolean = false) {
if (! dryRun) {
KFiles.copyRecursively(from, toDir)
require(from.exists(), { -> "$from should exist" })
- require(from.isDirectory, { -> kobaltLog(1, "$from should be a directory")})
- require(toDir.isDirectory, { -> kobaltLog(1, "$toDir should be a file")})
+ require(from.isDirectory, { -> println("$from should be a directory")})
+ require(toDir.isDirectory, { -> println("$toDir should be a file")})
}
}
@@ -56,7 +58,7 @@ class Io(val dryRun: Boolean = false) {
private fun rmDir(dir: File, keep: (File) -> Boolean, indent : String) {
kobaltLog("rm -rf $dir")
- require(dir.isDirectory, { -> kobaltLog(1, "$dir should be a directory")})
+ require(dir.isDirectory, { -> println("$dir should be a directory")})
dir.listFiles({ p0 -> ! keep(p0!!) }).forEach {
if (it.isDirectory) {
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..807a6aba 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
@@ -1,16 +1,16 @@
package com.beust.kobalt.misc
-import com.beust.kobalt.From
+import com.beust.kobalt.Glob
import com.beust.kobalt.IFileSpec
-import com.beust.kobalt.IncludedFile
-import com.beust.kobalt.To
-import com.beust.kobalt.archive.MetaArchive
import com.google.common.io.CharStreams
-import java.io.File
-import java.io.FileOutputStream
-import java.io.InputStreamReader
+import java.io.*
+import java.nio.file.Paths
+import java.util.jar.JarEntry
import java.util.jar.JarFile
+import java.util.jar.JarInputStream
+import java.util.zip.ZipEntry
import java.util.zip.ZipFile
+import java.util.zip.ZipOutputStream
class JarUtils {
companion object {
@@ -21,15 +21,18 @@ class JarUtils {
}
}
- fun addFiles(directory: String, files: List, metaArchive: MetaArchive,
+ fun addFiles(directory: String, files: List, target: ZipOutputStream,
expandJarFiles: Boolean,
onError: (Exception) -> Unit = DEFAULT_HANDLER) {
files.forEach {
- addSingleFile(directory, it, metaArchive, expandJarFiles, onError)
+ addSingleFile(directory, it, target, expandJarFiles, onError)
}
}
- fun addSingleFile(directory: String, file: IncludedFile, metaArchive: MetaArchive,
+ private val DEFAULT_JAR_EXCLUDES =
+ Glob("META-INF/*.SF", "META-INF/*.DSA", "META-INF/*.RSA")
+
+ fun addSingleFile(directory: String, file: IncludedFile, outputStream: ZipOutputStream,
expandJarFiles: Boolean, onError: (Exception) -> Unit = DEFAULT_HANDLER) {
val foundFiles = file.allFromFiles(directory)
foundFiles.forEach { foundFile ->
@@ -48,24 +51,50 @@ class JarUtils {
// Directory
val includedFile = IncludedFile(From(""), To(""), listOf(IFileSpec.GlobSpec("**")))
- addSingleFile(localFile.path, includedFile, metaArchive, expandJarFiles)
+ addSingleFile(localFile.path, includedFile, outputStream, expandJarFiles)
} else {
- try {
- if (file.expandJarFiles && foundFile.name.endsWith(".jar") && !file.from.contains("resources")) {
- kobaltLog(2, " Writing contents of jar file $foundFile")
- metaArchive.addArchive(foundFile)
- } else {
- val toPath = File(file.to).normalize().path
- val finalPath = if (toPath.isEmpty()) null else (toPath + "/")
- metaArchive.addFile(File(directory, fromFile.path), foundFile, finalPath)
+ if (file.expandJarFiles && foundFile.name.endsWith(".jar") && ! file.from.contains("resources")) {
+ kobaltLog(2, " Writing contents of jar file $foundFile")
+ val stream = JarInputStream(FileInputStream(localFile))
+ var entry = stream.nextEntry
+ while (entry != null) {
+ if (!entry.isDirectory && !KFiles.isExcluded(entry.name, DEFAULT_JAR_EXCLUDES)) {
+ val ins = JarFile(localFile).getInputStream(entry)
+ addEntry(ins, JarEntry(entry), outputStream, onError)
+ }
+ entry = stream.nextEntry
}
- } catch(ex: Exception) {
- onError(ex)
+ } else {
+ val entryFileName = file.to(foundFile.path).path.replace("\\", "/")
+ val entry = JarEntry(entryFileName)
+ entry.time = localFile.lastModified()
+ addEntry(FileInputStream(localFile), entry, outputStream, onError)
}
}
}
}
+ private fun addEntry(inputStream: InputStream, entry: ZipEntry, outputStream: ZipOutputStream,
+ onError: (Exception) -> Unit = DEFAULT_HANDLER) {
+ var bis: BufferedInputStream? = null
+ try {
+ outputStream.putNextEntry(entry)
+ bis = BufferedInputStream(inputStream)
+
+ val buffer = ByteArray(50 * 1024)
+ while (true) {
+ val count = bis.read(buffer)
+ if (count == -1) break
+ outputStream.write(buffer, 0, count)
+ }
+ outputStream.closeEntry()
+ } catch(ex: Exception) {
+ onError(ex)
+ } finally {
+ bis?.close()
+ }
+ }
+
fun extractTextFile(zip : ZipFile, fileName: String) : String? {
val enumEntries = zip.entries()
while (enumEntries.hasMoreElements()) {
@@ -105,3 +134,39 @@ class JarUtils {
}
}
+open class Direction(open val p: String) {
+ override fun toString() = path
+ fun isCurrentDir() = path == "./"
+ val path: String get() =
+ if (p.isEmpty()) "./"
+ else if (p.startsWith("/") || p.endsWith("/")) p
+ else p + "/"
+}
+
+class IncludedFile(val fromOriginal: From, val toOriginal: To, val specs: List,
+ val expandJarFiles: Boolean = false) {
+ constructor(specs: List, expandJarFiles: Boolean = false) : this(From(""), To(""), specs, expandJarFiles)
+ fun from(s: String) = File(if (fromOriginal.isCurrentDir()) s else KFiles.joinDir(from, s))
+ val from: String get() = fromOriginal.path.replace("\\", "/")
+ fun to(s: String) = File(if (toOriginal.isCurrentDir()) s else KFiles.joinDir(to, s))
+ val to: String get() = toOriginal.path.replace("\\", "/")
+ override fun toString() = toString("IncludedFile",
+ "files - ", specs.map { it.toString() },
+ "from", from,
+ "to", to)
+
+ fun allFromFiles(directory: String? = null): List {
+ val result = arrayListOf()
+ specs.forEach { spec ->
+// val fullDir = if (directory == null) from else KFiles.joinDir(directory, from)
+ spec.toFiles(directory, from).forEach { source ->
+ result.add(if (source.isAbsolute) source else File(source.path))
+ }
+ }
+ return result.map { Paths.get(it.path).normalize().toFile()}
+ }
+}
+
+class From(override val p: String) : Direction(p)
+
+class To(override val p: String) : Direction(p)
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..a396827a 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
@@ -3,39 +3,24 @@ package com.beust.kobalt.misc
import com.beust.kobalt.*
import com.beust.kobalt.api.Kobalt
import com.beust.kobalt.api.Project
+import com.beust.kobalt.internal.build.BuildFile
import com.beust.kobalt.maven.Md5
-import org.apache.commons.io.FileUtils
-import java.io.*
+import java.io.File
+import java.io.IOException
+import java.io.InputStream
+import java.io.OutputStream
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 {
/**
* This actually returns a list of strings because in development mode, we are not pointing to a single
- * jar file but to a set of classes/directories.
+ * jar file but to a set of /classes directories.
*/
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 +32,18 @@ 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(".")[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() }
@@ -111,12 +93,10 @@ class KFiles {
*/
fun joinDir(vararg ts: String): String = ts.toMutableList().joinToString(File.separator)
- val LIBS_DIR = "libs"
-
/**
* Where assemblies get generated ("kobaltBuild/libs")
*/
- fun libsDir(project: Project): String = KFiles.makeDir(KFiles.buildDir(project).path, LIBS_DIR).path
+ fun libsDir(project: Project) = KFiles.makeDir(KFiles.buildDir(project).path, "libs").path
/**
* The paths elements are expected to be a directory. Make that directory and join the
@@ -136,18 +116,15 @@ 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 makeDir(dir: String, s: String? = null) =
(if (s != null) File(dir, s) else File(dir)).apply { mkdirs() }
fun findRecursively(rootDir: File) : List