Revision ef12c83 by Bastien Montagne (readfile_factorize_common_id_processing, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 6, 2020, 15:29 (GMT) |
Readfile: refactor/factorize more handling of common ID data. - Move handling of private ID data (nodetree and master_collection) under generic ID code. This shortens code a bit, but mostly avoids having to modify all type-specific callback functions if/when we have to add generic processing to IDs there. - Seriously factorize `expand_xxx` area, in the same way we were already doing in `direct_link_xxx` and `lib_link_xxx` areas. Differential Revision: https://developer.blender.org/D6764 |
Revision ba02dd4 by Bastien Montagne (readfile_factorize_common_id_processing, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 6, 2020, 15:24 (GMT) |
NodeTree: Add access to the address of an ID's nodetree pointer. |
Revision 54004f5 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 6, 2020, 13:08 (GMT) |
Merge branch 'master' into undo-experiments |
Revision ae46232 by Bastien Montagne (id-ensure-unique-memory-address, readfile-rework-refcount-handling, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 5, 2020, 16:52 (GMT) |
Better handling of usages of usercount increment in readfile liblink. Some places could/should still need proper ID refcounting in liblink: * UI data (spaces) - although this should be strictly 'user one' only... * Deprectaed data/pointers which are not handled by libquery code. Not sure whether IPO pointers really need usercount actually... |
Revision ea0dc96 by Bastien Montagne (id-ensure-unique-memory-address, readfile-rework-refcount-handling, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 5, 2020, 16:04 (GMT) |
Merge branch 'master' into readfile-rework-refcount-handling Conflicts: source/blender/blenloader/intern/readfile.c |
Revision 8c75037 by Bastien Montagne (id-ensure-unique-memory-address, readfile-rework-refcount-handling, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 3, 2020, 09:52 (GMT) |
readfile: Quick experiment with refcounting moved to libquery. Having that extra ID users handling at readfile level, besides generic one ensured by libquery, has been something bothering me for a long time (had to fix my share of bugs due to mismatches between those two areas). Further more, work on undo speedup will require even more complex ID refcount management if we want to keep it in readfile.c area. So idea is instead to generalize what we did for linked data already when undoing: recompute properly usercount numbers after liblink step, for all IDs. Note that extra time required here is neglectable in a whole .blend file reading (few extra milliseconds when loading a full production scene e.g.). |
Revision 2d0e6ca by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 1, 2020, 18:43 (GMT) |
Merge branch 'master' into undo-experiments |
Revision 9829a3c by Bastien Montagne (id-ensure-unique-memory-address, readfile-rework-refcount-handling, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 1, 2020, 18:43 (GMT) |
Refactor readfile's liblink code. Liblink specific ID type function was so far running a loop over all IDs of relevant type, unlike almost any other 'ID-callback-like' functions in Blender, which usually let the looping controll to calling code. The latter approach is more convinient when one want to add generic (i.e. type-agnostic) code, since it typically only has to change code in one place (caller function) instead of tens of places (all the callback functions). This commit also changes/sanitizes a few things that had nothing to do in main liblink code, like mesh conversion from tessfaces to polys (which can be done in after-linking versionning code), or scenes' cycles detection/check regarding background 'set' scenes. Differential Revision: https://developer.blender.org/D6727 |
Revision db6f3eb by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 31, 2020, 14:55 (GMT) |
undoexp: cleanup: move/tweak assert re undo direction value. |
Revision b55f656 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 31, 2020, 13:47 (GMT) |
Merge branch 'master' into undo-experiments |
Revision 7ee4b9c by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 31, 2020, 13:46 (GMT) |
undoexp: Fix issue with usual infamous pose's bone pointers. |
Revision 8c57402 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 31, 2020, 13:45 (GMT) |
undoexp: cleanup typo. |
Revision 75b917e by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 30, 2020, 14:29 (GMT) |
undoexp: tweak `setup_app_data()` to better handle undo case. The way we detected undo case there was somewhat weak, now we have a stronger way to do it from `BlendFileReadParams`. |
Revision ff487a0 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 30, 2020, 14:11 (GMT) |
undoexp: fix memleak after recent change of WM/SCR/WS IDs handling. |
Revision d7da371 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 30, 2020, 11:29 (GMT) |
Merge branch 'master' into undo-experiments |
Revision e38ab3c by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 30, 2020, 11:27 (GMT) |
undoexp: fix bug/crash in recent refactor of WM/SCR/WS IDs handling. Mismatch when partial undo was not enabled. |
Revision a149952 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 29, 2020, 10:52 (GMT) |
undoexp: cleanup/simplify handling of WM/SCR/WS IDs. Re-read from memfile WindowManagers, Screens and WorkSpaces are never actually used in undo situation. This allows us to simply early abort on those ID types, even if we do not find them in current (old) bmain for some reason. |
Revision c2a6cb9 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 29, 2020, 10:05 (GMT) |
undoexp: style cleanup. |
Revision ca8706b by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 28, 2020, 15:14 (GMT) |
Merge branch 'master' into undo-experiments |
Revision 9205f3a by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) January 28, 2020, 10:31 (GMT) |
Merge branch 'master' into undo-experiments |
|