From f1c64f0fff0481067078ae218ae13d29488afbad Mon Sep 17 00:00:00 2001 From: hvvikram Date: Fri, 17 Mar 2023 14:33:25 -0700 Subject: [PATCH] Add config cleanCacheDir (#977) * Add config cleanCacheDir which controls whether to delete the entire cache dir or only the existing dependency rules files, before generating the dependency rule files * Switched to parallel delete * Use TrueFileFilter for directory filter instead of null --- README-zh.md | 2 +- README.md | 2 +- Usage.md | 5 +++ .../core/manager/DependencyManager.java | 40 ++++++++----------- .../com/uber/okbuck/core/util/FileUtil.java | 24 +++++++++++ .../ExternalDependenciesExtension.java | 13 +++++- 6 files changed, 59 insertions(+), 27 deletions(-) diff --git a/README-zh.md b/README-zh.md index 36ba3f67d..f6e6a4846 100644 --- a/README-zh.md +++ b/README-zh.md @@ -9,7 +9,7 @@ buildscript { jcenter() } dependencies { - classpath 'com.uber:okbuck:0.53.2' + classpath 'com.uber:okbuck:0.53.3' } } diff --git a/README.md b/README.md index b2fab0559..8ee1f1767 100644 --- a/README.md +++ b/README.md @@ -21,7 +21,7 @@ buildscript { jcenter() } dependencies { - classpath 'com.uber:okbuck:0.53.2' + classpath 'com.uber:okbuck:0.53.3' } } diff --git a/Usage.md b/Usage.md index 9b93a8dbe..d75b18dbc 100644 --- a/Usage.md +++ b/Usage.md @@ -62,6 +62,11 @@ okbuck { experimental { transform = true } + + externalDependencies { + cache = "3rdparty/jvm" + cleanCacheDir = true + } } dependencies { diff --git a/buildSrc/src/main/java/com/uber/okbuck/core/manager/DependencyManager.java b/buildSrc/src/main/java/com/uber/okbuck/core/manager/DependencyManager.java index d6fb7d859..efb84c152 100644 --- a/buildSrc/src/main/java/com/uber/okbuck/core/manager/DependencyManager.java +++ b/buildSrc/src/main/java/com/uber/okbuck/core/manager/DependencyManager.java @@ -1,5 +1,8 @@ package com.uber.okbuck.core.manager; +import static com.uber.okbuck.core.dependency.OResolvedDependency.AAR; +import static com.uber.okbuck.core.dependency.OResolvedDependency.JAR; + import com.google.common.base.Joiner; import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableList; @@ -28,14 +31,6 @@ import com.uber.okbuck.extension.OkBuckExtension; import com.uber.okbuck.template.common.BazelFunctionRule; import com.uber.okbuck.template.core.Rule; -import org.apache.commons.io.FileUtils; -import org.gradle.api.Project; -import org.gradle.api.artifacts.Configuration; -import org.gradle.api.artifacts.Dependency; -import org.gradle.api.artifacts.ExternalDependency; -import org.gradle.api.artifacts.ResolvedConfiguration; -import org.gradle.api.artifacts.ResolvedDependency; - import java.io.File; import java.io.IOException; import java.nio.file.Path; @@ -49,9 +44,12 @@ import java.util.Set; import java.util.stream.Collectors; import java.util.stream.IntStream; - -import static com.uber.okbuck.core.dependency.OResolvedDependency.AAR; -import static com.uber.okbuck.core.dependency.OResolvedDependency.JAR; +import org.gradle.api.Project; +import org.gradle.api.artifacts.Configuration; +import org.gradle.api.artifacts.Dependency; +import org.gradle.api.artifacts.ExternalDependency; +import org.gradle.api.artifacts.ResolvedConfiguration; +import org.gradle.api.artifacts.ResolvedDependency; public class DependencyManager { @@ -72,9 +70,10 @@ public class DependencyManager { private final DependencyExporter dependencyExporter; public DependencyManager( - Project rootProject, OkBuckExtension okBuckExtension, BuckFileManager buckFileManager, + Project rootProject, + OkBuckExtension okBuckExtension, + BuckFileManager buckFileManager, DependencyExporter dependencyExporter) { - this.project = rootProject; this.externalDependenciesExtension = okBuckExtension.getExternalDependenciesExtension(); this.jetifierExtension = okBuckExtension.getJetifierExtension(); @@ -390,17 +389,10 @@ private void processDependencies( OkBuckExtension okBuckExtension) { Path rootPath = project.getRootDir().toPath(); File cacheDir = rootPath.resolve(externalDependenciesExtension.getCache()).toFile(); - if (cacheDir.exists()) { - try { - FileUtils.deleteDirectory(cacheDir); - } catch (IOException e) { - throw new IllegalStateException("Could not delete dependency directory: " + cacheDir, e); - } - } - - if (!cacheDir.mkdirs()) { - throw new IllegalStateException("Couldn't create dependency directory: " + cacheDir); - } + FileUtil.deleteQuitelyAndCreate( + cacheDir, + externalDependenciesExtension.shouldCleanCacheDir(), + okBuckExtension.buildFileName); Map> groupToDependencyMap = dependencyMap diff --git a/buildSrc/src/main/java/com/uber/okbuck/core/util/FileUtil.java b/buildSrc/src/main/java/com/uber/okbuck/core/util/FileUtil.java index 2d6dbad1b..6595981a1 100644 --- a/buildSrc/src/main/java/com/uber/okbuck/core/util/FileUtil.java +++ b/buildSrc/src/main/java/com/uber/okbuck/core/util/FileUtil.java @@ -22,6 +22,8 @@ import java.util.HashMap; import java.util.stream.Stream; import org.apache.commons.io.FileUtils; +import org.apache.commons.io.filefilter.NameFileFilter; +import org.apache.commons.io.filefilter.TrueFileFilter; import org.gradle.api.Project; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -156,4 +158,26 @@ public static void persistMapToJsonFile(HashMap map, File file) writer.flush(); writer.close(); } + + public static void deleteQuitelyAndCreate(File dir, boolean deleteDir, String fileName) { + + // Clean the dir, if it exists, based on deleteDir config + if (dir.exists()) { + if (deleteDir) { + try { + FileUtils.deleteDirectory(dir); + } catch (IOException e) { + throw new IllegalStateException("Could not delete dependency directory: " + dir, e); + } + } else { + FileUtils.listFiles(dir, new NameFileFilter(fileName), TrueFileFilter.INSTANCE) + .parallelStream() + .forEach(FileUtils::deleteQuietly); + } + } + + if (!dir.exists() && !dir.mkdirs()) { + throw new IllegalStateException("Couldn't create dependency directory: " + dir); + } + } } diff --git a/buildSrc/src/main/java/com/uber/okbuck/extension/ExternalDependenciesExtension.java b/buildSrc/src/main/java/com/uber/okbuck/extension/ExternalDependenciesExtension.java index 690bdd037..b13a8c8af 100644 --- a/buildSrc/src/main/java/com/uber/okbuck/extension/ExternalDependenciesExtension.java +++ b/buildSrc/src/main/java/com/uber/okbuck/extension/ExternalDependenciesExtension.java @@ -16,6 +16,12 @@ public class ExternalDependenciesExtension { /** Specifies the folder where all external dependency rules gets generated. */ @Input private String cache = ".okbuck/ext"; + /** + * Specifies to delete the cache dir, before generating dependency rules If set to false, only + * deletes the existing dependency rules files. + */ + @Input private boolean cleanCacheDir = true; + /** Specifies whether the external dependencies should be downloaded by buck or not. */ @Input private boolean downloadInBuck = true; @@ -46,7 +52,8 @@ public class ExternalDependenciesExtension { * dependencies like robolectric runtime deps. */ @Input - private List allowAllVersions = Collections.singletonList("org.robolectric:android-all-instrumented"); + private List allowAllVersions = + Collections.singletonList("org.robolectric:android-all-instrumented"); /** * Stores the dependency versions to be used for dynamic notations that have , or + in their @@ -172,4 +179,8 @@ public boolean bazelDepsEnabled() { public String getSha256Cache() { return sha256Cache; } + + public boolean shouldCleanCacheDir() { + return cleanCacheDir; + } }