Що є у вашому .vimrc? [зачинено]


157

Vi та Vim дозволяють зробити справді приголомшливі налаштування, як правило, зберігаються у .vimrcфайлі. Типовими особливостями для програміста є виділення синтаксису, розумне відступ тощо.

Які ще хитрощі для продуктивного програмування ви заховали у своєму .vimrc?

Мене найбільше цікавлять рефактори, автокласи та подібні макроси продуктивності, особливо для C #.


11
Я думаю, ви мали б попросити людей опублікувати свої коментовані файли vim config.
innaM

Чому б не поділитися цими речами на github? У мене є ціла папка .vim під git, і все це можна побачити тут: github.com/lsdr/vim-folder
lsdr

1
Я не думаю, що цілі .vimrcs корисні; якщо купа людей викликає відповідь, ти просто збираєшся взяти всю річ і ляпати її у свою систему? Фрагменти набагато корисніші, так само як список корисних псевдонімів або функцій набагато кращий, ніж цілі. (Bash | z) rc файли.
Xiong Chiamiov

Відповіді:


104

Ви просили його :-)

"{{{Auto Commands

" Automatically cd into the directory that the file is in
autocmd BufEnter * execute "chdir ".escape(expand("%:p:h"), ' ')

" Remove any trailing whitespace that is in the file
autocmd BufRead,BufWrite * if ! &bin | silent! %s/\s\+$//ge | endif

" Restore cursor position to where it was before
augroup JumpCursorOnEdit
   au!
   autocmd BufReadPost *
            \ if expand("<afile>:p:h") !=? $TEMP |
            \   if line("'\"") > 1 && line("'\"") <= line("$") |
            \     let JumpCursorOnEdit_foo = line("'\"") |
            \     let b:doopenfold = 1 |
            \     if (foldlevel(JumpCursorOnEdit_foo) > foldlevel(JumpCursorOnEdit_foo - 1)) |
            \        let JumpCursorOnEdit_foo = JumpCursorOnEdit_foo - 1 |
            \        let b:doopenfold = 2 |
            \     endif |
            \     exe JumpCursorOnEdit_foo |
            \   endif |
            \ endif
   " Need to postpone using "zv" until after reading the modelines.
   autocmd BufWinEnter *
            \ if exists("b:doopenfold") |
            \   exe "normal zv" |
            \   if(b:doopenfold > 1) |
            \       exe  "+".1 |
            \   endif |
            \   unlet b:doopenfold |
            \ endif
augroup END

"}}}

"{{{Misc Settings

" Necesary  for lots of cool vim things
set nocompatible

" This shows what you are typing as a command.  I love this!
set showcmd

" Folding Stuffs
set foldmethod=marker

" Needed for Syntax Highlighting and stuff
filetype on
filetype plugin on
syntax enable
set grepprg=grep\ -nH\ $*

" Who doesn't like autoindent?
set autoindent

" Spaces are better than a tab character
set expandtab
set smarttab

" Who wants an 8 character tab?  Not me!
set shiftwidth=3
set softtabstop=3

" Use english for spellchecking, but don't spellcheck by default
if version >= 700
   set spl=en spell
   set nospell
endif

" Real men use gcc
"compiler gcc

" Cool tab completion stuff
set wildmenu
set wildmode=list:longest,full

" Enable mouse support in console
set mouse=a

" Got backspace?
set backspace=2

" Line Numbers PWN!
set number

" Ignoring case is a fun trick
set ignorecase

" And so is Artificial Intellegence!
set smartcase

" This is totally awesome - remap jj to escape in insert mode.  You'll never type jj anyway, so it's great!
inoremap jj <Esc>

nnoremap JJJJ <Nop>

" Incremental searching is sexy
set incsearch

" Highlight things that we find with the search
set hlsearch

" Since I use linux, I want this
let g:clipbrdDefaultReg = '+'

" When I close a tab, remove the buffer
set nohidden

" Set off the other paren
highlight MatchParen ctermbg=4
" }}}

"{{{Look and Feel

" Favorite Color Scheme
if has("gui_running")
   colorscheme inkpot
   " Remove Toolbar
   set guioptions-=T
   "Terminus is AWESOME
   set guifont=Terminus\ 9
else
   colorscheme metacosm
endif

"Status line gnarliness
set laststatus=2
set statusline=%F%m%r%h%w\ (%{&ff}){%Y}\ [%l,%v][%p%%]

" }}}

"{{{ Functions

"{{{ Open URL in browser

function! Browser ()
   let line = getline (".")
   let line = matchstr (line, "http[^   ]*")
   exec "!konqueror ".line
endfunction

"}}}

"{{{Theme Rotating
let themeindex=0
function! RotateColorTheme()
   let y = -1
   while y == -1
      let colorstring = "inkpot#ron#blue#elflord#evening#koehler#murphy#pablo#desert#torte#"
      let x = match( colorstring, "#", g:themeindex )
      let y = match( colorstring, "#", x + 1 )
      let g:themeindex = x + 1
      if y == -1
         let g:themeindex = 0
      else
         let themestring = strpart(colorstring, x + 1, y - x - 1)
         return ":colorscheme ".themestring
      endif
   endwhile
endfunction
" }}}

"{{{ Paste Toggle
let paste_mode = 0 " 0 = normal, 1 = paste

func! Paste_on_off()
   if g:paste_mode == 0
      set paste
      let g:paste_mode = 1
   else
      set nopaste
      let g:paste_mode = 0
   endif
   return
endfunc
"}}}

"{{{ Todo List Mode

function! TodoListMode()
   e ~/.todo.otl
   Calendar
   wincmd l
   set foldlevel=1
   tabnew ~/.notes.txt
   tabfirst
   " or 'norm! zMzr'
endfunction

"}}}

"}}}

"{{{ Mappings

" Open Url on this line with the browser \w
map <Leader>w :call Browser ()<CR>

" Open the Project Plugin <F2>
nnoremap <silent> <F2> :Project<CR>

" Open the Project Plugin
nnoremap <silent> <Leader>pal  :Project .vimproject<CR>

" TODO Mode
nnoremap <silent> <Leader>todo :execute TodoListMode()<CR>

" Open the TagList Plugin <F3>
nnoremap <silent> <F3> :Tlist<CR>

" Next Tab
nnoremap <silent> <C-Right> :tabnext<CR>

" Previous Tab
nnoremap <silent> <C-Left> :tabprevious<CR>

" New Tab
nnoremap <silent> <C-t> :tabnew<CR>

" Rotate Color Scheme <F8>
nnoremap <silent> <F8> :execute RotateColorTheme()<CR>

" DOS is for fools.
nnoremap <silent> <F9> :%s/$//g<CR>:%s// /g<CR>

" Paste Mode!  Dang! <F10>
nnoremap <silent> <F10> :call Paste_on_off()<CR>
set pastetoggle=<F10>

