Deleting entire function definition in Vim
Asked Answered
C

15

63

I've been trying Vim for any text editing work for almost a week now. I want to know the fastest way to select a C function definition.

For example, if I have a function like this:

void helloworlds( int num )
{
    int n;
    for ( n = 0; n < num; ++n ) {
        printf( "Hello World!\n" );
    }
}

How would I be able to delete the whole definition including the function name?

Chema answered 30/7, 2012 at 14:4 Comment(1)
Put cursor into the function body, for example the first line of body. Then, va}o-0. If { is at the same line with function signature, for example void helloworlds( int num ) {, then use va}o0.Lepidote
A
106

As is common in Vim, there are a bunch of ways!

Note that the first two solutions depend on an absence of blank lines.

  • If your cursor is on the line with the function name, try d}. It will delete everything to the next block (i.e. your function body).

  • Within the function body itself, dap will delete the 'paragraph'.

  • You can delete a curly brace block with da}. (If you like this syntax, I recommend Tim Pope's fantastic surround.vim, which adds more features with a similar feel).

  • You could also try using regular expressions to delete until the next far left-indented closing curly brace: d/^}Enter

  • ]] and [[ move to the next/previous first-column curly brace (equivalent to using / and ? with that regex I mentioned above. Combine with the d motion, and you acheive the same effect. In addons like Python-mode, these operators are redefined to mean exactly what you're looking for: move from function to function.

How to delete the whole block, header included

If you're on the header/name, or the line before the block, da} should do the trick.

If you're below a block, you can also make use of the handy 'offset' feature of a Vim search. d?^{?-1 will delete backwards to one line before the first occurrence of a first-column opening curly brace. This command's a bit tricky to type. Maybe you could make a <leader> shortcut out of it.

Plugins

I don't do much C programming in Vim, but there are surely plugins to help with such a thing. Try Vim Scripts or their mirror at GitHub.

Amara answered 30/7, 2012 at 14:10 Comment(7)
da} (or daB) is built-in Vim functionality, it doesn't need the plugin (see :help aB)Insole
Oops! The plugin does such an awesome job with the "Vim feel" I forget what's built-in. Thanks for the pointer! The rest of my tips are vim -u NONE tested, however. =)Amara
Thanks, I tried those commands and they work great if I just want to delete the function block. Is there a way to delete the function header/name altogether?Chema
@Jacky, I was responding as a comment, but it got too long. I made another edit addressing your question. Let me know if that suits your needs.Amara
Whoa that's a lot of commands haha! I guess I'll resort to the plugins then. Thanks for the references!Chema
Read this answer assuming I'd find something "good enough" to use in Python despite this being a C question (and I did with d}), but then you mentioned Python-mode, which is exactly what I needed.Birdhouse
da} doesn't include the declaration, an easy way is to use a visual selection and convert it to a visual line selection to get the entire function: va}V and then yank/delete y/dNolpros
L
33

To delete an entire function, including its definition, such as:

function tick() {
        // ... 
}
  • Move to the line with the function name.
  • Move the cursor to the opening brace, f{ should do it, or simply $.
  • Press V%d (Visual line, move to matching pair, delete)

If your functions look like this:

function tick() 
{
        // ... 
}
  • Move to the line with the function name.
  • Press J (join the current line with line bellow. This also puts your cursor at the last character on the resulting line, {, just the one we need for the next command.)
  • Press V%d (Visual line, move to matching pair, delete.)

or

  • Move to the line with the function name.
  • Press V[Down]%d (Visual line, move one line down, move to matching pair, delete.)
Lin answered 26/11, 2013 at 22:57 Comment(1)
Why not Vj%d? There's no need to [Down].Germaine
W
8

If you are willing to install plugins vim-textobj-function will give you vif for Visual select Inside Function and vaf for Visual select A Function.

daf will delete the function, both the line with the signature and the function body ({})

The text object defined by this plugin are more specific and they don't rely on the function body being a contiguous block of text or { being placed at the first character on the line.

The drawback is that you depend on an external plugin.

Wringer answered 9/2, 2015 at 17:36 Comment(0)
F
5

You can use this shortcut to delete not only the function, also the lines between curly braces, i.e the code between if-else statements,while,for loops ,etc.

Press Shitf + v [Will get you in visual Mode] at the curly brace start/end.

Then Press ] + } i.e ] + Shitf ] - If you are in start brace.

