2017-07-28 20:38:26 -04:00
|
|
|
The NERDTree
|
2011-12-24 10:58:57 +00:00
|
|
|
=============
|
|
|
|
|
2017-07-28 20:38:26 -04:00
|
|
|
Introduction
|
|
|
|
------------
|
2011-12-24 10:58:57 +00:00
|
|
|
|
2017-07-28 20:38:26 -04:00
|
|
|
The NERDTree is a file system explorer for the Vim editor. Using this plugin,
|
|
|
|
you can visually browse complex directory hierarchies, quickly open files for
|
|
|
|
reading or editing, and perform basic file system operations. This plugin can
|
|
|
|
also be extended with custom mappings using a special API. The details of this
|
|
|
|
API and other NERDTree features is described in the included documentation.
|
2011-12-24 10:58:57 +00:00
|
|
|
|
2017-07-28 20:38:26 -04:00
|
|
|
![NERDTree Screenshot](https://github.com/scrooloose/nerdtree/raw/master/screenshot.png)
|
2011-12-24 10:58:57 +00:00
|
|
|
|
|
|
|
Installation
|
|
|
|
------------
|
|
|
|
|
2017-03-26 14:51:09 -04:00
|
|
|
#### [pathogen.vim](https://github.com/tpope/vim-pathogen)
|
2011-12-24 10:58:57 +00:00
|
|
|
|
2016-05-23 10:59:07 -05:00
|
|
|
git clone https://github.com/scrooloose/nerdtree.git ~/.vim/bundle/nerdtree
|
2011-12-24 10:58:57 +00:00
|
|
|
|
2017-07-04 10:14:35 -04:00
|
|
|
Then reload Vim, run `:helptags ~/.vim/bundle/nerdtree/doc/`, and check out `:help NERDTree.txt`.
|
2011-12-24 10:58:57 +00:00
|
|
|
|
|
|
|
|
2017-03-26 14:51:09 -04:00
|
|
|
#### [apt-vim](https://github.com/egalpin/apt-vim)
|
2015-07-30 08:52:17 -04:00
|
|
|
|
|
|
|
apt-vim install -y https://github.com/scrooloose/nerdtree.git
|
|
|
|
|
2017-07-28 20:38:26 -04:00
|
|
|
F.A.Q.
|
|
|
|
------
|
2011-12-24 10:58:57 +00:00
|
|
|
|
2015-05-02 12:01:22 +01:00
|
|
|
> Is there any support for `git` flags?
|
2011-12-27 21:52:43 +00:00
|
|
|
|
2015-05-02 12:01:22 +01:00
|
|
|
Yes, install [nerdtree-git-plugin](https://github.com/Xuyuanp/nerdtree-git-plugin).
|
2011-12-24 10:58:57 +00:00
|
|
|
|
2016-03-05 17:03:23 -05:00
|
|
|
---
|
2012-01-04 11:44:54 +00:00
|
|
|
|
2015-05-02 12:01:22 +01:00
|
|
|
> Can I have the nerdtree on every tab automatically?
|
2012-01-04 11:44:54 +00:00
|
|
|
|
2015-05-02 12:01:22 +01:00
|
|
|
Nope. If this is something you want then chances are you aren't using tabs and
|
|
|
|
buffers as they were intended to be used. Read this
|
|
|
|
http://stackoverflow.com/questions/102384/using-vims-tabs-like-buffers
|
2012-01-04 11:44:54 +00:00
|
|
|
|
2015-05-02 12:01:22 +01:00
|
|
|
If you are interested in this behaviour then consider [vim-nerdtree-tabs](https://github.com/jistr/vim-nerdtree-tabs)
|
2012-01-04 11:44:54 +00:00
|
|
|
|
2016-03-05 17:03:23 -05:00
|
|
|
---
|
2015-05-02 12:01:22 +01:00
|
|
|
> How can I open a NERDTree automatically when vim starts up?
|
|
|
|
|
|
|
|
Stick this in your vimrc: `autocmd vimenter * NERDTree`
|
|
|
|
|
2016-03-05 17:03:23 -05:00
|
|
|
---
|
2015-05-02 12:01:22 +01:00
|
|
|
> How can I open a NERDTree automatically when vim starts up if no files were specified?
|
|
|
|
|
2015-11-26 18:57:38 +00:00
|
|
|
Stick this in your vimrc:
|
2014-06-29 12:29:49 +01:00
|
|
|
|
|
|
|
autocmd StdinReadPre * let s:std_in=1
|
2014-07-02 19:46:03 -04:00
|
|
|
autocmd VimEnter * if argc() == 0 && !exists("s:std_in") | NERDTree | endif
|
2012-01-04 11:44:54 +00:00
|
|
|
|
2015-11-26 18:57:38 +00:00
|
|
|
Note: Now start vim with plain `vim`, not `vim .`
|
|
|
|
|
2016-10-09 15:26:48 +08:00
|
|
|
---
|
2016-10-10 15:16:00 -04:00
|
|
|
> How can I open NERDTree automatically when vim starts up on opening a directory?
|
2016-10-09 15:11:27 +08:00
|
|
|
|
|
|
|
autocmd StdinReadPre * let s:std_in=1
|
2016-10-09 20:28:33 +08:00
|
|
|
autocmd VimEnter * if argc() == 1 && isdirectory(argv()[0]) && !exists("s:std_in") | exe 'NERDTree' argv()[0] | wincmd p | ene | endif
|
2016-10-09 15:26:48 +08:00
|
|
|
|
2016-10-10 15:16:00 -04:00
|
|
|
This window is tab-specific, meaning it's used by all windows in the tab. This trick also prevents NERDTree from hiding when first selecting a file.
|
2016-10-09 15:11:27 +08:00
|
|
|
|
2016-03-05 17:03:23 -05:00
|
|
|
---
|
2015-05-02 12:01:22 +01:00
|
|
|
> How can I map a specific key or shortcut to open NERDTree?
|
2012-12-31 16:15:55 -02:00
|
|
|
|
2015-05-02 12:01:22 +01:00
|
|
|
Stick this in your vimrc to open NERDTree with `Ctrl+n` (you can set whatever key you want):
|
2014-10-29 20:00:36 -04:00
|
|
|
|
2015-05-12 20:58:35 +01:00
|
|
|
map <C-n> :NERDTreeToggle<CR>
|
2012-12-31 16:15:55 -02:00
|
|
|
|
2016-03-05 17:03:23 -05:00
|
|
|
---
|
2015-05-02 12:01:22 +01:00
|
|
|
> How can I close vim if the only window left open is a NERDTree?
|
2012-01-04 11:44:54 +00:00
|
|
|
|
2015-05-02 12:01:22 +01:00
|
|
|
Stick this in your vimrc:
|
2012-01-04 11:44:54 +00:00
|
|
|
|
2015-11-14 12:01:55 +00:00
|
|
|
autocmd bufenter * if (winnr("$") == 1 && exists("b:NERDTree") && b:NERDTree.isTabTree()) | q | endif
|
2015-05-12 20:57:49 +01:00
|
|
|
|
2016-03-05 17:03:23 -05:00
|
|
|
---
|
2015-05-12 20:57:49 +01:00
|
|
|
> Can I have different highlighting for different file extensions?
|
|
|
|
|
|
|
|
See here: https://github.com/scrooloose/nerdtree/issues/433#issuecomment-92590696
|
2015-09-11 23:44:06 +06:00
|
|
|
|
2016-03-05 17:03:23 -05:00
|
|
|
---
|
2015-09-11 23:44:06 +06:00
|
|
|
> How can I change default arrows?
|
|
|
|
|
|
|
|
Use these variables in your vimrc. Note that below are default arrow symbols
|
|
|
|
|
2016-10-04 17:52:12 -04:00
|
|
|
let g:NERDTreeDirArrowExpandable = '▸'
|
|
|
|
let g:NERDTreeDirArrowCollapsible = '▾'
|