Skip to content

Ability to change what happens when pasting with Cmd+v the editor while still being able to use Cmd+v to paste in dialogs #1505

Open
@adamnovak

Description

@adamnovak

Is your feature request about something that is currently impossible or hard to do? Please describe the problem.

I'm trying to customize paste behavior in MacVim in insert mode, to add come <C-g>u sequences to create undo points before and after the pasted text.

I can do that with an inoremap <D-v>. But in order for <D-v> to make it to the Vim input processing, it can't be bound in the MacVim menu system to the paste: action. So the folks at SuperUser suggest:

macmenu Edit.Paste key=<nop>
noremap <D-v> "*P
cnoremap <D-v> <C-r><C-o>*
inoremap <D-v> <C-g>u<C-r><C-o>*

But if you do that, then paste doesn't work in dialogs and other non-Vim UI elements insider MacVim, such as the graphical find dialog. As noted in the MacVim help on customizing the menu:

(E.g. the menu item "Edit.Paste" must be bound to the action "paste:" otherwise pasting won't work in dialogs since that is the action that instructs them to paste something.)

And I can't find any documentation on how to either change what happens when a paste: action is received by the Vim layer, or to set what happens when a <D-v> is sent to the GUI layer when it's not bound to a menu option.

So I'm not able to achieve the configuration where pressing Command+v creates undo points around the pasted text in Vim's insert mode, but also still works on text boxes in the GUI.

Describe the solution you'd like

My ideal approach would be to have paste: reach the Vim core exactly as if <D-v> were being typed, so that remapping <D-v> with inoremap would Just Work without having to unbind it from the menu item.

Describe alternatives you've considered
Other approaches would be:

  • Providing a command to control what MacVim actions like paste: do when they reach the Vim level.
  • Providing an option on the macmenu command to set key sequences to be issued in Vim before/after the action is processed.
  • Providing a mode-specific map-like command to map keys in the "mode" of having a dialog box selected, so that you could <something>noremap <D-v> to :macaction paste: and have that work in the dialogs. This might be totally impossible since then Vim internals would have to process all the keypresses in the dialogs.
  • Documenting some already-existing way to customize what the paste: action does by overwriting/replacing some VimScript function it already invokes.

Additional context
I only barely know enough about Vim input processing to articulate what I want to achieve, so it's possible I'm missing something obvious about how pasting works in Vim.

Metadata

Metadata

Assignees

No one assigned

    Labels

    InputIssues related to keyboard or other types of input

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions