Cordapps now correctly resolve dependencies.

This commit is contained in:
Clinton Alexander 2016-10-31 16:08:07 +00:00
parent f26813c1ab
commit 29e203315b
2 changed files with 9 additions and 8 deletions

View File

@ -2,6 +2,7 @@ package com.r3corda.plugins
import org.gradle.api.Plugin
import org.gradle.api.Project
import org.gradle.api.artifacts.Configuration
/**
* The Cordformation plugin deploys nodes to a directory in a state ready to be used by a developer for experimentation,
@ -9,7 +10,9 @@ import org.gradle.api.Project
*/
class Cordformation implements Plugin<Project> {
void apply(Project project) {
Configuration cordappConf = project.configurations.create("cordapp")
cordappConf.transitive = false
project.configurations.compile.extendsFrom cordappConf
}
/**

View File

@ -174,9 +174,9 @@ class Node {
*/
private void installDependencies() {
def cordaJar = verifyAndGetCordaJar()
def cordappList = getCordappList()
def cordappDeps = getCordappList()
def depsDir = new File(nodeDir, "dependencies")
def appDeps = project.configurations.runtime.filter { it != cordaJar && !cordappList.contains(it) }
def appDeps = project.configurations.runtime.filter { it != cordaJar && !cordappDeps.contains(it) }
project.copy {
from appDeps
into depsDir
@ -224,11 +224,9 @@ class Node {
*
* @return List of this node's cordapps.
*/
private AbstractFileCollection getCordappList() {
def cordaJar = verifyAndGetCordaJar()
return project.configurations.runtime.filter {
def jarName = it.name.split('-').first()
return (it != cordaJar) && cordapps.contains(jarName)
private Collection<File> getCordappList() {
return project.configurations.cordapp.files {
cordapps.contains(it.getName())
}
}
}