Merge pull request #314 from sgoings/master

Avian UX Upgrade: Artifact Publishing v2
This commit is contained in:
Joshua Warner 2014-07-28 17:32:15 -06:00
commit e6b587333a
3 changed files with 79 additions and 30 deletions

View File

@ -1,15 +1,12 @@
language: cpp language: cpp
env: env:
global: global:
- secure: Pe7OLUvdk3DeTAShyaYsdAXBcnjdNOrtfTPt1mCP5+JKBUw3z0n7BpTgATVRBmkn866pDqxL0N3+jBgjKUpEpqOj23bTB2AeDdIzlYkFGvTd3GQQV1lMFn16I9LOgWJhkfICTJ1rIYiNf8xSkJoeKGB7eGUM0KGsTvelFfsaGVc= - TERM=dumb
- secure: OWgsHP9ijb7oLpZVJqlovccT+OO3uAWEZxVdT/rNFS1riGoTSwi1ptlHUw/lEZY1Lw1dEaSW6kfc2rqpTgsHOFQpcdJeK8E29TLn1x25kYaGzo6JY2wWi5q4I3IMRRcFEharXlucJUO6yZWqhDXZTD4J8yf+wXt4blSRrAXil50= - secure: Pe7OLUvdk3DeTAShyaYsdAXBcnjdNOrtfTPt1mCP5+JKBUw3z0n7BpTgATVRBmkn866pDqxL0N3+jBgjKUpEpqOj23bTB2AeDdIzlYkFGvTd3GQQV1lMFn16I9LOgWJhkfICTJ1rIYiNf8xSkJoeKGB7eGUM0KGsTvelFfsaGVc=
- secure: T19BYOl5UB5vTDD3Q2np0iHroPm1elHhCW7AOkUPnjXE+mwMTWQlRm1LxbZ+tv1dykUSlhBwdLP7dNWRzWa1JbAY6Y2SbMmwfdryZTBaELcXWsTcGOP80pKx1ruY30mQfyguVukfIZj8qvRSIMwXCYm+Do+XffC8fmqXSTBRulA= # BINTRAY_USER
- TERM=dumb - secure: CauPpj2QrbgEaePEPQx+FDeZqc46HmWXHfdAyn+DA9g6np3RMyc+N/ESrJ9efc4E772rnxory2QRyyNffzi29ceNTpIzsIRDuk5WvvC+zePEsQm8kX1afsDK5g16QEvJN24jGSW9ci9uxuknqjeKVOukcFQdxssIyDe11tYWJeI=
# BINTRAY_API_KEY
- secure: Gao6KTkCbqrdCDI2hQswh1v+SpHBeF4hR1WXmCe9gjmPyJb731K2eWigQOrhPOw7Ns3nubo1FwCb5YevYmwPMLryh0f4sKJyqLL1MLbffNl5GttNF2oO3p73cJpgBfHdzabAMwAYGYbneqUZ0Qn4K8RkzXUaoBDv465KmZhqbA0=
script: "./test/ci.sh" script: "./test/ci.sh"
after_success: after_success:
- make clean build - "./gradlew artifactoryPublish"
- ./gradlew artifactoryPublish
- make javadoc
- ".utility/push-javadoc-to-gh-pages.sh"

View File

@ -19,6 +19,36 @@ model {
operatingSystem "linux" operatingSystem "linux"
architecture "x86_64" architecture "x86_64"
} }
create("linux-i386") {
operatingSystem "linux"
architecture "i386"
}
create("windows-x86_64") {
operatingSystem "windows"
architecture "x86_64"
}
create("windows-i386") {
operatingSystem "windows"
architecture "i386"
}
}
tasks {
platforms.each { platform ->
task "build${platform.name}"(type: Exec) {
executable "make"
args "platform=${platform.operatingSystem.name}",
"arch=${platform.architecture.name}"
environment JAVA_HOME: "/usr/local/java"
}
assemble {
dependsOn "build${platform.name}"
}
}
} }
} }
@ -43,6 +73,22 @@ sourceSets {
} }
} }
javadoc {
title = "Avian v${version} Class Library API"
}
task javadocJar(type: Jar) {
dependsOn javadoc
classifier = 'javadoc'
from {
javadoc.destinationDir
}
}
task install {
dependsOn assemble, publish
}
publishing { publishing {
repositories { repositories {
ivy { ivy {
@ -52,28 +98,36 @@ publishing {
} }
publications { publications {
def binSuffix=""
def publishBinSuffix="bin"
ivy(IvyPublication) {
from components.java
artifact(javadocJar)
}
platforms.each { platform -> platforms.each { platform ->
create(platform.name, IvyPublication) { create(platform.name, IvyPublication) {
def nativeBuildDir = "${buildDir}/${platform.operatingSystem.name}-${platform.architecture.name}" def nativeBuildDir = "${buildDir}/${platform.operatingSystem.name}-${platform.architecture.name}"
module "${project.name}-${platform.name}" if(platform.operatingSystem.name == "windows") {
publishBinSuffix = "exe"
artifact("${nativeBuildDir}/avian") { binSuffix = ".${publishBinSuffix}"
name "avian"
type "bin"
extension "bin"
} }
artifact("${nativeBuildDir}/classpath.jar") { module "${project.name}-${platform.name}"
name "classpath"
type "jar" artifact("${nativeBuildDir}/avian${binSuffix}") {
name "avian"
type publishBinSuffix
extension publishBinSuffix
} }
artifact("${nativeBuildDir}/binaryToObject/binaryToObject") { artifact("${nativeBuildDir}/binaryToObject/binaryToObject") {
name "binaryToObject" name "binaryToObject"
type "bin" type publishBinSuffix
extension "bin" extension publishBinSuffix
} }
artifact("${nativeBuildDir}/libavian.a") { artifact("${nativeBuildDir}/libavian.a") {
@ -86,6 +140,10 @@ publishing {
} }
} }
artifactoryPublish {
dependsOn assemble
}
artifactory { artifactory {
contextUrl = "http://oss.jfrog.org" contextUrl = "http://oss.jfrog.org"
@ -106,7 +164,9 @@ artifactory {
} }
defaults { defaults {
publications 'linux-x86_64' platforms.each {
publications it.name
}
} }
} }
} }

View File

@ -1527,14 +1527,6 @@ tarball:
(cd .. && tar --exclude=build --exclude='.*' --exclude='*~' -cjf \ (cd .. && tar --exclude=build --exclude='.*' --exclude='*~' -cjf \
avian/build/avian-$(version).tar.bz2 avian) avian/build/avian-$(version).tar.bz2 avian)
.PHONY: javadoc
javadoc:
$(JAVA_HOME)/bin/javadoc -sourcepath classpath -d build/javadoc -subpackages avian:java \
-windowtitle "Avian v$(version) Class Library API" \
-doctitle "Avian v$(version) Class Library API" \
-header "Avian v$(version)" \
-bottom "<a href=\"http://oss.readytalk.com/avian/\">http://oss.readytalk.com/avian</a>"
.PHONY: clean-current .PHONY: clean-current
clean-current: clean-current:
@echo "removing $(build)" @echo "removing $(build)"