Vim/Neovim Ile Go Geliştirme Ortamı
Bu yazıda VIM ile Go programlama dili için gerekli kurulumları nasıl yaparız onu anlatacağım.
Vim
Vim Vi Improved anlamına gelir. UNIX ile hayatımıza giren Vi editörünün gelişmiş halidir. Daha detaylı bilgi için aşağıdaki linklere bakabilirsiniz
Neovim
Neovim bir Vim forkudur. Çoğu vim eklentisi ile uyumludur. Daha detaylı bilgi için aşağıdaki linklere bakabilirsiniz.
neovim resmi sitesi
neovim github
Neovim Kurulumu
macOS / OS X
curl -LO https://github.com/neovim/neovim/releases/download/nightly/nvim-macos.tar.gz
tar xzf nvim-macos.tar.gz
./nvim-osx64/bin/nvim
brew install neovim
sudo port selfupdate
Linux
Arch Linux
sudo pacman -S neovim
Python modülleri için
sudo pacman -S python-pynvim
sudo apt-get install neovim
Python modülleri için
sudo apt-get install python-neovim
sudo apt-get install python3-neovim
Fedora
sudo dnf install -y neovim python3-neovim
emerge -a app-editors/neovim
Eklenti Yöneticisi
Ben eklenti yöneticisi olarak vim-plug kullanıyorum. Tercihinize göre bir plugin yöneticisi kullanabilirsiniz. Alternatif eklenti yöneticileri;
Sisteminize vim-plug yüklemek için aşağıdaki komutu çalıştırabilirsiniz
VIM
Unix
curl -fLo ~/.vim/autoload/plug.vim --create-dirs \
https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
Windows (Power Shell)
md ~\vimfiles\autoload
$uri = 'https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim'
(New-Object Net.WebClient).DownloadFile(
$uri,
$ExecutionContext.SessionState.Path.GetUnresolvedProviderPathFromPSPath(
"~\vimfiles\autoload\plug.vim"
)
)
Neovim
Unix
curl -fLo ~/.local/share/nvim/site/autoload/plug.vim --create-dirs \
https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim
Windows (Power Shell)
md ~\AppData\Local\nvim\autoload
$uri = 'https://raw.githubusercontent.com/junegunn/vim-plug/master/plug.vim'
(New-Object Net.WebClient).DownloadFile(
$uri,
$ExecutionContext.SessionState.Path.GetUnresolvedProviderPathFromPSPath(
"~\AppData\Local\nvim\autoload\plug.vim"
)
)
Daha deteylı bilgi için vim-plug
Pluhing yöneticimizi kurduğumuza göre artık ekletileri kurmaya başlayabiliriz.
Öncelikle kuracağımız eklentilerden kısaca bahsedelim
- vim-go adından da anlaşılacağı gibi Vim/Neovim için Go eklentisi
- coc-vim VIM/Neovim için intellisense aracı
- NerdTree VIM içinde çalışan bir dosya gezgini (opsiyonel)
- vim-airline VIM için kullanışlı bir status bar (opsiyonel)
- vim-airline-themes Airline status bar için temalar (opsiyonel)
- PaparCololor Theme Vim/Neovim için PaperColor teması (opsiyonel)
Ayarlar
Vim ayarları için kullanacağı dosyayı home dizini altında .vimrc dosyasında tutar Neovim ise home dizini altında .config/nvim/init.vim dosyasında tutar
Vim kullanıyorsanız
~/.vimrc
Neovim kullanıyorsanız
~/.config/nvim/init.vim
dosyasını açın ve aşağıdaki satırları ekleyin
call plug#begin('~/.vim/plugged')
Plug 'fatih/vim-go'
Plug 'neoclide/coc.nvim', {'branch': 'release'}
Plug 'preservim/nerdtree'
Plug 'vim-airline/vim-airline'
Plug 'vim-airline/vim-airline-themes'
Plug 'NLKNguyen/papercolor-theme'
call plug#end()
dosyayı kaydedeyip VIM/Neovim’den çıkmadan :PlugInstall komutu ile eklentilerimizi kuralım
Eklentilerimi kurduk. Şimdi sırada kurmuş olduğumuz eklentilerin ayarlarını yapalım
:GoInstallBinaries komutunu ile vim-go eklentisinin ihtiyaç duyduğu binarylerin kurulmasını sağlayalım
coc eklentisinin doğru bir şekilde kurulup kurulmadığını anlamak için :CocInfo komutunu çalıştırabiliriz.
Eklentinin go ile uyumlu şekilde çalışabilmesi için language server ayarlarını yapmamız lazım. Bunun için :CocConfig komutunu çalıştıralım ve açılan dosyaya aşağıdakileri yazıp kaydedelim
{
"languageserver": {
"golang": {
"command": "gopls",
"rootPatterns": ["go.mod", ".vim/", ".git/", ".hg/"],
"filetypes": ["go"]
}
}
}
Şimdi Vim/Neovim için bazı ayarlar ve kısayollar tanımlayalım
set number "Satır numaralarnı aktif eder
set cursorline "İmlecin olduğu satırı highlight eder
set splitright "Ekranı yatay olarak bölmek issues yeni eklentilerin sağda açar
set splitbelow "Ekranı dikey olarak bölmek istediğimizde yeni ekranı aşağıda açar
set background=dark "Koyu tema kullanmak istediğimizi belirtir
colorscheme PaperColor "Temayı PaparCololor olarak tanımlar
let g:go_def_mapping_enabled = 0
map <C-n> :NERDTreeToggle<CR> "Ctrl + n kombinasyonu ile NerdTree penceresini açar
let g:NERDTreeDirArrowExpandable = '▸'
let g:NERDTreeDirArrowCollapsible = '▾'
"Aşağıdaki satırlar Vim/Neovim için yön tuşlarını devre dışı bırakır
noremap <Up> <Nop>
noremap <Down> <Nop>
noremap <Left> <Nop>
noremap <Right> <Nop>
inoremap <UP> <Nop>
inoremap <Down> <Nop>
inoremap <Left> <Nop>
inoremap <Right> <Nop>
"--------------------- COC için github sayfasında önerilen ayarlar ---------------------------
" if hidden is not set, TextEdit might fail.
set hidden
" Some servers have issues with backup files, see #649
set nobackup
set nowritebackup
" Better display for messages
set cmdheight=2
" You will have bad experience for diagnostic messages when it's default 4000.
set updatetime=300
" don't give |ins-completion-menu| messages.
set shortmess+=c
" always show signcolumns
set signcolumn=yes
" Use tab for trigger completion with characters ahead and navigate.
" Use command ':verbose imap <tab>' to make sure tab is not mapped by other plugin.
inoremap <silent><expr> <TAB>
\ pumvisible() ? "\<C-n>" :
\ <SID>check_back_space() ? "\<TAB>" :
\ coc#refresh()
inoremap <expr><S-TAB> pumvisible() ? "\<C-p>" : "\<C-h>"
function! s:check_back_space() abort
let col = col('.') - 1
return !col || getline('.')[col - 1] =~# '\s'
endfunction
" Use <c-space> to trigger completion.
inoremap <silent><expr> <c-space> coc#refresh()
" Use <cr> to confirm completion, `<C-g>u` means break undo chain at current position.
" Coc only does snippet and additional edit on confirm.
inoremap <expr> <cr> pumvisible() ? "\<C-y>" : "\<C-g>u\<CR>"
" Or use `complete_info` if your vim support it, like:
" inoremap <expr> <cr> complete_info()["selected"] != "-1" ? "\<C-y>" : "\<C-g>u\<CR>"
" Use `[g` and `]g` to navigate diagnostics
nmap <silent> [g <Plug>(coc-diagnostic-prev)
nmap <silent> ]g <Plug>(coc-diagnostic-next)
" Remap keys for gotos
nmap <silent> gd <Plug>(coc-definition)
nmap <silent> gy <Plug>(coc-type-definition)
nmap <silent> gi <Plug>(coc-implementation)
nmap <silent> gr <Plug>(coc-references)
" Use K to show documentation in preview window
nnoremap <silent> K :call <SID>show_documentation()<CR>
function! s:show_documentation()
if (index(['vim','help'], &filetype) >= 0)
execute 'h '.expand('<cword>')
else
call CocAction('doHover')
endif
endfunction
" Highlight symbol under cursor on CursorHold
autocmd CursorHold * silent call CocActionAsync('highlight')
" Remap for rename current word
nmap <leader>rn <Plug>(coc-rename)
" Remap for format selected region
xmap <leader>f <Plug>(coc-format-selected)
nmap <leader>f <Plug>(coc-format-selected)
augroup mygroup
autocmd!
" Setup formatexpr specified filetype(s).
autocmd FileType typescript,json setl formatexpr=CocAction('formatSelected')
" Update signature help on jump placeholder
autocmd User CocJumpPlaceholder call CocActionAsync('showSignatureHelp')
augroup end
" Remap for do codeAction of selected region, ex: `<leader>aap` for current paragraph
xmap <leader>a <Plug>(coc-codeaction-selected)
nmap <leader>a <Plug>(coc-codeaction-selected)
" Remap for do codeAction of current line
nmap <leader>ac <Plug>(coc-codeaction)
" Fix autofix problem of current line
nmap <leader>qf <Plug>(coc-fix-current)
" Create mappings for function text object, requires document symbols feature of languageserver.
xmap if <Plug>(coc-funcobj-i)
xmap af <Plug>(coc-funcobj-a)
omap if <Plug>(coc-funcobj-i)
omap af <Plug>(coc-funcobj-a)
" Use <TAB> for select selections ranges, needs server support, like: coc-tsserver, coc-python
nmap <silent> <TAB> <Plug>(coc-range-select)
xmap <silent> <TAB> <Plug>(coc-range-select)
" Use `:Format` to format current buffer
command! -nargs=0 Format :call CocAction('format')
" Use `:Fold` to fold current buffer
command! -nargs=? Fold :call CocAction('fold', <f-args>)
" use `:OR` for organize import of current buffer
command! -nargs=0 OR :call CocAction('runCommand', 'editor.action.organizeImport')
" Add status line support, for integration with other plugin, checkout `:h coc-status`
set statusline^=%{coc#status()}%{get(b:,'coc_current_function','')}
" Using CocList
" Show all diagnostics
nnoremap <silent> <space>a :<C-u>CocList diagnostics<cr>
" Manage extensions
nnoremap <silent> <space>e :<C-u>CocList extensions<cr>
" Show commands
nnoremap <silent> <space>c :<C-u>CocList commands<cr>
" Find symbol of current document
nnoremap <silent> <space>o :<C-u>CocList outline<cr>
" Search workspace symbols
nnoremap <silent> <space>s :<C-u>CocList -I symbols<cr>
" Do default action for next item.
nnoremap <silent> <space>j :<C-u>CocNext<CR>
" Do default action for previous item.
nnoremap <silent> <space>k :<C-u>CocPrev<CR>
" Resume latest coc list
nnoremap <silent> <space>p :<C-u>CocListResume<CR>
Kurulum ve ayar işlemleri bu kadar. Artık Vim/Neovim ile Go dilinde geliştirme yapabilirsiniz.
Yazıyı basit tutmak adına kullandığım ayarların tamamını yazıya eklemedim. Kullandığım ayarların tamamı için ayarlarımı tuttuğum github reposuna bakabilirsiniz.