" Edit vimrc \ev
nnoremap <silent> <Leader>ev :tabnew<CR>:e ~/.vimrc<CR>

" Edit gvimrc \gv
nnoremap <silent> <Leader>gv :tabnew<CR>:e ~/.gvimrc<CR>

" Up and down are more logical with g..
nnoremap <silent> k gk
nnoremap <silent> j gj
inoremap <silent> <Up> <Esc>gka
inoremap <silent> <Down> <Esc>gja

" Good call Benjie (r for i)
nnoremap <silent> <Home> i <Esc>r
nnoremap <silent> <End> a <Esc>r

" Create Blank Newlines and stay in Normal mode
nnoremap <silent> zj o<Esc>
nnoremap <silent> zk O<Esc>

" Space will toggle folds!
nnoremap <space> za

" Search mappings: These will make it so that going to the next one in a
" search will center on the line it's found in.
map N Nzz
map n nzz

" Testing
set completeopt=longest,menuone,preview

inoremap <expr> <cr> pumvisible() ? "\<c-y>" : "\<c-g>u\<cr>"
inoremap <expr> <c-n> pumvisible() ? "\<lt>c-n>" : "\<lt>c-n>\<lt>c-r>=pumvisible() ? \"\\<lt>down>\" : \"\"\<lt>cr>"
inoremap <expr> <m-;> pumvisible() ? "\<lt>c-n>" : "\<lt>c-x>\<lt>c-o>\<lt>c-n>\<lt>c-p>\<lt>c-r>=pumvisible() ? \"\\<lt>down>\" : \"\"\<lt>cr>"

" Swap ; and :  Convenient.
nnoremap ; :
nnoremap : ;

" Fix email paragraphs
nnoremap <leader>par :%s/^>$//<CR>

"ly$O#{{{ "lpjjj_%A#}}}jjzajj

"}}}

"{{{Taglist configuration
let Tlist_Use_Right_Window = 1
let Tlist_Enable_Fold_Column = 0
let Tlist_Exit_OnlyWindow = 1
let Tlist_Use_SingleClick = 1
let Tlist_Inc_Winwidth = 0
"}}}

let g:rct_completion_use_fri = 1
"let g:Tex_DefaultTargetFormat = "pdf"
let g:Tex_ViewRule_pdf = "kpdf"

filetype plugin indent on
syntax on

78
Але чому 3, встановити shiftwidth = 3, встановити softtabstop = 3 ... можливо 2 або 4, але чому 3?
Йоган

1
Цікаво, але чи не відображення jj в <Esc> незначне відставання при натисканні j у режимі вставки?
sykora

1
@sykora: так, але як тільки ви введете інший символ (це не j), він з’явиться. Я роблю те саме, але натомість з jk, як я думаю, що ударити jk швидше, ніж вдарити jj. Лише раз це вплинуло на мене, набираючи алфавіт, тож, може, kj, ти будеш кращим.
Девід Міані

2
@Johan: тому що "три - це магічне число". :) Насправді це просто велосипед, але я теж віддаю перевагу. :)
Роберт Массайолі

4
Якщо справжні чоловіки використовують gcc, то чому б вам не зробити це? (компілятор gcc коментується!)
Abdulsattar Mohammed

73

Це не в моєму файлі .vimrc, але вчора я дізнався про ]pкоманду. Це вставляє вміст буфера так само, як pце робить, але він автоматично налаштовує відступ відповідно до рядка, на якому курсор! Це чудово для переміщення коду.


Ви маєте на увазі це схоже на: set paste, p,: set nopaste?
гіперборея

3
Наскільки мені відомо, параметр: set paste не впливає на команду p, він впливає лише на текст, набраний (або вставлений через термінал) у режимі вставки. Так ні, це інша особливість.
Грег Х'югілл

1
Не слід закликати до цього, бо це не відповідає на питання, але мені це дуже подобається;)
gorsky

53

Я використовую наступне, щоб зберігати всі тимчасові та резервні файли в одному місці:

set backup
set backupdir=~/.vim/backup
set directory=~/.vim/tmp

Економить захаращені робочі каталоги всюди.

Спершу вам доведеться створити ці каталоги, vim не створить їх для вас.


2
Я мушу зазначити, що вам доведеться створювати ці каталоги самостійно, vim не зробить це за вас.
Харлі Холкомб

Чи правильно це обробляє кілька однакових файлів? (наприклад, якщо ви редагуєте кілька різних гілок одного і того ж коду)
yungchin

Ні, це замінить старі файли резервних копій з тим самим іменем. Якщо у когось є шлях до цього, дайте мені знати.
Харлі Холкомб

3
Спробуйте це: au BufWritePre * let & bex = '-'. строк ("% Y% m% d-% H% M% S"). '.vimbackup' (Це один рядок.) І я також мушу згадати про це: vim.wikia.com/wiki/VimTip962
Zsolt Botykai

1
Це також заважає Vim не скаржитися під час відкриття Dropbox- файлів на різних машинах.
Коді Гесс

31

У когось (наприклад, Frew), який опублікував вище, був такий рядок:

"Автоматично введіть CD у каталог, у якому знаходиться файл:"

autocmd BufEnter * execute "chdir ".escape(expand("%:p:h"), ' ')

Я робив щось подібне сам до тих пір, поки не виявив, що те ж саме можна зробити за допомогою вбудованої установки:

set autochdir

Я думаю, що щось подібне трапилося зі мною кілька різних часів. Vim має стільки різних вбудованих налаштувань та параметрів, що іноді швидше і простіше прокручувати власні, ніж шукати в документах вбудований спосіб це зробити.


чудова знахідка! Мені подобається використовувати вбудовані речі більше ^ _ ^. плюс це не провалюється, якщо є | у назві файлу.
Javed Ahamed

2
autochdir має деякі роздратування, над якими я ніколи не міг обійтись (змінивши каталог перед завантаженням файлу, заданого в командному рядку), і я читав тут ще в SO, про autocmd BufEnter * silent! lcd %:p:h:gs/ /\\ /який робиться те саме основне, але не калічить командний рядок.
Даш-Том-Банг

Я вважаю за краще зробити його необов’язковим і використовувати цю команду для входу в каталог поточного файлу: cd%: h
staackuser2

28

Моє останнє доповнення - для виділення поточного рядка

set cul                                           # highlight current line
hi CursorLine term=none cterm=none ctermbg=3      # adjust color

2
чи є спосіб вибрати з декількох кольорів?
Fzs2

Яка різниця між встановленим куль і встановленою курсорною лінією?
putolaruan

Я просто використовую "встановити куль", щоб отримати рядок під поточним рядком. Налаштування курсору занадто сильно псується з виділенням синтаксису на мій смак.
Claes Mogren

2
Щоб отримати доступні кольори, зверніться до цього сценарію ( vim.org/scripts/script.php?script_id=1349 ). Можливо, потрібно ввімкнути 256-кольорову підтримку для vim, щоб отримати більш широке різноманіття.
Брайан Віггінтон