Then Press [ + { i.e [ + Shitf [ - If you are in end brace.

Then DEL to delete the lines selected.

Friendly answered 6/11, 2013 at 14:36 Comment(0)
P
5

The simplest and most direct way way is as follows (works anywhere inside function):

v   enter visual mode
{   move to first brace in function (may have to press more than once)
o   exchange cursor from top to bottom of selection
}   extend selection to bottom of function
d   delete selected text

The complete command sequence would be v{o}d. Note that you can do other operations besides delete the same way. For example, to copy the function, use y (yank) instead of d.

Palmy answered 13/10, 2014 at 20:58 Comment(0)
T
4

Use this simple way

   1.Go to the function definition 
   2.dd  - delete function definition 
   3.d    -start delete operation 
   4.shift+5(%) - delete the lines between { to }
Throstle answered 17/1, 2014 at 6:36 Comment(2)
dW if func() {Elegance
and dt{ if func () { :PElegance
M
3

If your function were separated by the blank lines, just type:

dip

which means "delete inner paragraph".

Moritz answered 7/9, 2018 at 16:6 Comment(0)
M
1

Another way is to go to the line of the start of your function and hit: Vj% (or V%% if your style puts the opening brace on the same line). This puts you into Visual-Line mode and the percent takes you to the matching closing brace. In the second style, the first % takes you to the opening brace on the line that you selected and the second to its matching closing brace.

Also works for parentheses, brackets, C-style multi-line comments and preprocessor directives.

See the manual for more info.

Medor answered 27/6, 2016 at 21:0 Comment(1)
% jumps to the ) instead of }Elegance
S
1

Pre-condition: be somewhere inside the function. Go to the previous closing curly bracket on the first line using

[]

Then delete down to the next closing curly bracket on the first line using

d][
Seoul answered 12/6, 2018 at 11:42 Comment(0)
H
1

Most posted methods have a downside or two. Usually, when working withing a class definition of some object oriented language, you might not have an empty line after the function body, because many code formatters put the closing braces of last method and class on consecutive lines. Also, you might have annotations on top of the function. To make matters worse, there might be empty lines within your function body. Additionally you'd prefer a method that works with the cursor anywhere within the function, because having to move it to a specific line or worse, character, takes valuable time. Imagine something like

public class Test {

    /* ... */

    @Test
    public void testStuff() {
        // given
        doSetup();

        // when
        doSomething();

        // then
        assertSomething();
    }
}

In this scenario, vap won't do you any good, since it stops at the first empty line within your function. v{o} is out for the same reason. va{V is better but doesn't catch the annotation on top of the method. So what I would do in the most general case is va{o{. va{ selects the whole function body (caveat: if your cursor is within a nested block, for instance an inner if statement, then you'll only get that block), o puts the cursor to the beginning of the selection and { selects the whole paragraph prepending your selection. This means you'll get the function definition, all annotations and doc comments.

Huba answered 6/7, 2020 at 12:4 Comment(0)
M
1

the most easy way I found is: Get to the line where the function starts and do this: ^^vf{% to mark the entire function and then whatever you like.

  • ^^ - start of the line
  • v - start visual mode
  • f - jump to the next search character
  • { - this is the search character
  • % - jump to the closing brackets

This is also very logical after you have used it a few times.

Morose answered 30/8, 2022 at 18:56 Comment(0)
M
0

non-visual way:

d/^}/e

... delete by searching for } at line beining, including it for deletion.

without /e (not mentioned in above answers), solution is incomplete.

with /e - searching goes to end of match, so closing bracket is included, and command is well for yanking too:

y/^}/e
Misguide answered 3/4, 2015 at 16:17 Comment(0)
P
0

if you use neovim version :>0.5
the modern way is to use treesitter and build your model, then you can be selected or yanked or deleted...

Tree-sitter is a parser generator tool and an incremental parsing library. It can build a concrete syntax tree for a source file and efficiently update the syntax tree as the source file is edited

I suggested this video on youtube to learn how to use treesitter to build your model : Let's create a Neovim plugin using Treesitter and Lua

Peeve answered 1/9, 2021 at 5:37 Comment(0)
S
0

I tried all the top answers here, but none of them works except the one by Nick which suggests to press f{ to get to the opening curly brace. Then V%d to delete the whole function.

Note that, the whole function gets yanked, so you can paste it elsewhere. I come across this use-case frequently, especially when moving if blocks inside another.

Snowflake answered 6/2, 2022 at 7:44 Comment(1)
As it’s currently written, your answer is unclear. Please edit to add additional details that will help others understand how this addresses the question asked. You can find more information on how to write good answers in the help center.Plenitude
S
0

I use this map. It work for me

"delete function definition
"only support function body surround by {}
nnoremap <LEADER>df {v/{<cr>%d
Sarilda answered 5/1, 2023 at 10:10 Comment(1)
As it’s currently written, your answer is unclear. Please edit to add additional details that will help others understand how this addresses the question asked. You can find more information on how to write good answers in the help center.Plenitude

© 2022 - 2025 — McMap. All rights reserved.