Welcome to mirror list, hosted at ThFree Co, Russian Federation.

git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBastien Montagne <montagne29@wanadoo.fr>2020-02-03 16:32:45 +0300
committerBastien Montagne <montagne29@wanadoo.fr>2020-02-03 16:32:45 +0300
commited8e110b5ab37bdb112bef2d6698d5f42eb2a0df (patch)
tree607393c0500cd7792be43157e7be417981a10646 /source/blender/blenkernel
parentf037244e2cbd9dec7d423cdd1f966678156a374a (diff)
parentf13940e883cf7c64ee5d7dd1d05ac425db56d126 (diff)
Merge branch 'blender-v2.82-release'
Diffstat (limited to 'source/blender/blenkernel')
-rw-r--r--source/blender/blenkernel/intern/library_override.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/source/blender/blenkernel/intern/library_override.c b/source/blender/blenkernel/intern/library_override.c
index 2e958c8a578..a8cc37973f2 100644
--- a/source/blender/blenkernel/intern/library_override.c
+++ b/source/blender/blenkernel/intern/library_override.c
@@ -30,6 +30,8 @@
#include "DNA_object_types.h"
#include "DEG_depsgraph.h"
+
+#include "BKE_armature.h"
#include "BKE_library.h"
#include "BKE_library_override.h"
#include "BKE_library_remap.h"
@@ -579,6 +581,17 @@ bool BKE_override_library_status_check_local(Main *bmain, ID *local)
BLI_assert(GS(local->name) == GS(reference->name));
+ if (GS(local->name) == ID_OB) {
+ /* Our beloved pose's bone cross-data pointers... Usually, depsgraph evaluation would ensure
+ * this is valid, but in some cases (like hidden collections etc.) this won't be the case, so
+ * we need to take care of this ourselves. */
+ Object *ob_local = (Object *)local;
+ if (ob_local->data != NULL && ob_local->type == OB_ARMATURE && ob_local->pose != NULL &&
+ ob_local->pose->flag & POSE_RECALC) {
+ BKE_pose_rebuild(bmain, ob_local, ob_local->data, true);
+ }
+ }
+
/* Note that reference is assumed always valid, caller has to ensure that itself. */
PointerRNA rnaptr_local, rnaptr_reference;
@@ -633,6 +646,17 @@ bool BKE_override_library_status_check_reference(Main *bmain, ID *local)
}
}
+ if (GS(local->name) == ID_OB) {
+ /* Our beloved pose's bone cross-data pointers... Usually, depsgraph evaluation would ensure
+ * this is valid, but in some cases (like hidden collections etc.) this won't be the case, so
+ * we need to take care of this ourselves. */
+ Object *ob_local = (Object *)local;
+ if (ob_local->data != NULL && ob_local->type == OB_ARMATURE && ob_local->pose != NULL &&
+ ob_local->pose->flag & POSE_RECALC) {
+ BKE_pose_rebuild(bmain, ob_local, ob_local->data, true);
+ }
+ }
+
PointerRNA rnaptr_local, rnaptr_reference;
RNA_id_pointer_create(local, &rnaptr_local);
RNA_id_pointer_create(reference, &rnaptr_reference);
@@ -678,6 +702,17 @@ bool BKE_override_library_operations_create(Main *bmain, ID *local, const bool f
return ret;
}
+ if (GS(local->name) == ID_OB) {
+ /* Our beloved pose's bone cross-data pointers... Usually, depsgraph evaluation would ensure
+ * this is valid, but in some cases (like hidden collections etc.) this won't be the case, so
+ * we need to take care of this ourselves. */
+ Object *ob_local = (Object *)local;
+ if (ob_local->data != NULL && ob_local->type == OB_ARMATURE && ob_local->pose != NULL &&
+ ob_local->pose->flag & POSE_RECALC) {
+ BKE_pose_rebuild(bmain, ob_local, ob_local->data, true);
+ }
+ }
+
PointerRNA rnaptr_local, rnaptr_reference;
RNA_id_pointer_create(local, &rnaptr_local);
RNA_id_pointer_create(local->override_library->reference, &rnaptr_reference);