1
@Claes Власне, set culі set cursorlineроби саме те саме.
Джерардо Марсет

24

Оновлення 2012 року : Зараз я дійсно рекомендую перевірити vim-powerline, який замінив мій старий сценарій статусу, хоча в даний час відсутні деякі функції, які я сумую.


Я б сказав, що дані про статус у моєму vimrc, мабуть, були найцікавішими / корисними з партії (зірвана з авторів vimrc тут та відповідна публікація блогу тут ).

Знімок екрана:

рядок стану http://img34.imageshack.us/img34/849/statusline.png

Код:

"recalculate the trailing whitespace warning when idle, and after saving
autocmd cursorhold,bufwritepost * unlet! b:statusline_trailing_space_warning

"return '[\s]' if trailing white space is detected
"return '' otherwise
function! StatuslineTrailingSpaceWarning()
    if !exists("b:statusline_trailing_space_warning")

        if !&modifiable
            let b:statusline_trailing_space_warning = ''
            return b:statusline_trailing_space_warning
        endif

        if search('\s\+$', 'nw') != 0
            let b:statusline_trailing_space_warning = '[\s]'
        else
            let b:statusline_trailing_space_warning = ''
        endif
    endif
    return b:statusline_trailing_space_warning
endfunction


"return the syntax highlight group under the cursor ''
function! StatuslineCurrentHighlight()
    let name = synIDattr(synID(line('.'),col('.'),1),'name')
    if name == ''
        return ''
    else
        return '[' . name . ']'
    endif
endfunction

"recalculate the tab warning flag when idle and after writing
autocmd cursorhold,bufwritepost * unlet! b:statusline_tab_warning

"return '[&et]' if &et is set wrong
"return '[mixed-indenting]' if spaces and tabs are used to indent
"return an empty string if everything is fine
function! StatuslineTabWarning()
    if !exists("b:statusline_tab_warning")
        let b:statusline_tab_warning = ''

        if !&modifiable
            return b:statusline_tab_warning
        endif

        let tabs = search('^\t', 'nw') != 0

        "find spaces that arent used as alignment in the first indent column
        let spaces = search('^ \{' . &ts . ',}[^\t]', 'nw') != 0

        if tabs && spaces
            let b:statusline_tab_warning = '[mixed-indenting]'
        elseif (spaces && !&et) || (tabs && &et)
            let b:statusline_tab_warning = '[&et]'
        endif
    endif
    return b:statusline_tab_warning
endfunction

"recalculate the long line warning when idle and after saving
autocmd cursorhold,bufwritepost * unlet! b:statusline_long_line_warning

"return a warning for "long lines" where "long" is either &textwidth or 80 (if
"no &textwidth is set)
"
"return '' if no long lines
"return '[#x,my,$z] if long lines are found, were x is the number of long
"lines, y is the median length of the long lines and z is the length of the
"longest line
function! StatuslineLongLineWarning()
    if !exists("b:statusline_long_line_warning")

        if !&modifiable
            let b:statusline_long_line_warning = ''
            return b:statusline_long_line_warning
        endif

        let long_line_lens = s:LongLines()

        if len(long_line_lens) > 0
            let b:statusline_long_line_warning = "[" .
                        \ '#' . len(long_line_lens) . "," .
                        \ 'm' . s:Median(long_line_lens) . "," .
                        \ '$' . max(long_line_lens) . "]"
        else
            let b:statusline_long_line_warning = ""
        endif
    endif
    return b:statusline_long_line_warning
endfunction

"return a list containing the lengths of the long lines in this buffer
function! s:LongLines()
    let threshold = (&tw ? &tw : 80)
    let spaces = repeat(" ", &ts)

    let long_line_lens = []

    let i = 1
    while i <= line("$")
        let len = strlen(substitute(getline(i), '\t', spaces, 'g'))
        if len > threshold
            call add(long_line_lens, len)
        endif
        let i += 1
    endwhile

    return long_line_lens
endfunction

"find the median of the given array of numbers
function! s:Median(nums)
    let nums = sort(a:nums)
    let l = len(nums)

    if l % 2 == 1
        let i = (l-1) / 2
        return nums[i]
    else
        return (nums[l/2] + nums[(l/2)-1]) / 2
    endif
endfunction


"statusline setup
set statusline=%f "tail of the filename

"display a warning if fileformat isnt unix
set statusline+=%#warningmsg#
set statusline+=%{&ff!='unix'?'['.&ff.']':''}
set statusline+=%*

"display a warning if file encoding isnt utf-8
set statusline+=%#warningmsg#
set statusline+=%{(&fenc!='utf-8'&&&fenc!='')?'['.&fenc.']':''}
set statusline+=%*

set statusline+=%h "help file flag
set statusline+=%y "filetype
set statusline+=%r "read only flag
set statusline+=%m "modified flag

"display a warning if &et is wrong, or we have mixed-indenting
set statusline+=%#error#
set statusline+=%{StatuslineTabWarning()}
set statusline+=%*

set statusline+=%{StatuslineTrailingSpaceWarning()}

set statusline+=%{StatuslineLongLineWarning()}

set statusline+=%#warningmsg#
set statusline+=%{SyntasticStatuslineFlag()}
set statusline+=%*

"display a warning if &paste is set
set statusline+=%#error#
set statusline+=%{&paste?'[paste]':''}
set statusline+=%*

set statusline+=%= "left/right separator

function! SlSpace()
    if exists("*GetSpaceMovement")
        return "[" . GetSpaceMovement() . "]"
    else
        return ""
    endif
endfunc
set statusline+=%{SlSpace()}

set statusline+=%{StatuslineCurrentHighlight()}\ \ "current highlight
set statusline+=%c, "cursor column
set statusline+=%l/%L "cursor line/total lines
set statusline+=\ %P "percent through file
set laststatus=2

Крім усього іншого, він повідомляє про рядок статусу звичайну стандартну інформацію про файли, але також включає додаткові речі, такі як попередження для: встановити пасту, змішане відступ, пробіл та інше.

Крім того, і як показано на скріншоті, комбінування його з синтаксичним дозволяє виділити на ньому будь-які синтаксичні помилки (якщо припустити, що у вашій вибраній мові є пов'язана перевірка синтаксису.


У мене виникають проблеми з вищезазначеним. У LongLines () відсутня умовна умова. Я змінив його на "в той час як я <поріг", проте відсутній і лен, який викликається всередині цієї умови. Будь-які ідеї про лен?
Алі

Це нормально, я знайшов тут справжню річ: dotfiles.org/~gregf/.vimrc
Алі

@pug Внутрішня помилка сервера є зараз. = (Чи можете ви надати підказку чи вставити відповідну порцію .vimrc десь, будь ласка?
Антон Строгонов

@Anton виправив пасту, яка зіпсувалася шляхом форматування коду. Має бути добре зараз. Я також рекомендую вставляти його у файл plugin / statusline.vim, щоб він не захаращував ваш .vimrc, якщо ви збираєтесь його використовувати.
Гевін Гілмор

@Gavin працює чудово, дякую за виправлення та за пораду! У мене раніше було щось на зразок autocmd BufEnter *.py match OverLength /\%81v.\+/invimrc для виділення довгих ліній, але ваш підхід може бути менш відволікаючим. Крім того, результат перевірки синтаксису в рядку стану - це одна серйозно класна річ!
Антон Строгонов

19

Моя міні-версія:

syntax on
set background=dark
set shiftwidth=2
set tabstop=2

if has("autocmd")
  filetype plugin indent on
endif

set showcmd             " Show (partial) command in status line.
set showmatch           " Show matching brackets.
set ignorecase          " Do case insensitive matching
set smartcase           " Do smart case matching
set incsearch           " Incremental search
set hidden              " Hide buffers when they are abandoned

Велика версія, зібрана з різних місць:

syntax on
set background=dark
set ruler                     " show the line number on the bar
set more                      " use more prompt
set autoread                  " watch for file changes
set number                    " line numbers
set hidden
set noautowrite               " don't automagically write on :next
set lazyredraw                " don't redraw when don't have to
set showmode
set showcmd
set nocompatible              " vim, not vi
set autoindent smartindent    " auto/smart indent
set smarttab                  " tab and backspace are smart
set tabstop=2                 " 6 spaces
set shiftwidth=2
set scrolloff=5               " keep at least 5 lines above/below
set sidescrolloff=5           " keep at least 5 lines left/right
set history=200
set backspace=indent,eol,start
set linebreak
set cmdheight=2               " command line two lines high
set undolevels=1000           " 1000 undos
set updatecount=100           " switch every 100 chars
set complete=.,w,b,u,U,t,i,d  " do lots of scanning on tab completion
set ttyfast                   " we have a fast terminal
set noerrorbells              " No error bells please
set shell=bash
set fileformats=unix
set ff=unix
filetype on                   " Enable filetype detection
filetype indent on            " Enable filetype-specific indenting
filetype plugin on            " Enable filetype-specific plugins
set wildmode=longest:full
set wildmenu                  " menu has tab completion
let maplocalleader=','        " all my macros start with ,
set laststatus=2

"  searching
set incsearch                 " incremental search
set ignorecase                " search ignoring case
set hlsearch                  " highlight the search
set showmatch                 " show matching bracket
set diffopt=filler,iwhite     " ignore all whitespace and sync

"  backup
set backup
set backupdir=~/.vim_backup
set viminfo=%100,'100,/100,h,\"500,:100,n~/.viminfo
"set viminfo='100,f1

" spelling
if v:version >= 700
  " Enable spell check for text files
  autocmd BufNewFile,BufRead *.txt setlocal spell spelllang=en
endif

" mappings
" toggle list mode
nmap <LocalLeader>tl :set list!<cr>
" toggle paste mode
nmap <LocalLeader>pp :set paste!<cr>

fyi, 'smartindent' є застарілим (його замінюють cindent) і нічого не робить, коли ви використовуєте відступ файлів файлів, і буде активним лише тоді, коли це не корисно
greyh

13

Іноді найцінніші речі найцінніші. Два рядки в моєму .vimrc абсолютно необхідні:

норе; :
nore,;

Я зробив nore \ ;замість цього , оскільки я використовую в ,якості мого<leader>
aehlke

3
Але що це робить? :)
Генрік Бьорнсков

6
напівкрапка - це рідко використовувана команда. двокрапка - надзвичайно поширена команда, яка використовується для входу в режим командного рядка. Перемикання однієї на іншу дозволяє входити в режим командного рядка, не натискаючи клавішу зсуву, тим самим зберігаючи м’язи ваших маленьких пальців.
Вільям Перселл

7
На французьких клавіатурах вам не потрібно "shift", щоб написати ",", ";" і ':' ... Але '\', '[' і ']' - це справжній біль.
Олів'є Понс

12

Різне налаштування:

  1. Вимкніть дратівливі дзвінки помилок:

    set noerrorbells
    set visualbell
    set t_vb=
    
  2. Зробіть переміщення курсору, як очікувалося, за допомогою загорнутих ліній:

    inoremap <Down> <C-o>gj
    inoremap <Up> <C-o>gk
    
  3. Знайдіть ctags"теги" файлу в каталозі, поки не знайдеться один:

    set tags=tags;/
    
  4. Відобразити файли SCons із синтаксисом Python:

    autocmd BufReadPre,BufNewFile SConstruct set filetype=python
    autocmd BufReadPre,BufNewFile SConscript set filetype=python
    

Додайте #! / Usr / bin / python у файл SConstruct, це спричинить вбудовану Vim у магію виявлення типу файлу
richq

Чи є кращий спосіб зробити j/ kрухатись так, як очікувалося, загорнутими лініями? Я не хочу натискати gкожен раз.
puk

8

Я не самий просунутий vim'er у світі, але ось декілька я взяв

function! Mosh_Tab_Or_Complete()
    if col('.')>1 && strpart( getline('.'), col('.')-2, 3 ) =~ '^\w'
        return "\<C-N>"
    else
        return "\<Tab>"
endfunction

inoremap <Tab> <C-R>=Mosh_Tab_Or_Complete()<CR>

Робить вкладку автозаповнення зрозуміти, чи потрібно ви розмістити там слово чи фактичну вкладку (4 пробіли).

map cc :.,$s/^ *//<CR>

Видаліть усі пробіли, що відкриваються, звідти до кінця файлу. Чомусь я вважаю це корисним багато.

set nu! 
set nobackup

Показуйте номери рядків і не створюйте цих дратівливих резервних файлів. Я ніколи нічого не відновлював зі старої резервної копії.

imap ii <C-[>

Перебуваючи у вставці, натисніть i двічі, щоб перейти до командного режиму. Я ніколи не стикався з словом або змінною з 2 я в ряд, і таким чином мені не потрібно, щоб пальці виходили з домашнього ряду або натискали кілька клавіш, щоб перемикатися вперед і назад


3
Цікаве відображення ii ... дуже цікаво. Дуже класна ідея - хоча я б хвилювався, що це сильно вплине на мою здатність використовувати «ванільну» віму, якщо мені доведеться.
thomasrutter

Я робив те саме, що і; тривалий час і не стикалися з жодними проблемами. Коли я змушений вживати vanilla vi / vim, я одразу згадую, що я використовував тупу клавішу [esc] (це була одна з причин, що я ненавиджу vim стільки років!). Для мене ця настройка абсолютно необхідна. Я ніколи не охоче використовую vi (m) без нього. <br> І мені подобається ідея використовувати 'ii' замість ';;': інтуїтивніше, майже як перемикач.
іконоборство

Іншою можливістю є використання Ctrl-C для виходу з режиму вставки. Це майже те саме, що і Escape (єдина відмінність, яка мене турбує, коли я працюю на лініях візуального блоку).
a3nm

8

Мій сильно коментував vimrc, з readline-esque (emacs) клавіатурними вкладками:

if version >= 700

"------ Meta ------"

" clear all autocommands! (this comment must be on its own line)
autocmd!

set nocompatible                " break away from old vi compatibility
set fileformats=unix,dos,mac    " support all three newline formats
set viminfo=                    " don't use or save viminfo files

"------ Console UI & Text display ------"

set cmdheight=1                 " explicitly set the height of the command line
set showcmd                     " Show (partial) command in status line.
set number                      " yay line numbers
set ruler                       " show current position at bottom
set noerrorbells                " don't whine
set visualbell t_vb=            " and don't make faces
set lazyredraw                  " don't redraw while in macros
set scrolloff=5                 " keep at least 5 lines around the cursor
set wrap                        " soft wrap long lines
set list                        " show invisible characters
set listchars=tab:>·,trail:·    " but only show tabs and trailing whitespace
set report=0                    " report back on all changes
set shortmess=atI               " shorten messages and don't show intro
set wildmenu                    " turn on wild menu :e <Tab>
set wildmode=list:longest       " set wildmenu to list choice
if has('syntax')
    syntax on
    " Remember that rxvt-unicode has 88 colors by default; enable this only if
    " you are using the 256-color patch
    if &term == 'rxvt-unicode'
        set t_Co=256
    endif

    if &t_Co == 256
        colorscheme xoria256
    else
        colorscheme peachpuff
    endif
endif

"------ Text editing and searching behavior ------"

set nohlsearch                  " turn off highlighting for searched expressions
set incsearch                   " highlight as we search however
set matchtime=5                 " blink matching chars for .x seconds
set mouse=a                     " try to use a mouse in the console (wimp!)
set ignorecase                  " set case insensitivity
set smartcase                   " unless there's a capital letter
set completeopt=menu,longest,preview " more autocomplete <Ctrl>-P options
set nostartofline               " leave my cursor position alone!
set backspace=2                 " equiv to :set backspace=indent,eol,start
set textwidth=80                " we like 80 columns
set showmatch                   " show matching brackets
set formatoptions=tcrql         " t - autowrap to textwidth
                                " c - autowrap comments to textwidth
                                " r - autoinsert comment leader with <Enter>
                                " q - allow formatting of comments with :gq
                                " l - don't format already long lines

"------ Indents and tabs ------"

set autoindent                  " set the cursor at same indent as line above
set smartindent                 " try to be smart about indenting (C-style)
set expandtab                   " expand <Tab>s with spaces; death to tabs!
set shiftwidth=4                " spaces for each step of (auto)indent
set softtabstop=4               " set virtual tab stop (compat for 8-wide tabs)
set tabstop=8                   " for proper display of files with tabs
set shiftround                  " always round indents to multiple of shiftwidth
set copyindent                  " use existing indents for new indents
set preserveindent              " save as much indent structure as possible
filetype plugin indent on       " load filetype plugins and indent settings

"------ Key bindings ------"

" Remap broken meta-keys that send ^[
for n in range(97,122) " ASCII a-z
    let c = nr2char(n)
    exec "set <M-". c .">=\e". c
    exec "map  \e". c ." <M-". c .">"
    exec "map! \e". c ." <M-". c .">"
endfor

""" Emacs keybindings
" first move the window command because we'll be taking it over
noremap <C-x> <C-w>
" Movement left/right
noremap! <C-b> <Left>
noremap! <C-f> <Right>
" word left/right
noremap  <M-b> b
noremap! <M-b> <C-o>b
noremap  <M-f> w
noremap! <M-f> <C-o>w
" line start/end
noremap  <C-a> ^
noremap! <C-a> <Esc>I
noremap  <C-e> $
noremap! <C-e> <Esc>A
" Rubout word / line and enter insert mode
noremap  <C-w> i<C-w>
noremap  <C-u> i<C-u>
" Forward delete char / word / line and enter insert mode
noremap! <C-d> <C-o>x
noremap  <M-d> dw
noremap! <M-d> <C-o>dw
noremap  <C-k> Da
noremap! <C-k> <C-o>D
" Undo / Redo and enter normal mode
noremap  <C-_> u
noremap! <C-_> <C-o>u<Esc><Right>
noremap! <C-r> <C-o><C-r><Esc>

" Remap <C-space> to word completion
noremap! <Nul> <C-n>

" OS X paste (pretty poor implementation)
if has('mac')
    noremap  √ :r!pbpaste<CR>
    noremap! √ <Esc>√
endif

""" screen.vim REPL: http://github.com/ervandew/vimfiles
" send paragraph to parallel process
vmap <C-c><C-c> :ScreenSend<CR>
nmap <C-c><C-c> mCvip<C-c><C-c>`C
imap <C-c><C-c> <Esc><C-c><C-c><Right>
" set shell region height
let g:ScreenShellHeight = 12


"------ Filetypes ------"

" Vimscript
autocmd FileType vim setlocal expandtab shiftwidth=4 tabstop=8 softtabstop=4

" Shell
autocmd FileType sh setlocal expandtab shiftwidth=4 tabstop=8 softtabstop=4

" Lisp
autocmd Filetype lisp,scheme setlocal equalprg=~/.vim/bin/lispindent.lisp expandtab shiftwidth=2 tabstop=8 softtabstop=2

" Ruby
autocmd FileType ruby setlocal expandtab shiftwidth=2 tabstop=2 softtabstop=2

" PHP
autocmd FileType php setlocal expandtab shiftwidth=4 tabstop=4 softtabstop=4

" X?HTML & XML
autocmd FileType html,xhtml,xml setlocal expandtab shiftwidth=2 tabstop=2 softtabstop=2

" CSS
autocmd FileType css setlocal expandtab shiftwidth=4 tabstop=4 softtabstop=4

" JavaScript
" autocmd BufRead,BufNewFile *.json setfiletype javascript
autocmd FileType javascript setlocal expandtab shiftwidth=2 tabstop=2 softtabstop=2
let javascript_enable_domhtmlcss=1

"------ END VIM-500 ------"

endif " version >= 500

fyi, 'smartindent' є застарілим (його замінює cindent) і нічого не робить, коли ви використовуєте відступ файлу файлів, і буде активним лише тоді, коли це не корисно
greyh

7
syntax on
set cindent
set ts=4
set sw=4
set backspace=2
set laststatus=2
set nohlsearch
set modeline
set modelines=3
set ai
map Q gq

set vb t_vb=

set nowrap
set ss=5
set is
set scs
set ru

map <F2> <Esc>:w<CR>
map! <F2> <Esc>:w<CR>

map <F10> <Esc>:qa<CR>
map! <F10> <Esc>:qa<CR>

map <F9>  <Esc>:wqa<CR>
map! <F9>  <Esc>:wqa<CR>

inoremap <s-up> <Esc><c-w>W<Ins>
inoremap <s-down> <Esc><c-w>w<Ins>

nnoremap <s-up> <c-w>W
nnoremap <s-down> <c-w>w

" Fancy middle-line <CR>
inoremap <C-CR> <Esc>o
nnoremap <C-CR> o

" This is the way I like my quotation marks and various braces
inoremap '' ''<Left>
inoremap "" ""<Left>
inoremap () ()<Left>
inoremap <> <><Left>
inoremap {} {}<Left>
inoremap [] []<Left>
inoremap () ()<Left>

" Quickly set comma or semicolon at the end of the string
inoremap ,, <End>,
inoremap ;; <End>;
au FileType python inoremap :: <End>:


au FileType perl,python set foldlevel=0
au FileType perl,python set foldcolumn=4
au FileType perl,python set fen
au FileType perl        set fdm=syntax
au FileType python      set fdm=indent
au FileType perl,python set fdn=4
au FileType perl,python set fml=10
au FileType perl,python set fdo=block,hor,mark,percent,quickfix,search,tag,undo,search

au FileType perl,python abbr sefl self
au FileType perl abbr sjoft shift
au FileType perl abbr DUmper Dumper

function! ToggleNumberRow()
       if !exists("g:NumberRow") || 0 == g:NumberRow
               let g:NumberRow = 1
               call ReverseNumberRow()
       else
               let g:NumberRow = 0
               call NormalizeNumberRow()
       endif
endfunction


" Reverse the number row characters
function! ReverseNumberRow()
       " map each number to its shift-key character
       inoremap 1 !
       inoremap 2 @
       inoremap 3 #
       inoremap 4 $
       inoremap 5 %
       inoremap 6 ^
       inoremap 7 &
       inoremap 8 *
       inoremap 9 (
       inoremap 0 )
       inoremap - _
    inoremap 90 ()<Left>
       " and then the opposite
       inoremap ! 1
       inoremap @ 2
       inoremap # 3
       inoremap $ 4
       inoremap % 5
       inoremap ^ 6
       inoremap & 7
       inoremap * 8
       inoremap ( 9
       inoremap ) 0
       inoremap _ -
endfunction

" DO the opposite to ReverseNumberRow -- give everything back
function! NormalizeNumberRow()
       iunmap 1
       iunmap 2
       iunmap 3
       iunmap 4
       iunmap 5
       iunmap 6
       iunmap 7
       iunmap 8
       iunmap 9
       iunmap 0
       iunmap -
       "------
       iunmap !
       iunmap @
       iunmap #
       iunmap $
       iunmap %
       iunmap ^
       iunmap &
       iunmap *
       iunmap (
       iunmap )
       iunmap _
       inoremap () ()<Left>
endfunction

"call ToggleNumberRow()
nnoremap <M-n> :call ToggleNumberRow()<CR>

" Add use <CWORD> at the top of the file
function! UseWord(word)
       let spec_cases = {'Dumper': 'Data::Dumper'}
       let my_word = a:word
       if has_key(spec_cases, my_word)
               let my_word = spec_cases[my_word]
       endif

       let was_used = search("^use.*" . my_word, "bw")

       if was_used > 0
               echo "Used already"
               return 0
       endif

       let last_use = search("^use", "bW")
       if 0 == last_use
               last_use = search("^package", "bW")
               if 0 == last_use
                       last_use = 1
               endif
       endif

       let use_string = "use " . my_word . ";"
       let res = append(last_use, use_string)
       return 1
endfunction

function! UseCWord()
       let cline = line(".")
       let ccol = col(".")
       let ch = UseWord(expand("<cword>"))
       normal mu
       call cursor(cline + ch, ccol)

endfunction

function! GetWords(pattern)
       let cline = line(".")
       let ccol = col(".")
       call cursor(1,1)

       let temp_dict = {}
       let cpos = searchpos(a:pattern)
       while cpos[0] != 0
               let temp_dict[expand("<cword>")] = 1
               let cpos = searchpos(a:pattern, 'W')
       endwhile

       call cursor(cline, ccol)
       return keys(temp_dict)
endfunction

" Append the list of words, that match the pattern after cursor
function! AppendWordsLike(pattern)
       let word_list = sort(GetWords(a:pattern))
       call append(line("."), word_list)
endfunction


nnoremap <F7>  :call UseCWord()<CR>

" Useful to mark some code lines as debug statements
function! MarkDebug()
       let cline = line(".")
       let ctext = getline(cline)
       call setline(cline, ctext . "##_DEBUG_")
endfunction

" Easily remove debug statements
function! RemoveDebug()
       %g/#_DEBUG_/d
endfunction

au FileType perl,python inoremap <M-d> <Esc>:call MarkDebug()<CR><Ins>
au FileType perl,python inoremap <F6> <Esc>:call RemoveDebug()<CR><Ins>
au FileType perl,python nnoremap <F6> :call RemoveDebug()<CR>

" end Perl settings

nnoremap <silent> <F8> :TlistToggle<CR>
inoremap <silent> <F8> <Esc>:TlistToggle<CR><Esc>

function! AlwaysCD()
       if bufname("") !~ "^scp://" && bufname("") !~ "^sftp://" && bufname("") !~ "^ftp://"
               lcd %:p:h
       endif
endfunction
autocmd BufEnter * call AlwaysCD()

function! DeleteRedundantSpaces()
       let cline = line(".")
       let ccol = col(".")
       silent! %s/\s\+$//g
       call cursor(cline, ccol)
endfunction
au BufWrite * call DeleteRedundantSpaces()

set nobackup
set nowritebackup
set cul

colorscheme evening

autocmd FileType python set formatoptions=wcrq2l
autocmd FileType python set inc="^\s*from"
autocmd FileType python so /usr/share/vim/vim72/indent/python.vim

autocmd FileType c      set si
autocmd FileType mail   set noai
autocmd FileType mail   set ts=3
autocmd FileType mail   set tw=78
autocmd FileType mail   set shiftwidth=3
autocmd FileType mail   set expandtab
autocmd FileType xslt   set ts=4
autocmd FileType xslt   set shiftwidth=4
autocmd FileType txt    set ts=3
autocmd FileType txt    set tw=78
autocmd FileType txt    set expandtab

" Move cursor together with the screen
noremap <c-j> j<c-e>
noremap <c-k> k<c-y>

" Better Marks
nnoremap ' `

6

Деякі виправлення типових помилок врятували мене дивно:

:command WQ wq
:command Wq wq
:command W w
:command Q q

iab anf and
iab adn and
iab ans and
iab teh the
iab thre there

25
Мені це не подобається - він просто тренує помилки.
Svante

Мені це подобається за слова: і, то, там, але не для збереження та виходу
шістдесят футів

3
@Svante, як правило, я погодився б, за винятком того, що я також маю це в своїй команді, я прагну часто економити або часто зберігати / кидати. Часто мій пінк - це лише частина секунди, що надто повільно знімає клавішу зсуву, і БАМ той чи інший в кінці закінчується великим капіталом, це дратує!
Фараун

1
vi написано на і для терміналу ADM3A, який мав призначений ключ для двокрапки (:), тому вам не потрібно було натискати shift. Якщо ви перезаписуєте ключ, який зазвичай не використовується в звичайному / візуальному режимі, як, наприклад, пробіл, ви не будете сильно стикатися з цією проблемою. nnoremap <Space>: і vnomap <Space>: en.wikipedia.org/wiki/File:KB_Terminal_ADM3A.svg
aoeu

Мені це подобається за команди save / quit, але не для слів. Якщо ви зробите помилку, коли запобіжної мережі немає, Vim скаже вам свою помилку. Якщо ви пишете як "teh", коли автокорекції немає, ви не помітите, і ви будете виглядати неосвіченими.
Роберт Мартін

5

Я не усвідомлював, скільки моїх 3200 ліній .vimrc були саме для моїх вигадливих потреб, і було б досить не натхненно перераховувати тут. Але, можливо, саме тому Vim такий корисний ...

iab AlP ABCDEFGHIJKLMNOPQRSTUVWXYZ
iab MoN January February March April May June July August September October November December
iab MoO Jan Feb Mar Apr May Jun Jul Aug Sep Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec
iab NuM 12345678901234567890123456789012345678901234567890123456789012345678901234567890 
iab RuL ----+----1----+----2----+----3----+----4----+----5----+----6----+----7----+----8----+----9----+----0

" Highlight every other line
map ,<Tab> :set hls<CR>/\\n.*\\n/<CR>

" This is for working across multiple xterms and/or gvims
" Transfer/read and write one block of text between vim sessions (capture whole line):
" Write
nmap ;w :. w! ~/.vimxfer<CR>
" Read
nmap ;r :r ~/.vimxfer<CR>
" Append 
nmap ;a :. w! >>~/.vimxfer<CR>

5

Мій 242-й рядок .vimrcне такий цікавий, але оскільки ніхто про це не згадував, я відчував, що я повинен поділитися двома найважливішими відображеннями, які покращили мій робочий процес окрім відображень за замовчуванням:

map <C-j> :bprev<CR>
map <C-k> :bnext<CR>
set hidden " this will go along

Серйозно, перемикання буферів - це справа, яку потрібно робити дуже часто. Windows, звичайно, але все не так добре підходить до екрану.

Аналогічний набір карт для швидкого перегляду помилок (див. Швидке виправлення) та результатів grep:

map <C-n> :cn<CR>
map <C-m> :cp<CR>

Простий, легкий і ефективний.


Я не дуже перемикався між буферами, оскільки Vim отримав підтримку вкладок. У мене на клавіатурі додаткові клавіші "назад" і "вперед" відображені на навігаційних командах вкладки.
Дон Реба

@Don Reba, ви знаєте, вкладки просто копіюють деякі функції буферів. Тож немає великої різниці в тому, щоб "використовувати" ні буфери, ні вкладки. Пуристи говорять, що вкладки призначені для організації завдань, щоб розділити регіони і більше нічого. Все, що я говорю, - це те, що буфери мають усі зручності, і що я залишив користуватися вкладками, резервуючи їх на щось інше, якщо знадобиться щось більш високе абстрагування. :)
nperson325681

4

set nobackup 
set nocp
set tabstop=4
set shiftwidth=4
set et
set ignorecase

set ai
set ruler
set showcmd
set incsearch
set dir=$temp       " Make swap live in the %TEMP% directory
syn on

" Load the color scheme
colo inkpot

4

Я використовую cscope зсередини vim (велике використання декількох буферів). Я використовую control-K, щоб ініціювати більшість команд (вкрадені з ctags, наскільки я пам'ятаю). Також я вже створив файл .cscope.out.

якщо має ("cscope")

set cscopeprg=/usr/local/bin/cscope
set cscopetagorder=0
set cscopetag
set cscopepathcomp=3
set nocscopeverbose
cs add .cscope.out
set csverb

"
" cscope find
"
" 0 or s: Find this C symbol
" 1 or d: Find this definition
" 2 or g: Find functions called by this function
" 3 or c: Find functions calling this function
" 4 or t: Find assignments to
" 6 or e: Find this egrep pattern
" 7 or f: Find this file
" 8 or i: Find files #including this file
" 
map ^Ks     :cs find 0 <C-R>=expand("<cword>")<CR><CR>
map ^Kd     :cs find 1 <C-R>=expand("<cword>")<CR><CR>
map ^Kg     :cs find 2 <C-R>=expand("<cword>")<CR><CR>
map ^Kc     :cs find 3 <C-R>=expand("<cword>")<CR><CR>
map ^Kt     :cs find 4 <C-R>=expand("<cword>")<CR><CR>
map ^Ke     :cs find 6 <C-R>=expand("<cword>")<CR><CR>
map ^Kf     :cs find 7 <C-R>=expand("<cfile>")<CR><CR>
map ^Ki     :cs find 8 <C-R>=expand("%")<CR><CR>

закінчення



3

Я перебуваю на OS X, тому деякі з них можуть мати кращі налаштування за замовчуванням на інших платформах, але незалежно:

syntax on
set tabstop=4
set expandtab
set shiftwidth=4

1
Можливо, ви захочете шукати softtabstopі використовувати це замість цього tabstop. Залишити tabstopзначення за замовчуванням 8 допоможе при читанні файлів, створених іншими за допомогою вкладок.
Грег Х'югілл

6
Що стосується OSX з вкладками?
aehlke

3
map = }{!}fmt^M}
map + }{!}fmt -p '> '^M}
set showmatch

= призначено для переформатування звичайних абзаців. + призначений для переформатування абзаців у цитованих електронних листах. showmatch призначений для миготіння відповідних дужок / дужок, коли я набираю близькі дужки або дужки.


3

Використовуйте перший доступний файл "тегів" у дереві каталогів:

:set tags=tags;/

Ліворуч і праворуч - для перемикання буферів, а не переміщення курсору:

map <right> <ESC>:bn<RETURN>
map <left> <ESC>:bp<RETURN>

Вимкнення підсвічування пошуку одним натисканням клавіші:

map - :nohls<cr>

3
set tabstop=4 softtabstop=4 shiftwidth=4 expandtab autoindent cindent 
set encoding=utf-8 fileencoding=utf-8
set nobackup nowritebackup noswapfile autoread
set number
set hlsearch incsearch ignorecase smartcase

if has("gui_running")
    set lines=35 columns=140
    colorscheme ir_black
else
    colorscheme darkblue
endif

" bash like auto-completion
set wildmenu
set wildmode=list:longest

inoremap <C-j> <Esc>

" for lusty explorer
noremap glr \lr
noremap glf \lf
noremap glb \lb

" use ctrl-h/j/k/l to switch between splits
map <c-j> <c-w>j
map <c-k> <c-w>k
map <c-l> <c-w>l
map <c-h> <c-w>h

" Nerd tree stuff
let NERDTreeIgnore = ['\.pyc$', '\.pyo$']
noremap gn :NERDTree<Cr>

" cd to the current file's directory
noremap gc :lcd %:h<Cr>

Мені подобається дуже багато того, що відбувається у вашій конфігурації. Кілька наборів на рядок if has("gui_running"), і круті карти. Я скопіював більшу частину вашого конфігурації в мою. ДЯКУЮ!
Джастін Форс

3

Помістіть це у свій vimrc:

imap <C-l> <Space>=><Space>

і ніколи більше не замислюйтеся над тим, щоб набрати знову хеш-ракет. Так, я знаю, що вам не потрібно в Ruby 1.9. Але не заважайте цьому.

Мій повний vimrc тут .


Це відмінна ідея, але я б запропонував лише autocmd FileType ruby imap <C-l> <Space>=><Space>
зіставити

Чи можете ви пояснити, що це робить для людини Emacs, яка не знає Рубі?
Томас

Це додає гарячу клавішу Control-L у режим вставки Vim, щоб автоматично ввести хеш-ракетку з пробілами (=>). Хешрокет - це ключовий оператор Ruby для хешей.
dpogg1

2

Ну, вам доведеться самостійно очищати мої конфігурації . Весело. Здебільшого це лише бажане налаштування, включаючи відображення та речі, пов'язані з випадковим синтаксисом, а також налаштування складок та деяку конфігурацію плагінів, аналізатор текстової компіляції тощо.

До речі, щось, що мені здалося надзвичайно корисним, - це "виділити слово під курсором":

 highlight flicker cterm=bold ctermfg=white
 au CursorMoved <buffer> exe 'match flicker /\V\<'.escape(expand('<cword>'), '/').'\>/'

Зауважте, що тільки ctermі termfgвикористовуються, тому що я не використовую gvim. Якщо ви хочете, щоб це працювало, gvimпросто замініть їх відповідно guiі guifg, відповідно.


Як змусити його працювати з відкритими кількома вікнами? Здається, працює лише з головним, запущеним як перший буфером.
оні

2

Я намагався зберегти свій .vimrc якомога кориснішим.

Зручним трюком є ​​обробник файлів .gpg для їх безпечного редагування:

au BufNewFile,BufReadPre *.gpg :set secure vimi= noswap noback nowriteback hist=0 binary
au BufReadPost *.gpg :%!gpg -d 2>/dev/null
au BufWritePre *.gpg :%!gpg -e -r 'name@email.com' 2>/dev/null
au BufWritePost *.gpg u

2

1) Мені подобається рядок стану (із назвою файлу, значенням ascii (десяткове), шістнадцятковим значенням та стандартними рядками, знаками та%):

set statusline=%t%h%m%r%=[%b\ 0x%02B]\ \ \ %l,%c%V\ %P
" Always show a status line
set laststatus=2
"make the command line 1 line high
set cmdheight=1

