Blender Git Statistics -> Branches -> undo-experiments-swap-reread-datablocks
"Undo-experiments-swap-reread-datablocks" branch
Total commits : 201
Total committers : 2
First Commit : August 30, 2019
Latest Commit : February 28, 2020
Commits by Month
Date | Number of Commits | |
---|---|---|
February, 2020 | 110 | |
January, 2020 | 64 | |
December, 2019 | 6 | |
November, 2019 | 16 | |
October, 2019 | 0 | |
September, 2019 | 2 | |
August, 2019 | 3 |
Committers
Author | Number of Commits |
---|---|
Bastien Montagne | 197 |
Bastien Montagne | 4 |
Popular Files
Filename | Total Edits |
---|---|
readfile.c | 57 |
readfile.h | 10 |
undo_system.c | 9 |
memfile_undo.c | 9 |
blendfile.c | 8 |
BKE_main.h | 8 |
main.c | 8 |
readblenentry.c | 8 |
undofile.c | 6 |
library.c | 5 |
Latest commits
Revision f6658ff by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 28, 2020, 09:57 (GMT) |
Cleanup outdated comment. |
Revision 4c6e49e by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 28, 2020, 09:53 (GMT) |
Merge branch 'undo-experiments' into undo-experiments-swap-reread-datablocks |
Revision 9cd67a7 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 28, 2020, 09:52 (GMT) |
Merge branch 'id-ensure-unique-memory-address' into undo-experiments |
Revision eb043d4 by Bastien Montagne (id-ensure-unique-memory-address, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 28, 2020, 09:45 (GMT) |
Merge branch 'master' into id-ensure-unique-memory-address |
Revision 88e1152 by Bastien Montagne (id-ensure-unique-memory-address, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 28, 2020, 09:45 (GMT) |
Merge branch 'id-ensure-unique-memory-address' of git.blender.org:blender into id-ensure-unique-memory-address |
Revision 9b03c45 by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 14:05 (GMT) |
Merge branch 'undo-experiments' into undo-experiments-swap-reread-datablocks |
Revision 1823876 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 14:04 (GMT) |
Merge branch 'id-ensure-unique-memory-address' into undo-experiments |
Revision 76f381f by Bastien Montagne (id-ensure-unique-memory-address, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 14:02 (GMT) |
Ensure IDs get unique memory addresses withing q given editing session. Disclaimer: this should be considered as an engeneering, explanatory patch. Rational: for undo work, we are now manipulating IDs from potentially many different 'memory realms' (in contrast to current undo system, where, since we always reallocate the whole main database at each undo step, we only ever have to deal with two, the old one from the memfile, and the new one from re-read data from that memfile). So far, new undo system has used ID names-based search to remap old to new pointers, but this is slower, less safe, and forces us to do full undo barrier e.g. when renaming an ID. Idea of this patch is instead to ensure that within a given editing session, we never ever allocate a data-block at the same address twice. That way, we can consider ID pointers as valid UIDs withing that scope, and use their values to handle remapping in udo steps even in case an ID has had several memory addresses in the history of the editing session. This patches does two things: # Add a way to ensure a newly allocated ID gets a memory address never used before for any ID. # Store the history of all memory addresses ever used by a given ID. Note that point 1 above is currently using a fairly simple and naive solution, but also quiet innefficient (just allocating again and again until we get a 'free' address), we can imagine a much more efficient solution if we go deeper in MEM_ allocator system itself. Not sure if it is worth it though, as with new undo system actual re-allocation of a same ID at a different address should be fairly rare (i.e. history of used/forbidden addresses should remain quiet short). Differential Revision: https://developer.blender.org/D6937 |
Revision bfdb28a by Bastien Montagne (id-ensure-unique-memory-address, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 13:15 (GMT) |
Merge branch 'master' into id-ensure-unique-memory-address |
Revision b9a8cd6 by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 11:54 (GMT) |
Various updates/cleanups after recent changes. Mainly: * Use a simple `GSet` instead of an `IDNameLib_Map` for storing valid old IDs pointers (since we do not need to complex name-based search anymore). * Use new `BKE_main_idmemhash_lookup_id` helper to search into history of IDs memaddresses. |
Revision b2b971b by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 11:50 (GMT) |
Merge branch 'undo-experiments' into undo-experiments-swap-reread-datablocks |
Revision 6b9c4e2 by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 11:50 (GMT) |
Merge branch 'id-ensure-unique-memory-address' into undo-experiments |
Revision a5ddb3d by Bastien Montagne (id-ensure-unique-memory-address, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 11:48 (GMT) |
Cleanup; add missing static statement. |
Revision 1ef2c5f by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 11:43 (GMT) |
Merge branch 'undo-experiments' into undo-experiments-swap-reread-datablocks |
Revision e98c83e by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 11:21 (GMT) |
Fix for recent merge. |
Revision 7bff0ae by Bastien Montagne (undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 11:19 (GMT) |
Merge branch 'id-ensure-unique-memory-address' into undo-experiments |
Revision 6ba8c39 by Bastien Montagne (id-ensure-unique-memory-address, undo-experiments, undo-experiments-swap-reread-datablocks, uuid-undo-experiments, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 11:19 (GMT) |
Rework a bit re-allocating code, add a lookup utils for history memaddresses. |
Revision 380996c by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 10:08 (GMT) |
Add some debug prints about reusing or not old IDs during undo. |
Revision 15fd537 by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 26, 2020, 09:51 (GMT) |
Rmove full undo barrier when renaming an ID, we don't need it anymore. Keeping the undo barrier system though, think this might still be useful in some cases, also to be exposed as debug option and/or through Py API... |
Revision 3c12093 by Bastien Montagne (undo-experiments-swap-reread-datablocks, uuid-undo-experiments-swap-reread-datablocks) February 25, 2020, 18:08 (GMT) |
Switch back to remaping based on ID addresses. Now that we have unique memaddresses and history of all of them for each ID... Still very dirty code, needs a lot of cleanup. And we should now be able to get rid of the 'full undo' in more cases too, like ID rename e.g. |
MiikaHweb - Blender Git Statistics v1.06