Fix T75893: Undo causes crash with "Load UI" disabled.
We need to re-generate a new session uuid for the UI-related data-blocks that are kept across file reading, when load UI is disabled. Otherwise there will be several IDs with same uuid, which is an ensured way to crash in new undo code.
This commit is contained in:
parent
b4993a9032
commit
bc3aab3fa5
Notes:
blender-bot
2023-02-14 01:35:49 +01:00
Referenced by issue #76392, Crash with Load UI off and calling the same template twice Referenced by issue #75893, Undo causes crash with "Load UI" disabled
|
@ -74,6 +74,7 @@ void BKE_libblock_init_empty(struct ID *id) ATTR_NONNULL(1);
|
|||
|
||||
void BKE_lib_libblock_session_uuid_reset(void);
|
||||
void BKE_lib_libblock_session_uuid_ensure(struct ID *id);
|
||||
void BKE_lib_libblock_session_uuid_renew(struct ID *id);
|
||||
|
||||
void *BKE_id_new(struct Main *bmain, const short type, const char *name);
|
||||
void *BKE_id_new_nomain(const short type, const char *name);
|
||||
|
|
|
@ -201,6 +201,27 @@ static void setup_app_data(bContext *C,
|
|||
SWAP(ListBase, bmain->workspaces, bfd->main->workspaces);
|
||||
SWAP(ListBase, bmain->screens, bfd->main->screens);
|
||||
|
||||
/* In case of actual new file reading without loading UI, we need to regenerate the session
|
||||
* uuid of the UI-related datablocks we are keeping from previous session, otherwise their uuid
|
||||
* will collide with some generated for newly read data. */
|
||||
if (mode != LOAD_UNDO) {
|
||||
ID *id;
|
||||
FOREACH_MAIN_LISTBASE_ID_BEGIN (&bfd->main->wm, id) {
|
||||
BKE_lib_libblock_session_uuid_renew(id);
|
||||
}
|
||||
FOREACH_MAIN_LISTBASE_ID_END;
|
||||
|
||||
FOREACH_MAIN_LISTBASE_ID_BEGIN (&bfd->main->workspaces, id) {
|
||||
BKE_lib_libblock_session_uuid_renew(id);
|
||||
}
|
||||
FOREACH_MAIN_LISTBASE_ID_END;
|
||||
|
||||
FOREACH_MAIN_LISTBASE_ID_BEGIN (&bfd->main->screens, id) {
|
||||
BKE_lib_libblock_session_uuid_renew(id);
|
||||
}
|
||||
FOREACH_MAIN_LISTBASE_ID_END;
|
||||
}
|
||||
|
||||
/* we re-use current window and screen */
|
||||
win = CTX_wm_window(C);
|
||||
curscreen = CTX_wm_screen(C);
|
||||
|
|
|
@ -1087,6 +1087,18 @@ void BKE_lib_libblock_session_uuid_ensure(ID *id)
|
|||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Re-generate a new session-wise uuid for the given \a id.
|
||||
*
|
||||
* \warning This has a very specific use-case (to handle UI-related data-blocks that are kept
|
||||
* across new file reading, when we do keep existing UI). No other usage is expected currently.
|
||||
*/
|
||||
void BKE_lib_libblock_session_uuid_renew(ID *id)
|
||||
{
|
||||
id->session_uuid = MAIN_ID_SESSION_UUID_UNSET;
|
||||
BKE_lib_libblock_session_uuid_ensure(id);
|
||||
}
|
||||
|
||||
/**
|
||||
* Generic helper to create a new empty data-block of given type in given \a bmain database.
|
||||
*
|
||||
|
|
Loading…
Reference in New Issue