Skip to content
Snippets Groups Projects
Commit d2325587 authored by Alexander Gavrilov's avatar Alexander Gavrilov
Browse files

Rigify: fix T99352 - generation issues when same named rig is linked.

Only consider local datablocks when searching for the rig object,
widget collection and widget objects themselves during generation.
parent 6af061bc
No related branches found
No related tags found
No related merge requests found
......@@ -76,7 +76,7 @@ class Generator(base_generate.BaseGenerator):
target_rig.display_type = 'WIRE'
# If the object is already added to the scene, switch to its collection
if target_rig.name in self.context.scene.collection.all_objects:
if target_rig in list(self.context.scene.collection.all_objects):
self.__switch_to_usable_collection(target_rig)
else:
# Otherwise, add to the selected collection or the metarig collection if unusable
......@@ -117,11 +117,14 @@ class Generator(base_generate.BaseGenerator):
wgts_group_name = "WGTS_" + self.obj.name
old_collection = bpy.data.collections.get(wgts_group_name)
if old_collection.library:
old_collection = None
if not old_collection:
# Update the old 'Widgets' collection
legacy_collection = bpy.data.collections.get('Widgets')
if legacy_collection and wgts_group_name in legacy_collection.objects:
if legacy_collection and wgts_group_name in legacy_collection.objects and not legacy_collection.library:
legacy_collection.name = wgts_group_name
old_collection = legacy_collection
......
......@@ -53,7 +53,7 @@ def ensure_collection(context, collection_name, hidden=False) -> bpy.types.Colle
active_collection = active_layer_coll.collection
collection = bpy.data.collections.get(collection_name)
if not collection:
if not collection or collection.library:
# Create the collection
collection = bpy.data.collections.new(collection_name)
collection.hide_viewport = hidden
......
......@@ -86,6 +86,9 @@ def create_widget(rig, bone_name, bone_transform_name=None, *, widget_name=None,
if not obj:
# Search the scene by name
obj = scene.objects.get(obj_name)
if obj.library:
local_objs = [obj for obj in scene.objects if obj.name == obj_name and not obj.library]
obj = local_objs[0] if local_objs else None
if obj:
# Record the generated widget
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment