[Bf-blender-cvs] [bb63ce98393] master: Fix (unreported) bad handling of shapekeys when applying override rules.

Bastien Montagne noreply at git.blender.org
Mon Jul 20 19:18:52 CEST 2020


Commit: bb63ce9839322c2730721ffd552edc98c875d897
Author: Bastien Montagne
Date:   Mon Jul 20 19:14:37 2020 +0200
Branches: master
https://developer.blender.org/rBbb63ce9839322c2730721ffd552edc98c875d897

Fix (unreported) bad handling of shapekeys when applying override rules.

We need to do a full proper swap of those shape keys as well, previous
code ended up breaking relationships between data-blocks...

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

M	source/blender/blenkernel/intern/lib_override.c

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

diff --git a/source/blender/blenkernel/intern/lib_override.c b/source/blender/blenkernel/intern/lib_override.c
index fc84ec0b314..322149bc3ce 100644
--- a/source/blender/blenkernel/intern/lib_override.c
+++ b/source/blender/blenkernel/intern/lib_override.c
@@ -1276,8 +1276,6 @@ void BKE_lib_override_library_update(Main *bmain, ID *local)
   Key *local_key = BKE_key_from_id(local);
   Key *tmp_key = BKE_key_from_id(tmp_id);
   if (local_key != NULL && tmp_key != NULL) {
-    /* This is some kind of hard-coded 'always enforced override'... */
-    tmp_key->from = local_key->from;
     tmp_key->id.flag |= (local_key->id.flag & LIB_EMBEDDED_DATA_LIB_OVERRIDE);
   }
 
@@ -1296,6 +1294,12 @@ void BKE_lib_override_library_update(Main *bmain, ID *local)
    * So when we'll free tmp_id, we'll actually free old, outdated data from local. */
   BKE_lib_id_swap(bmain, local, tmp_id);
 
+  if (local_key != NULL && tmp_key != NULL) {
+    /* This is some kind of hard-coded 'always enforced override'... */
+    BKE_lib_id_swap(bmain, &local_key->id, &tmp_key->id);
+    tmp_key->id.flag |= (local_key->id.flag & LIB_EMBEDDED_DATA_LIB_OVERRIDE);
+  }
+
   /* Again, horribly inn-efficient in our case, we need something off-Main
    * (aka more generic nolib copy/free stuff)! */
   /* XXX And crashing in complex cases (e.g. because depsgraph uses same data...). */



More information about the Bf-blender-cvs mailing list