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?
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.