-
Notifications
You must be signed in to change notification settings - Fork 110
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
bug: snacks undo picker layout tree discrepancies #863
Comments
I had done the visualization similar to telescope-undo.nvim, but I agree that it could be improved. I'm not a fan of how undotree.vim does it, since they combine the tree view while sorting by See the examples below. |
There's a bug somewhere. Sorting isn't stable. Looking into it |
Fixed and I also made it much much faster for files with a large undo history. The problem was that while processing the undo history, Neovim would constantly send change tracking Now I create a temp file (without ft) from the buffer and copy over its undo file. Added benefit is that the active buffer also won't show the processing. |
Thanks @folke, appreciate you!
Was this also why the history on undotree disappeared when the snacks undo picker is opened? |
No, that's because undotree shows you the history of the current buffer. But if you have snacks open, the current buffer is the snacks picker, which doesn't have undo history of course |
ahh makes sense, thanks! |
🤖 I have created a release *beep* *boop* --- ## [2.18.0](v2.17.0...v2.18.0) (2025-02-03) ### Features * **dashboard:** play nice with file explorer netrw replacement ([5420a64](5420a64)) * **explorer.git:** added git_status_open. When false, then dont show recursive git status in open directories ([8646ba4](8646ba4)) * **explorer:** added `]g` and `[g` to jump between files mentioned in `git status` ([263dfde](263dfde)) * **explorer:** added git status. Closes [#817](#817) ([5cae48d](5cae48d)) * **explorer:** hide git status for open directories by default. it's mostly redundant ([b40c0d4](b40c0d4)) * **explorer:** keep expanded dir state. Closes [#816](#816) ([31984e8](31984e8)) * **explorer:** more keymaps and tree rework. See [#837](#837) ([2ff3893](2ff3893)) * **explorer:** navigate with h/l to close/open directories. Closes [#833](#833) ([4b29ddc](4b29ddc)) * **explorer:** new `explorer` module with shortcut to start explorer picker and netrw replacement functionlity ([670c673](670c673)) * **explorer:** recursive copy and copying of selected items with `c` ([2528fcb](2528fcb)) * **explorer:** update on cwd change ([8dea225](8dea225)) * **explorer:** update status when saving a file that is currently visible ([78d4116](78d4116)) * **picker.commands:** do not autorun commands that require arguments ([#879](#879)) ([62d99ed](62d99ed)) * **picker.frecency:** added frecency support for directories ([ce67fa9](ce67fa9)) * **picker.input:** search syntax highlighting ([4242f90](4242f90)) * **picker.lines:** jump to first position of match. Closes [#806](#806) ([ae897f3](ae897f3)) * **picker.list:** use regular CursorLine when picker window is not focused ([8a570bb](8a570bb)) * **picker.matcher:** added opts.matcher.history_bonus that does fzf's scheme=history. Closes [#882](#882). Closes [#872](#872) ([78c2853](78c2853)) * **picker.pickwin:** optional win/buf filter. Closes [#877](#877) ([5c5b40b](5c5b40b)) * **picker.projects:** added `<c-t>` to open a new tab page with the projects picker ([ced377a](ced377a)) * **picker.projects:** allow disabling projects from recent files ([c2dedb6](c2dedb6)) * **picker.projects:** default to tcd instead of cd ([3d2a075](3d2a075)) * **picker.projects:** enabled frecency for projects picker ([5a20565](5a20565)) * **picker.projects:** projects now automatically processes dev folders and added a bunch of actions/keymaps. Closes [#871](#871) ([6f8f0d3](6f8f0d3)) * **picker.undo:** better undo tree visualization. Closes [#863](#863) ([44b8e38](44b8e38)) * **picker.undo:** make diff opts for undo configurable ([d61fb45](d61fb45)) * **picker:** added support for double cliking and confirm ([8b26bae](8b26bae)) * **picker:** automatically download sqlite3.dll on Windows when using frecency / history for the first time. ([65907f7](65907f7)) * **picker:** beter API to interact with active pickers. Closes [#851](#851) ([6a83373](6a83373)) * **picker:** better health checks. Fixes [#855](#855) ([d245925](d245925)) * **picker:** history per source. Closes [#843](#843) ([35295e0](35295e0)) ### Bug Fixes * **dashboard:** open pull requests with P instead of p in the github exmaple ([b2815d7](b2815d7)) * **dashboard:** update on VimResized and WinResized ([558b0ee](558b0ee)) * **explorer:** after search, cursor always jumped to top. Closes [#827](#827) ([d17449e](d17449e)) * **explorer:** always use `--follow` to make sure we see dir symlinks as dirs. Fixes [#814](#814) ([151fd3d](151fd3d)) * **explorer:** cwd is now changed automatically, so no need to update state. ([5549d4e](5549d4e)) * **explorer:** don't disable netrw fully. Just the autocmd that loads a directory ([836eb9a](836eb9a)) * **explorer:** don't try to show when closed. Fixes [#836](#836) ([6921cd0](6921cd0)) * **explorer:** fix git status sorting ([551d053](551d053)) * **explorer:** fixed hierarchical sorting. Closes [#828](#828) ([fa32e20](fa32e20)) * **explorer:** keep global git status cache ([a54a21a](a54a21a)) * **explorer:** remove sleep :) ([efbc4a1](efbc4a1)) * **git:** use os.getenv to get env var. Fixes [#5504](https://github.com/folke/snacks.nvim/issues/5504) ([16d700e](16d700e)) * **layout:** adjust zindex when needed when another layout is already open. Closes [#826](#826) ([ab8af1b](ab8af1b)) * **layout:** destroy in schedule. Fixes [#861](#861) ([c955a8d](c955a8d)) * **picker.actions:** fix split/vsplit/tab. Closes [#818](#818) ([ff02241](ff02241)) * **picker.actions:** pass edit commands to jump. Closes [#859](#859) ([df0e3e3](df0e3e3)) * **picker.actions:** reworked split/vsplit/drop/tab cmds to better do what's intended. Closes [#854](#854) ([2946875](2946875)) * **picker.actions:** tab -> tabnew. Closes [#842](#842) ([d962d5f](d962d5f)) * **picker.explorer:** do LSP stuff on move ([894ff74](894ff74)) * **picker.explorer:** use cached git status ([1ce435c](1ce435c)) * **picker.format:** extra slash in path ([dad3e00](dad3e00)) * **picker.format:** use item.file for filename_only ([e784a9e](e784a9e)) * **picker.git_log:** add extra space between the date and the message ([#885](#885)) ([d897ead](d897ead)) * **picker.keymaps:** added normalized lhs to search text ([fbd39a4](fbd39a4)) * **picker.lazy:** don't use live searches. Fixes [#809](#809) ([1a5fd93](1a5fd93)) * **picker.lines:** col is first non-whitespace. Closes [#806](#806) ([ec8eb60](ec8eb60)) * **picker.list:** better virtual scrolling that works from any window ([4a50291](4a50291)) * **picker.matcher:** fix cwd_bonus check ([00af290](00af290)) * **picker.matcher:** regex offset by one. Fixes [#878](#878) ([9a82f0a](9a82f0a)) * **picker.undo:** add newlines ([72826a7](72826a7)) * **picker.undo:** cleanup tmp buffer ([8368176](8368176)) * **picker.undo:** copy over buffer lines instead of just the file ([c900e2c](c900e2c)) * **picker.undo:** disable swap for tmp undo buffer ([033db25](033db25)) * **picker:** better main window management. Closes [#842](#842) ([f0f053a](f0f053a)) * **picker:** improve resume. Closes [#853](#853) ([0f5b30b](0f5b30b)) * **picker:** make pick_win work with split layouts. Closes [#834](#834) ([6dbc267](6dbc267)) * **picker:** multi layouts that need async task work again. ([cd44efb](cd44efb)) * **picker:** no auto-close when entering a floating window ([08e6c12](08e6c12)) * **picker:** no need to track jumping ([b37ea74](b37ea74)) * **picker:** propagate WinEnter when going to the real window after entering the layout split window ([8555789](8555789)) * **picker:** show regex matches in list when needed. Fixes [#878](#878) ([1d99bac](1d99bac)) * **picker:** show_empty for files / grep. Closes [#808](#808) ([a13ff6f](a13ff6f)) * **util:** better default icons when no icon plugin is installed ([0e4ddfd](0e4ddfd)) * **util:** better keymap normalization ([e1566a4](e1566a4)) * **util:** normkey. Closes [#763](https://github.com/folke/snacks.nvim/issues/763) ([6972960](6972960)) * **win:** close help when leaving the win buffer ([4aba559](4aba559)) ### Performance Improvements * **explorer:** don't wait till git status finished. Update tree when needed. See [#869](#869) ([287db30](287db30)) * **explorer:** use cache when possible for opening/closing directories. Closes [#869](#869) ([cef4fc9](cef4fc9)) * **git:** also check top-level path to see if it's a git root. Closes [#807](#807) ([b9e7c51](b9e7c51)) * **picker.files:** no need to check every time for cmd availability ([8f87c2c](8f87c2c)) * **picker.undo:** more performance improvements for the undo picker ([3d4b8ee](3d4b8ee)) * **picker.undo:** use a tmp buffer to get diffs. Way faster than before. Closes [#863](#863) ([d4a5449](d4a5449)) --- This PR was generated with [Release Please](https://github.com/googleapis/release-please). See [documentation](https://github.com/googleapis/release-please#release-please). Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com>
Did you check docs and existing issues?
Neovim version (nvim -v)
NVIM v0.10.3
Operating system/version
Ubuntu 24.04.1
Describe the bug
Thanks for all the hard work on snacks, the new pickers are amazing!
i used undotree to compare with the snacks undo picker, and picked up a few discrepencies.
On undotree the the undo sequences form 3 distinct paths (1-2-5, 1-3, 1-4), while on the undo picker, it's less clear (at least to me) exactly which undo sequences are linked.
Steps To Reproduce
Generate actions that can be undone
Expected Behavior
to be shone the different undo paths with the correct undo sequences linked to them when i open the undo picker
Repro
The text was updated successfully, but these errors were encountered: