diff options
author | zeertzjq <zeertzjq@outlook.com> | 2024-02-16 06:56:12 +0800 |
---|---|---|
committer | zeertzjq <zeertzjq@outlook.com> | 2024-02-16 07:18:06 +0800 |
commit | 163add40b8b98b91dfb8eff589f49dc75f1032ea (patch) | |
tree | c6502c68406be5ae3ef88e292f81cff9f9d71ac2 /src/nvim/undo.c | |
parent | c1fa8789c1ba5549dc37163dfa9be039c5092a41 (diff) | |
download | rneovim-163add40b8b98b91dfb8eff589f49dc75f1032ea.tar.gz rneovim-163add40b8b98b91dfb8eff589f49dc75f1032ea.tar.bz2 rneovim-163add40b8b98b91dfb8eff589f49dc75f1032ea.zip |
vim-patch:9.1.0113: duplicate code when cleaning undo stack
Problem: duplicate code when cleaning undo stack
Solution: refactor undo cleanup into a single public function
related: vim/vim#13928
https://github.com/vim/vim/commit/9071ed8107244e0c56a16b77d1c28e975cb21dd2
Co-authored-by: Christian Brabandt <cb@256bit.org>
Diffstat (limited to 'src/nvim/undo.c')
-rw-r--r-- | src/nvim/undo.c | 36 |
1 files changed, 22 insertions, 14 deletions
diff --git a/src/nvim/undo.c b/src/nvim/undo.c index 6081268e53..e9170ba858 100644 --- a/src/nvim/undo.c +++ b/src/nvim/undo.c @@ -2988,6 +2988,28 @@ void u_clearall(buf_T *buf) buf->b_u_line_lnum = 0; } +/// Free all allocated memory blocks for the buffer 'buf'. +void u_blockfree(buf_T *buf) +{ + while (buf->b_u_oldhead != NULL) { +#ifndef NDEBUG + u_header_T *previous_oldhead = buf->b_u_oldhead; +#endif + + u_freeheader(buf, buf->b_u_oldhead, NULL); + assert(buf->b_u_oldhead != previous_oldhead); + } + xfree(buf->b_u_line_ptr); +} + +/// Free all allocated memory blocks for the buffer 'buf'. +/// and invalidate the undo buffer +void u_clearallandblockfree(buf_T *buf) +{ + u_blockfree(buf); + u_clearall(buf); +} + /// Save the line "lnum" for the "U" command. void u_saveline(buf_T *buf, linenr_T lnum) { @@ -3054,20 +3076,6 @@ void u_undoline(void) check_cursor_col(); } -/// Free all allocated memory blocks for the buffer 'buf'. -void u_blockfree(buf_T *buf) -{ - while (buf->b_u_oldhead != NULL) { -#ifndef NDEBUG - u_header_T *previous_oldhead = buf->b_u_oldhead; -#endif - - u_freeheader(buf, buf->b_u_oldhead, NULL); - assert(buf->b_u_oldhead != previous_oldhead); - } - xfree(buf->b_u_line_ptr); -} - /// Allocate memory and copy curbuf line into it. /// /// @param lnum the line to copy |