diff --git a/src/main/groovy/com/google/protobuf/gradle/GenerateProtoTask.groovy b/src/main/groovy/com/google/protobuf/gradle/GenerateProtoTask.groovy index b51e6d6f..678e5cf1 100644 --- a/src/main/groovy/com/google/protobuf/gradle/GenerateProtoTask.groovy +++ b/src/main/groovy/com/google/protobuf/gradle/GenerateProtoTask.groovy @@ -330,12 +330,55 @@ public abstract class GenerateProtoTask extends DefaultTask { @Internal("Input captured by getAlternativePaths(), this is used to query alternative path by locator name.") abstract MapProperty getLocatorToAlternativePathsMapping() - @InputFiles - @PathSensitive(PathSensitivity.NONE) + @Internal + abstract MapProperty getLocatorToDependencyMapping() + + @Internal ConfigurableFileCollection getAlternativePaths() { return objectFactory.fileCollection().from(getLocatorToAlternativePathsMapping().get().values()) } + /** + * For each protoc and code gen plugin defined by an artifact specification, this list will contain a String with the + * group, artifact, and version, as long as the version is a stable release version. + * + * Giving this as an input to the task allows gradle to ignore the OS classifier and use cached outputs generated from + * different operating systems since the expectation is that different operating systems will produce the same + * generated code. + */ + @Input + Provider> getReleaseArtifacts() { + releaseDependenciesMapping.map { it.values().collect() } + } + + /** + * This file collection contains the file for each protoc and code gen plugin that is defined by an artifact + * specification that specifies a SNAPSHOT version. + * + * Since snapshots are expected to differ within the same version, this input allows Gradle to consider the file + * itself rather than the version number. + */ + @InputFiles + @PathSensitive(PathSensitivity.NONE) + FileCollection getSnapshotArtifacts() { + def snapshotArtifacts = locatorToAlternativePathsMapping.map { map -> + def releaseArtifactKeys = releaseDependenciesMapping.get().keySet() + map.findAll { entry -> + !releaseArtifactKeys.contains(entry.key) + }.values() + } + + objectFactory.fileCollection().from(snapshotArtifacts) + } + + @Internal + Provider> getReleaseDependenciesMapping() { + providerFactory.provider { + locatorToDependencyMapping.get() + .findAll { entry -> ! entry.value.endsWith ("-SNAPSHOT") } + } + } + @Internal("Input captured by getAlternativePaths()") abstract MapProperty getPluginsExecutableLocators() diff --git a/src/main/groovy/com/google/protobuf/gradle/ToolsLocator.groovy b/src/main/groovy/com/google/protobuf/gradle/ToolsLocator.groovy index 3b2e8b9f..d3113ed1 100644 --- a/src/main/groovy/com/google/protobuf/gradle/ToolsLocator.groovy +++ b/src/main/groovy/com/google/protobuf/gradle/ToolsLocator.groovy @@ -112,6 +112,7 @@ class ToolsLocator { for (GenerateProtoTask protoTask in protoTasks) { if (protoc.is(locator) || protoTask.hasPlugin(locator.name)) { protoTask.locatorToAlternativePathsMapping.put(locator.name, artifactFiles) + protoTask.locatorToDependencyMapping.put(locator.name, "$groupId:$artifact:$version".toString()) } } }