diff options
author | Bastien Montagne <montagne29@wanadoo.fr> | 2016-11-09 18:42:28 +0300 |
---|---|---|
committer | Bastien Montagne <montagne29@wanadoo.fr> | 2016-11-09 18:42:28 +0300 |
commit | 18be39ff17e995ab09bd9eef2b842f66f5270e37 (patch) | |
tree | 68e744dc7325dbb0b721261129d2e2b6f9bab059 | |
parent | e72caa513aa649b43a7765093b5d30f4afd57f14 (diff) |
Fix some assert when making local (due to infamous PITA ShapeKey ID).
-rw-r--r-- | source/blender/blenkernel/intern/library.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/source/blender/blenkernel/intern/library.c b/source/blender/blenkernel/intern/library.c index 5d23788f6f7..14804d0077a 100644 --- a/source/blender/blenkernel/intern/library.c +++ b/source/blender/blenkernel/intern/library.c @@ -264,9 +264,12 @@ void id_fake_user_clear(ID *id) } static int id_expand_local_callback( - void *UNUSED(user_data), struct ID *UNUSED(id_self), struct ID **id_pointer, int UNUSED(cd_flag)) + void *UNUSED(user_data), struct ID *id_self, struct ID **id_pointer, int UNUSED(cd_flag)) { - if (*id_pointer) { + /* Can hapen that we get unlinkable ID here, e.g. with shapekey referring to itself (through drivers)... + * Just skip it, shape key can only be either indirectly linked, or fully local, period. + * And let's curse one more time that stupid useless shapekey ID type! */ + if (*id_pointer && *id_pointer != id_self && BKE_idcode_is_linkable(GS((*id_pointer)->name))) { id_lib_extern(*id_pointer); } |