Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Prevent Vim from updating its undo tree

Tags:

undo

vim

I have a Vimscript function which is called on BufWritePre to check the integrity of the file. Typically this involves trimming whitespace and checking that the fold structure is "valid" (according to my company's conventions).

My problem is that if I edit a file and then save it, the undo tree contains the edits made by the checking function. Is there a simple way to say that I don't want a function to modify the undo tree? Or can I save its state at the start of the function and restore it at the end?

like image 418
Prince Goulash Avatar asked Oct 05 '12 07:10

Prince Goulash


2 Answers

With :undojoin, you can join your changes with the last changes done by the user (though I would find that more confusing than having them separate). In general, undo is sequence of steps; you cannot simply omit steps in the middle, that would both be unintuitive and also difficult to implement in the undo engine.

Anyway, what's so bad about including your automatic reformatting in the undo history? As I understand it, it'll be re-applied on the next save when the user undoes his last edits.

like image 78
Ingo Karkat Avatar answered Nov 17 '22 14:11

Ingo Karkat


If your BufWritePre action is performing manipulations that ultimately leave your file unchanged, you can:

:wundo <tmpfile>

...Make changes leaving file the same afterwards...

:rundo <tmpfile>

This will leave you with your undo history prior to the temporary change, however if the file doesn't match it's previous state you'll get the error File contents changed, cannot use undo info.

If you wish to make the changes done during the BufWritePre impossible to undo, you can:

:set noundofile

.. Perform changes ...

:set undofile

However, this will lose all history prior to the BufWritePre

like image 3
Benj Avatar answered Nov 17 '22 14:11

Benj