On Thursday, September 25, 2014 12:10:09 AM UTC-5, Tony Mechelynck wrote:
> On 22/09/14 19:37, Ben Fritz wrote:
> 
> > I was actually quite surprised to find that abbreviations don't work if you 
> > wait 'updatetime' milliseconds between starting and ending the 
> > abbreviation, triggering the CursorHoldI event. That could be due to 
> > specific events firing, I don't really know, but it is not documented 
> > anywhere I could find.
> 
> 
> 
> What is documented is that mappings expire after 'timoutlen' 
> 
> milliseconds. Abbreviations are not explicitly mentioned there, but I 
> 
> imagine that they might share part of the mapping code.
> 
> 
> 
> - Try setting 'timeoutlen' and 'updatetime' to very different valuies so 
> 
> you can easily tell which of them is relevant;
> 
> - If 'updatetime' does trigger abbreviations even when very different 
> 
> from 'timeoulen', does it make a difference if you remove any CursoHoldI 
> 
> autocommands that you might have?
> 
> 

Oh, it's definitely 'updatetime' and CursorHoldI. In my case abbreviations 
would expand if I waited a few seconds, but if I waited longer the cursor would 
briefly pause in its flashing as my autocmds processed, and after that 
abbreviations would not expand. I checked my autocmds and found the culprit.

In my case the behavior is caused by this autocmd, which I did not remember 
having, and I can probably understand why it would impact abbreviations:

    if exists("##CursorHoldI")
      autocmd CursorHoldI * call feedkeys("\<C-G>u", "nt")
    endif

The autocmd breaks the undo sequence if pausing for a long time in insert mode, 
since if I pause a long time in insert mode I'm probably making multiple 
changes. I imagine breaking the undo sequence also breaks the insert so that it 
no longer looks like I typed the whole abbreviation this insert session.

I'm sure there may be other autocmds or plugins which could cause similar 
problems; all they must do is break the undo sequence somehow.

-- 
-- 
You received this message from the "vim_use" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_use" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
For more options, visit https://groups.google.com/d/optout.

Reply via email to