2) Мені також подобаються карти для розділених вікон.

" <space> switches to the next window (give it a second)
" <space>n switches to the next window
" <space><space> switches to the next window and maximizes it
" <space>= Equalizes the size of all windows
" + Increases the size of the current window
" - Decreases the size of the current window

 :map <space> <c-W>w
:map <space>n <c-W>w
:map <space><space> <c-W>w<c-W>_
:map <space>= <c-W>=
if bufwinnr(1)
  map + <c-W>+
  map - <c-W>-
endif

2

Насправді в моєму .vimrc (навіть якщо він має 850 рядків) не так вже й багато. Переважно налаштування та кілька поширених і простих відображень, які мені було лінь витягувати у плагіни.

Якщо ви маєте на увазі "шаблонні файли" під " автокласами ", я використовую плагін-розширювач шаблонів - на цьому ж веб-сайті ви знайдете ftplugins, який я визначив для редагування на C & C ++, деякі з них можуть бути адаптовані до C # я здогадуюсь.

Що стосується аспекту рефакторингу, на http://vim.wikia.com є порада, присвячена цій темі ; IIRC, приклад коду призначений для C #. Мене це надихнуло на плагін для рефакторингу, який ще потребує великої роботи (його потрібно переробити фактично).

Ви повинні ознайомитись з архівами розсилки vim-списку, особливо з теми про використання vim як ефективного IDE. Не забудьте ознайомитись: make, теги, ...

HTH,


2

Мій .vimrc включає (серед інших, більш корисних речей) наступний рядок:

set statusline=%2*%n\|%<%*%-.40F%2*\|\ %2*%M\ %3*%=%1*\ %1*%2.6l%2*x%1*%1.9(%c%V%)%2*[%1*%P%2*]%1*%2B

Мені нудно було під час навчання для фіналу середньої школи.


чи можете ви поясніть, що це робить?
Vijay Dev

Він показує рядок стану з номером буфера, ім'ям файлу, статусом модифікації, положенням у буфері та шістнадцятковим кодом символу під курсором. Приємно відформатований і кольоровий.
Тадеуш А. Кадлубовський

1

Ось мій .vimrc. Я використовую Gvim 7.2

set guioptions=em
set showtabline=2
set softtabstop=2
set shiftwidth=2
set tabstop=2

" Use spaces instead of tabs
set expandtab
set autoindent

" Colors and fonts
colorscheme inkpot
set guifont=Consolas:h11:cANSI

"TAB navigation like firefox
:nmap <C-S-tab> :tabprevious<cr>
:nmap <C-tab> :tabnext<cr>
:imap <C-S-tab> <ESC>:tabprevious<cr>i
:imap <C-tab> <ESC>:tabnext<cr>i
:nmap <C-t> :tabnew<cr>
:imap <C-t> <ESC>:tabnew<cr>i
:map <C-w> :tabclose<cr>

" No Backups and line numbers
set nobackup
set number
set nuw=6

" swp files are saved to %Temp% folder
set dir=$temp
" sets the default size of gvim on open
set lines=40 columns=90

1

Що в моєму .vimrc?

ngn@macavity:~$ cat .vimrc
" This file intentionally left blank

Реальні файли конфігурації лежать в ~/.vim/ :)

І більшість матеріалів там паразитують на зусиллях інших людей, явно адаптовані з vim.orgмоєї переваги редагування.


2
У мене це майже є, але .vimrc повинен містити "встановити несумісний", якщо ви використовуєте ці функції, чи не так? Принаймні його видалення викликає тут безліч помилок!
richq
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.