From f71d5d43e0aef9548f1e9d3d9cb33183080383c7 Mon Sep 17 00:00:00 2001 From: Braian Date: Mon, 10 Jun 2024 19:36:33 -0500 Subject: [PATCH] Refactoring en la clase glide para mejorar complejidad ciclomatica --- .../main/java/com/bumptech/glide/Glide.java | 58 +++++++------------ 1 file changed, 21 insertions(+), 37 deletions(-) diff --git a/library/src/main/java/com/bumptech/glide/Glide.java b/library/src/main/java/com/bumptech/glide/Glide.java index 612dde5718..83d7ac0ce6 100644 --- a/library/src/main/java/com/bumptech/glide/Glide.java +++ b/library/src/main/java/com/bumptech/glide/Glide.java @@ -104,20 +104,23 @@ public static File getPhotoCacheDir(@NonNull Context context) { @Nullable public static File getPhotoCacheDir(@NonNull Context context, @NonNull String cacheName) { File cacheDir = context.getCacheDir(); - if (cacheDir != null) { - File result = new File(cacheDir, cacheName); - if (result.isDirectory() || result.mkdirs()) { - return result; - } - // File wasn't able to create a directory, or the result exists but not a directory + if (cacheDir == null) { + Log.e(TAG, "getCacheDir returned null"); return null; } - if (Log.isLoggable(TAG, Log.ERROR)) { - Log.e(TAG, "default disk cache dir is null"); + + File result = new File(cacheDir, cacheName); + if (result.mkdirs()) { + return result; + } else { + if (Log.isLoggable(TAG, Log.WARN)) { + Log.w(TAG, "Failed to create directory: " + result); + } + return null; } - return null; } + /** * Get the singleton. * @@ -224,45 +227,26 @@ private static void initializeGlide( @NonNull Context context, @NonNull GlideBuilder builder, @Nullable GeneratedAppGlideModule annotationGeneratedModule) { + Context applicationContext = context.getApplicationContext(); + List manifestModules = Collections.emptyList(); if (annotationGeneratedModule == null || annotationGeneratedModule.isManifestParsingEnabled()) { manifestModules = new ManifestParser(applicationContext).parse(); } - if (annotationGeneratedModule != null - && !annotationGeneratedModule.getExcludedModuleClasses().isEmpty()) { - Set> excludedModuleClasses = annotationGeneratedModule.getExcludedModuleClasses(); - Iterator iterator = manifestModules.iterator(); - while (iterator.hasNext()) { - GlideModule current = iterator.next(); - if (!excludedModuleClasses.contains(current.getClass())) { - continue; - } - if (Log.isLoggable(TAG, Log.DEBUG)) { - Log.d(TAG, "AppGlideModule excludes manifest GlideModule: " + current); - } - iterator.remove(); - } - } - - if (Log.isLoggable(TAG, Log.DEBUG)) { - for (GlideModule glideModule : manifestModules) { - Log.d(TAG, "Discovered GlideModule from manifest: " + glideModule.getClass()); - } - } + Set> excludedModules = annotationGeneratedModule != null ? annotationGeneratedModule.getExcludedModuleClasses() : Collections.emptySet(); + manifestModules = manifestModules.stream() + .filter(module -> !excludedModules.contains(module.getClass())) + .collect(Collectors.toList()); - RequestManagerRetriever.RequestManagerFactory factory = - annotationGeneratedModule != null - ? annotationGeneratedModule.getRequestManagerFactory() - : null; + RequestManagerRetriever.RequestManagerFactory factory = annotationGeneratedModule != null ? annotationGeneratedModule.getRequestManagerFactory() : null; builder.setRequestManagerFactory(factory); - for (GlideModule module : manifestModules) { - module.applyOptions(applicationContext, builder); - } + manifestModules.forEach(module -> module.applyOptions(applicationContext, builder)); if (annotationGeneratedModule != null) { annotationGeneratedModule.applyOptions(applicationContext, builder); } + Glide glide = builder.build(applicationContext, manifestModules, annotationGeneratedModule); applicationContext.registerComponentCallbacks(glide); Glide.glide = glide;