Merge branch 'master' of github.com:ReadyTalk/avian

* 'master' of github.com:ReadyTalk/avian:
  publish vm.pro as part of the classpath artifact
  fix gradle macosx OperatingSystem naming
  adjust gradle publish coordinates
  automagically detect java_home in gradle
  move binaryToObject to a 'tools' artifact
  change classpath artifact name to 'classpath-avian' and remove c++ sources from it

Conflicts:
	build.gradle
This commit is contained in:
Seth Goings 2014-08-28 15:34:34 -06:00
commit 214cecfbc5
2 changed files with 95 additions and 40 deletions

View File

@ -13,7 +13,63 @@ apply plugin: 'ivy-publish'
apply plugin: 'java' apply plugin: 'java'
apply plugin: 'artifactory-publish' apply plugin: 'artifactory-publish'
enum SupportedOS implements OperatingSystem {
LINUX, WINDOWS, MACOSX;
public static final SupportedOS CURRENT;
static {
String p = System.properties['os.name']
switch(p.replaceAll(' ', '').toLowerCase()) {
case ~/.*linux.*/: CURRENT = LINUX; break;
case ~/.*darwin.*/: CURRENT = MACOSX; break;
case ~/.*osx.*/: CURRENT = MACOSX; break;
case ~/.*win.*/: CURRENT = WINDOWS; break;
default:
String m = "SupportedOS: unrecognized platform: ${p}"
println(m)
throw new IllegalArgumentException(m)
}
}
public String getName() {
return toString().toLowerCase()
}
public String getDisplayName() {
return getName()
}
public boolean isCurrent() { return this == CURRENT }
public boolean isFreeBSD() { return false }
public boolean isLinux() { return this == LINUX }
public boolean isMacOsX() { return this == MACOSX }
public boolean isSolaris() { return false }
public boolean isWindows() { return this == WINDOWS }
}
public String adjustArch(String arch) {
switch(arch) {
case ~/.*64.*/: return 'x86_64'
default: return 'i386'
}
}
ext { ext {
currentPlatform = SupportedOS.CURRENT.getName()
currentArch = adjustArch(System.properties['os.arch'])
currentPlatformArch = "${currentPlatform}-${currentArch}"
platform = project.hasProperty('platform') ? platform : currentPlatform
arch = project.hasProperty('arch') ? arch : currentArch
platformArch = "${platform}-${arch}"
java_home = System.properties.'java.home'
if(java_home.endsWith("/jre")) {
java_home = java_home.substring(0, java_home.length() - "/jre".length())
}
java_home = java_home
libDir = "${buildDir}/lib" libDir = "${buildDir}/lib"
} }
@ -47,30 +103,14 @@ dependencies {
model { model {
platforms { platforms {
if(project.hasProperty("platform") && project.hasProperty("arch")) { create(platformArch) {
create("${platform}-${arch}") { operatingSystem SupportedOS.valueOf(platform.toUpperCase())
operatingSystem "${platform}" architecture "${arch}"
architecture "${arch}" }
} if(platformArch != currentPlatformArch) {
} else { create(currentPlatformArch) {
create("linux-x86_64") { operatingSystem SupportedOS.CURRENT
operatingSystem "linux" architecture "${currentArch}"
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"
} }
} }
} }
@ -90,8 +130,7 @@ model {
dependsOn extractWin64 dependsOn extractWin64
args "win32=${libDir}/tools/win64" args "win32=${libDir}/tools/win64"
break break
} environment JAVA_HOME: java_home
environment JAVA_HOME: "/usr/local/java"
} }
assemble { assemble {
@ -130,9 +169,6 @@ sourceSets {
java { java {
srcDir 'classpath' srcDir 'classpath'
} }
resources {
srcDir 'classpath'
}
} }
} }
@ -148,6 +184,10 @@ task javadocJar(type: Jar) {
} }
} }
jar {
baseName "classpath-avian"
}
task install { task install {
dependsOn assemble, publish dependsOn assemble, publish
} }
@ -158,16 +198,37 @@ publishing {
} }
publications { publications {
def binSuffix=""
def publishBinSuffix="bin"
ivy(IvyPublication) { ivy(IvyPublication) {
from components.java from components.java
artifact(javadocJar) artifact(javadocJar)
artifact("vm.pro") {
name "vm"
type "proguard"
extension "pro"
}
module "classpath-avian"
}
create("tools-avian-${currentPlatformArch}", IvyPublication) {
module "tools-avian-${currentPlatformArch}"
def publishBinSuffix = currentPlatform == "windows" ? "exe" : "bin"
def binSuffix = currentPlatform == "windows" ? ".exe" : ""
artifact("${buildDir}/${currentPlatform}-${currentArch}/binaryToObject/binaryToObject") {
name "binaryToObject"
type publishBinSuffix
extension binSuffix
}
} }
platforms.each { platform -> platforms.each { platform ->
def binSuffix=""
def publishBinSuffix="bin"
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}"
@ -176,18 +237,12 @@ publishing {
binSuffix = ".${publishBinSuffix}" binSuffix = ".${publishBinSuffix}"
} }
module "${project.name}-${platform.name}" module "runtime-avian-${platform.name}"
artifact("${nativeBuildDir}/avian${binSuffix}") { artifact("${nativeBuildDir}/avian${binSuffix}") {
name "avian" name "avian"
type publishBinSuffix type publishBinSuffix
extension publishBinSuffix extension binSuffix
}
artifact("${nativeBuildDir}/binaryToObject/binaryToObject") {
name "binaryToObject"
type publishBinSuffix
extension publishBinSuffix
} }
artifact("${nativeBuildDir}/libavian.a") { artifact("${nativeBuildDir}/libavian.a") {

View File

@ -1,4 +1,4 @@
org.gradle.daemon=true org.gradle.daemon=true
group=com.readytalk group=com.readytalk.avian
version=1.1.0-SNAPSHOT version=1.1.0-SNAPSHOT