summaryrefslogtreecommitdiff
path: root/cli
diff options
context:
space:
mode:
authorRocky Madden <git@rockymadden.com>2012-12-10 20:18:23 -0700
committerRocky Madden <git@rockymadden.com>2012-12-10 20:18:23 -0700
commitc7b576e450f9878a1f916ef48dcec141665d002f (patch)
tree461e38ffbc126d7cc4cc738efe53cfa2588e11ec /cli
parentb49d899d7fedcda56c7d30e7cf43d8abd5d83d22 (diff)
downloadstringmetric-c7b576e450f9878a1f916ef48dcec141665d002f.tar.gz
stringmetric-c7b576e450f9878a1f916ef48dcec141665d002f.tar.bz2
stringmetric-c7b576e450f9878a1f916ef48dcec141665d002f.zip
Added Maven Central integration.
Diffstat (limited to 'cli')
-rwxr-xr-xcli/build.gradle71
1 files changed, 69 insertions, 2 deletions
diff --git a/cli/build.gradle b/cli/build.gradle
index 8491e97..397468d 100755
--- a/cli/build.gradle
+++ b/cli/build.gradle
@@ -1,12 +1,14 @@
apply plugin: 'eclipse'
+apply plugin: 'maven'
apply plugin: 'scala'
+apply plugin: 'signing'
+
+evaluationDependsOn(':stringmetric-core')
compileScala {
compileScala.scalaCompileOptions.additionalParameters = ['-optimise', '–Xdisable-assertions']
}
-evaluationDependsOn(':stringmetric-core')
-
dependencies {
compile project(':stringmetric-core')
compile 'org.scala-lang:scala-compiler:2.9.2'
@@ -20,6 +22,10 @@ dependencies {
testCompile 'org.scalatest:scalatest_2.9.2:1.8'
}
+signing {
+ sign configurations.archives
+}
+
sourceSets {
main {
output.resourcesDir "${project.buildDir}/classes/main"
@@ -49,6 +55,16 @@ sourceSets {
}
}
+task scaladocJar(type: Jar, dependsOn: scaladoc) {
+ classifier = 'javadoc'
+ from "${project.buildDir}/docs/scaladoc"
+}
+
+task sourceJar(type: Jar, dependsOn: classes) {
+ classifier = 'sources'
+ from sourceSets.main.allSource
+}
+
task tar(description: 'Assembles a compressed tar archive of source files.', dependsOn: [':stringmetric-cli:jar', ':stringmetric-core:jar']) {
ext.sourcePath = "${project.projectDir}/source/core/scala"
ext.outputPath = "${project.buildDir}"
@@ -110,4 +126,55 @@ task tar(description: 'Assembles a compressed tar archive of source files.', dep
tarfileset(dir: workingPath, fileMode: 755, prefix: project.name)
}
}
+}
+
+artifacts {
+ archives jar
+ archives scaladocJar
+ archives sourceJar
+}
+
+def isDeployable = hasProperty('sonatypeRepositoryUrl') && hasProperty('sonatypeUsername') && hasProperty('sonatypePassword')
+
+uploadArchives {
+ repositories {
+ if(isDeployable) {
+ mavenDeployer {
+ beforeDeployment { MavenDeployment deployment -> signing.signPom(deployment) }
+
+ repository(url: sonatypeRepositoryUrl) {
+ authentication(userName: sonatypeUsername, password: sonatypePassword)
+ }
+
+ pom.project {
+ description "${parent.project.description}"
+ groupId "${parent.project.group}"
+ name "${project.name}"
+ packaging 'jar'
+ url "${parent.project.url}"
+ version "${parent.project.version}"
+
+ developers {
+ developer {
+ id 'rockymadden'
+ name 'Rocky Madden'
+ }
+ }
+
+ licenses {
+ license {
+ name 'Apache License v2.0'
+ url 'http://www.apache.org/licenses/LICENSE-2.0.txt'
+ distribution 'repo'
+ }
+ }
+
+ scm {
+ url "${parent.project.scm}"
+ connection "${parent.project.scm}"
+ }
+ }
+ }
+ } else { mavenLocal() }
+ }
} \ No newline at end of file