[Bf-blender-cvs] [ab5a591] id-remap: Do not try to reload directly non-linkable datablocks (shapekeys), those will get reloaded by 'owner' mesh anyway.

Bastien Montagne noreply at git.blender.org
Wed Nov 11 20:00:21 CET 2015


Commit: ab5a591f9178c98ff1111d590263d58fe6ed7e27
Author: Bastien Montagne
Date:   Wed Nov 11 18:12:08 2015 +0100
Branches: id-remap
https://developer.blender.org/rBab5a591f9178c98ff1111d590263d58fe6ed7e27

Do not try to reload directly non-linkable datablocks (shapekeys),
those will get reloaded by 'owner' mesh anyway.

Why, why, why are shapekeys datablocks???

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

M	source/blender/blenkernel/intern/library.c
M	source/blender/windowmanager/intern/wm_operators.c

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

diff --git a/source/blender/blenkernel/intern/library.c b/source/blender/blenkernel/intern/library.c
index 377cd03..eb2d7fd 100644
--- a/source/blender/blenkernel/intern/library.c
+++ b/source/blender/blenkernel/intern/library.c
@@ -1078,8 +1078,9 @@ static bool foreach_libblock_remap_callback(void *user_data, ID **id_p, int cb_f
 		const bool is_never_null = ((cb_flag & IDWALK_NEVER_NULL) && (new_id == NULL));
 		const bool skip_never_null = (id_remap_data->flag & ID_REMAP_SKIP_NEVER_NULL_USAGE) != 0;
 
+		if (GS(id->name) == ID_TXT)
 		printf("\t\tIn %s (%p): remapping %s (%p) to %s (%p)\n",
-		       id->name, id, old_id->name, old_id, new_id ? new_id->name : "", new_id);
+		       id->name, id, old_id->name, old_id, new_id ? new_id->name : "<NONE>", new_id);
 
 		/* Special hack in case it's Object->data and we are in edit mode (skipped_direct too). */
 		if ((is_never_null && skip_never_null) ||
@@ -1163,11 +1164,12 @@ static void libblock_remap_data(
 	r_id_remap_data->skipped_indirect = 0;
 	r_id_remap_data->skipped_refcounted = 0;
 
+	if (id && GS(id->name) == ID_TXT)
 	printf("%s: %s (%p) replaced by %s (%p)\n", __func__,
 	       old_id ? old_id->name : "", old_id, new_id ? new_id->name : "", new_id);
 
 	if (id) {
-		printf("\tchecking id %s (%p, %p)\n", id->name, id, id->lib);
+//		printf("\tchecking id %s (%p, %p)\n", id->name, id, id->lib);
 		r_id_remap_data->id = id;
 		BKE_library_foreach_ID_link(id, foreach_libblock_remap_callback, (void *)r_id_remap_data, IDWALK_NOP);
 	}
@@ -1203,9 +1205,9 @@ static void libblock_remap_data(
 		new_id->flag |= LIB_EXTERN;
 	}
 
-	printf("%s: %d occurences skipped (%d direct and %d indirect ones)\n", __func__,
-	       r_id_remap_data->skipped_direct + r_id_remap_data->skipped_indirect,
-	       r_id_remap_data->skipped_direct, r_id_remap_data->skipped_indirect);
+//	printf("%s: %d occurences skipped (%d direct and %d indirect ones)\n", __func__,
+//	       r_id_remap_data->skipped_direct + r_id_remap_data->skipped_indirect,
+//	       r_id_remap_data->skipped_direct, r_id_remap_data->skipped_indirect);
 }
 
 /** Replace all references in .blend file to \a old_id by \a new_id (if \a new_id is NULL, it unlinks \a old_id). */
@@ -1221,7 +1223,7 @@ void BKE_libblock_remap_locked(Main *bmain, void *old_idv, void *new_idv, const
 	BLI_assert((new_id == NULL) || GS(old_id->name) == GS(new_id->name));
 	BLI_assert(old_id != new_id);
 
-	printf("%s: %s (%p) replaced by %s (%p)\n", __func__, old_id->name, old_id, new_id ? new_id->name : "", new_id);
+//	printf("%s: %s (%p) replaced by %s (%p)\n", __func__, old_id->name, old_id, new_id ? new_id->name : "", new_id);
 
 	libblock_remap_data(bmain, NULL, old_id, new_id, remap_flags, &id_remap_data);
 
diff --git a/source/blender/windowmanager/intern/wm_operators.c b/source/blender/windowmanager/intern/wm_operators.c
index a5cf81d..33a0a0c 100644
--- a/source/blender/windowmanager/intern/wm_operators.c
+++ b/source/blender/windowmanager/intern/wm_operators.c
@@ -3072,7 +3072,12 @@ static int wm_lib_relocate_exec_do(bContext *C, wmOperator *op, const bool reloa
 			lba_idx = set_listbasepointers(bmain, lbarray);
 			while (lba_idx--) {
 				ID *id = lbarray[lba_idx]->first;
-				const int idcode = id ? GS(id->name) : 0;
+				const short idcode = id ? GS(id->name) : 0;
+
+				if (!id || !BKE_idcode_is_linkable(idcode)) {
+					/* No need to reload non-linkable datatypes, those will get relinked with their 'users ID'. */
+					continue;
+				}
 
 				for (; id; id = id->next) {
 					if (id->lib == lib) {
@@ -3122,11 +3127,6 @@ static int wm_lib_relocate_exec_do(bContext *C, wmOperator *op, const bool reloa
 					/* Note that here, we also want to replace indirect usages. */
 					BKE_libblock_remap_locked(bmain, old_id, new_id, false);
 
-					if (old_id->flag & LIB_FAKEUSER) {
-						id_fake_user_clear(old_id);
-						id_fake_user_set(new_id);
-					}
-
 					printf("after remap, old_id users: %d, new_id users: %d\n", old_id->us, new_id->us);
 
 					/* In some cases, new_id might become direct link, remove parent of library in this case. */
@@ -3155,7 +3155,7 @@ static int wm_lib_relocate_exec_do(bContext *C, wmOperator *op, const bool reloa
 
 					BKE_reportf(op->reports, RPT_WARNING,
 					            "Lib Reload: Replacing all references to old datablock '%s' by reloaded one failed, "
-					            "old (%d remaining users) one had to be kept and was renamed to '%s'",
+					            "old one (%d remaining users) had to be kept and was renamed to '%s'",
 					            new_id->name, old_id->us, old_id->name);
 				}
 			}
@@ -3166,7 +3166,7 @@ static int wm_lib_relocate_exec_do(bContext *C, wmOperator *op, const bool reloa
 				WMLinkAppendDataItem *item = itemlink->link;
 				ID *old_id = item->customdata;
 
-				printf("%p\n", old_id);
+//				printf("%p\n", old_id);
 
 				if (old_id->us == 0) {
 					BKE_libblock_free(bmain, old_id);
@@ -3294,8 +3294,8 @@ static int wm_lib_relocate_exec_do(bContext *C, wmOperator *op, const bool reloa
 			wm_link_append_data_free(lapp_data);
 		}
 
-		/* Some datablocks can get reloaded/replaced 'silently' because they are not likable (shape keys e.g.),
-		 * wo we need another loop here to clear old ones if possible. */
+		/* Some datablocks can get reloaded/replaced 'silently' because they are not linkable (shape keys e.g.),
+		 * so we need another loop here to clear old ones if possible. */
 		lba_idx = set_listbasepointers(bmain, lbarray);
 		while (lba_idx--) {
 			ID *id = lbarray[lba_idx]->first;




More information about the Bf-blender-cvs mailing list