Skip to content

Commit

Permalink
Avoid resolving protobufToolsLocator_* dependencies at configruation …
Browse files Browse the repository at this point in the history
…time

Fixes #42 by deferring the ExecutableLocator
dependency resolution and downloads till the affected tasks are called in
the execution phase.
  • Loading branch information
steffenyount committed Apr 28, 2016
1 parent 1b761eb commit 07e32ba
Show file tree
Hide file tree
Showing 3 changed files with 41 additions and 19 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -249,6 +249,13 @@ public class GenerateProtoTask extends DefaultTask {
return plugins
}

/**
* Returns true if the task has a plugin with the given name, false otherwise.
*/
public boolean hasPlugin(String name) {
return plugins.findByName(name) != null
}

/**
* Add a directory to protoc's include path.
*/
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -122,7 +122,7 @@ class ProtobufPlugin implements Plugin<Project> {
linkGenerateProtoTasksToJavaCompile()
// protoc and codegen plugin configuration may change through the protobuf{}
// block. Only at this point the configuration has been finalized.
project.protobuf.tools.resolve()
project.protobuf.tools.registerTaskDependencies(project.protobuf.getGenerateProtoTasks().all())
}
}

Expand Down
51 changes: 33 additions & 18 deletions src/main/groovy/com/google/protobuf/gradle/ToolsLocator.groovy
Original file line number Diff line number Diff line change
Expand Up @@ -51,26 +51,29 @@ class ToolsLocator {
}

/**
* For every ExecutableLocator that points to an artifact spec, resolves the
* For every ExecutableLocator that points to an artifact spec: creates a
* project configuration dependency for that artifact, registers the
* configuration dependency as an input dependency with the specified tasks,
* and adds a doFirst {} block to the specified tasks which resolves the
* spec, downloads the artifact, and point to the local path.
*/
void resolve() {
resolve(protoc)
if (protoc.path == null) {
void registerTaskDependencies(Collection<GenerateProtoTask> protoTasks) {
if (protoc.artifact != null) {
registerDependencyWithTasks(protoc, protoTasks)
} else if (protoc.path == null) {
protoc.path = 'protoc'
}
plugins.each { plugin ->
resolve(plugin)
if (plugin.path == null) {
plugin.path = "protoc-gen-${plugin.name}"
for (ExecutableLocator pluginLocator in plugins) {
if (pluginLocator.artifact != null) {
registerDependencyWithTasks(pluginLocator, protoTasks)
} else if (pluginLocator.path == null) {
pluginLocator.path = "protoc-gen-${pluginLocator.name}"
}
}
}

void resolve(ExecutableLocator locator) {
if (locator.artifact == null) {
return
}
void registerDependencyWithTasks(ExecutableLocator locator, Collection<GenerateProtoTask> protoTasks) {
// create a project configuration dependency for the artifact
Configuration config = project.configurations.create("protobufToolsLocator_${locator.name}") {
visible = false
transitive = false
Expand All @@ -83,13 +86,25 @@ class ToolsLocator {
version: version,
classifier: project.osdetector.classifier,
ext: 'exe']
project.logger.info("Resolving artifact: ${notation}")
Dependency dep = project.dependencies.add(config.name, notation)
File file = config.fileCollection(dep).singleFile
if (!file.canExecute() && !file.setExecutable(true)) {
throw new GradleException("Cannot set ${file} as executable")

for (GenerateProtoTask protoTask in protoTasks) {
if (protoc.is(locator) || protoTask.hasPlugin(locator.name)) {
// register the configuration dependency as a task input
protoTask.inputs.files(config)

protoTask.doFirst {
if (locator.path == null) {
project.logger.info("Resolving artifact: ${notation}")
File file = config.fileCollection(dep).singleFile
if (!file.canExecute() && !file.setExecutable(true)) {
throw new GradleException("Cannot set ${file} as executable")
}
project.logger.info("Resolved artifact: ${file}")
locator.path = file.path
}
}
}
}
project.logger.info("Resolved artifact: ${file}")
locator.path = file.path
}
}

0 comments on commit 07e32ba

Please sign in to comment.