mirror of
https://github.com/corda/corda.git
synced 2025-01-23 04:48:09 +00:00
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:
commit
214cecfbc5
129
build.gradle
129
build.gradle
@ -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}"
|
||||||
}
|
}
|
||||||
} else {
|
if(platformArch != currentPlatformArch) {
|
||||||
create("linux-x86_64") {
|
create(currentPlatformArch) {
|
||||||
operatingSystem "linux"
|
operatingSystem SupportedOS.CURRENT
|
||||||
architecture "x86_64"
|
architecture "${currentArch}"
|
||||||
}
|
|
||||||
|
|
||||||
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") {
|
||||||
|
@ -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
|
Loading…
Reference in New Issue
Block a user