Commit: d56b90705e81768ca1a586b622ef4bbe3b216d5c
Author: Campbell Barton
Date:   Fri Jul 6 07:55:29 2018 +0200
Branches: master
https://developer.blender.org/rBd56b90705e81768ca1a586b622ef4bbe3b216d5c

BKE_addons: utility to remove by name

===================================================================

M       source/blender/blenkernel/BKE_addon.h
M       source/blender/blenkernel/intern/addon.c
M       source/blender/editors/interface/resources.c

===================================================================

diff --git a/source/blender/blenkernel/BKE_addon.h 
b/source/blender/blenkernel/BKE_addon.h
index 3af6d3b61bf..a463525d644 100644
--- a/source/blender/blenkernel/BKE_addon.h
+++ b/source/blender/blenkernel/BKE_addon.h
@@ -53,6 +53,7 @@ void            BKE_addon_pref_type_free(void);
 struct bAddon  *BKE_addon_new(void);
 struct bAddon  *BKE_addon_find(struct ListBase *addon_list, const char 
*module);
 struct bAddon  *BKE_addon_ensure(struct ListBase *addon_list, const char 
*module);
+bool            BKE_addon_remove_safe(struct ListBase *addon_list, const char 
*module);
 void            BKE_addon_free(struct bAddon *addon);
 
 #endif  /* __BKE_ADDON_H__ */
diff --git a/source/blender/blenkernel/intern/addon.c 
b/source/blender/blenkernel/intern/addon.c
index a9bb193a7a1..854bf62c061 100644
--- a/source/blender/blenkernel/intern/addon.c
+++ b/source/blender/blenkernel/intern/addon.c
@@ -69,6 +69,17 @@ bAddon *BKE_addon_ensure(ListBase *addon_list, const char 
*module)
        return addon;
 }
 
+bool BKE_addon_remove_safe(ListBase *addon_list, const char *module)
+{
+       bAddon *addon = BLI_findstring(addon_list, module, offsetof(bAddon, 
module));
+       if (addon) {
+               BLI_remlink(addon_list, addon);
+               BKE_addon_free(addon);
+               return true;
+       }
+       return false;
+}
+
 void BKE_addon_free(bAddon *addon)
 {
        if (addon->prop) {
diff --git a/source/blender/editors/interface/resources.c 
b/source/blender/editors/interface/resources.c
index b9da0923e07..77c36bf47f3 100644
--- a/source/blender/editors/interface/resources.c
+++ b/source/blender/editors/interface/resources.c
@@ -2788,11 +2788,7 @@ void init_userdef_do_versions(Main *bmain)
 
        /* Not versioning, just avoid errors. */
 #ifndef WITH_CYCLES
-       bAddon *addon = BLI_findstring(&U.addons, "cycles", offsetof(bAddon, 
module));
-       if (addon) {
-               BLI_remlink(&U.addons, addon);
-               BKE_addon_free(addon);
-       }
+       BKE_addon_remove_safe(&U.addons, "cycles");
 #endif
 
        /* funny name, but it is GE stuff, moves userdef stuff to engine */

_______________________________________________
Bf-blender-cvs mailing list
Bf-blender-cvs@blender.org
https://lists.blender.org/mailman/listinfo/bf-blender-cvs

Reply via email to