diff --git a/nerdtree_plugin/git_menu.vim b/nerdtree_plugin/git_menu.vim deleted file mode 100644 index fa5672e..0000000 --- a/nerdtree_plugin/git_menu.vim +++ /dev/null @@ -1,116 +0,0 @@ -" ============================================================================ -" File: git_menu.vim -" Description: plugin for the NERD Tree that provides a git menu -" Maintainer: Martin Grenfell -" Last Change: 20 July, 2009 -" License: This program is free software. It comes without any warranty, -" to the extent permitted by applicable law. You can redistribute -" it and/or modify it under the terms of the Do What The Fuck You -" Want To Public License, Version 2, as published by Sam Hocevar. -" See http://sam.zoy.org/wtfpl/COPYING for more details. -" -" ============================================================================ -" -" Adds a "g" submenu to the NERD tree menu. -" -" Note: this plugin assumes that the current tree root has a .git dir under -" it, and that the working tree and the .git repo are in the same place -" -if exists("g:loaded_nerdtree_git_menu") - finish -endif -let g:loaded_nerdtree_git_menu = 1 - -call NERDTreeAddMenuSeparator({'isActiveCallback': 'NERDTreeGitMenuEnabled'}) -let s:menu = NERDTreeAddSubmenu({ - \ 'text': '(g)it menu', - \ 'shortcut': 'g', - \ 'isActiveCallback': 'NERDTreeGitMenuEnabled' }) - -call NERDTreeAddMenuItem({ - \ 'text': 'git (a)dd', - \ 'shortcut': 'a', - \ 'isActiveCallback': 'NERDTreeGitMenuEnabled', - \ 'callback': 'NERDTreeGitAdd', - \ 'parent': s:menu }) - -call NERDTreeAddMenuItem({ - \ 'text': 'git (c)heckout', - \ 'shortcut': 'c', - \ 'isActiveCallback': 'NERDTreeGitMenuEnabled', - \ 'callback': 'NERDTreeGitCheckout', - \ 'parent': s:menu }) - -call NERDTreeAddMenuItem({ - \ 'text': 'git (m)v', - \ 'shortcut': 'm', - \ 'isActiveCallback': 'NERDTreeGitMenuEnabled', - \ 'callback': 'NERDTreeGitMove', - \ 'parent': s:menu }) - -call NERDTreeAddMenuItem({ - \ 'text': 'git (r)m', - \ 'shortcut': 'r', - \ 'isActiveCallback': 'NERDTreeGitMenuEnabled', - \ 'callback': 'NERDTreeGitRemove', - \ 'parent': s:menu }) - -function! NERDTreeGitMenuEnabled() - return isdirectory(s:GitRepoPath()) -endfunction - -function! s:GitRepoPath() - return b:NERDTreeRoot.path.str() . ".git" -endfunction - -function! NERDTreeGitMove() - let node = g:NERDTreeFileNode.GetSelected() - let path = node.path - let p = path.str({'escape': 1}) - - let newPath = input("==========================================================\n" . - \ "Enter the new path for the file: \n" . - \ "", node.path.str()) - if newPath ==# '' - call s:echo("git mv aborted.") - return - endif - - call s:execGitCmd('mv ' . p . ' ' . newPath) -endfunction - -function! NERDTreeGitAdd() - let node = g:NERDTreeFileNode.GetSelected() - let path = node.path - call s:execGitCmd('add ' . path.str({'escape': 1})) -endfunction - -function! NERDTreeGitRemove() - let node = g:NERDTreeFileNode.GetSelected() - let path = node.path - call s:execGitCmd('rm ' . path.str({'escape': 1})) -endfunction - -function! NERDTreeGitCheckout() - let node = g:NERDTreeFileNode.GetSelected() - let path = node.path - call s:execGitCmd('checkout ' . path.str({'escape': 1})) -endfunction - -function! s:execGitCmd(sub_cmd) - let extra_options = '--git-dir=' . s:GitRepoPath() . ' ' - let extra_options .= '--work-tree=' . b:NERDTreeRoot.path.str() - let cmd = "git" . ' ' . extra_options . ' ' . a:sub_cmd - - let output = system(cmd) - redraw! - if v:shell_error == 0 - let node = g:NERDTreeFileNode.GetSelected() - if !node.isRoot() - call node.parent.refresh() - call NERDTreeRender() - endif - else - echomsg output - endif -endfunction