From d2fdfa8a6e9241612bd04c65a5668cb0c06324d7 Mon Sep 17 00:00:00 2001 From: Schark Date: Tue, 5 Dec 2023 21:25:48 -0800 Subject: Init dotfiles --- vim/vimrc | 194 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 194 insertions(+) create mode 100644 vim/vimrc (limited to 'vim') diff --git a/vim/vimrc b/vim/vimrc new file mode 100644 index 0000000..73fbc2a --- /dev/null +++ b/vim/vimrc @@ -0,0 +1,194 @@ +" ================== DEFAULT .VIMRC VALUES ===================== +" ========================================================================= + +" When started as "evim", evim.vim will already have done these settings. +if v:progname =~? "evim" + finish +endif + +" Bail out if something that ran earlier, e.g. a system wide vimrc, does not +" want Vim to use these default values. +if exists('skip_defaults_vim') + finish +endif + +" Use Vim settings, rather than Vi settings (much better!). +" This must be first, because it changes other options as a side effect. +" Avoid side effects when it was already reset. +if &compatible + set nocompatible +endif + +" When the +eval feature is missing, the set command above will be skipped. +" Use a trick to reset compatible only when the +eval feature is missing. +silent! while 0 + set nocompatible +silent! endwhile + +" Allow backspacing over everything in insert mode. +set backspace=indent,eol,start + +set history=200 " keep 200 lines of command line history +set ruler " show the cursor position all the time +set showcmd " display incomplete commands +set wildmenu " display completion matches in a status line + +set ttimeout " time out for key codes +set ttimeoutlen=100 " wait up to 100ms after Esc for special key + +" Show @@@ in the last line if it is truncated. +set display=truncate + +" Show a few lines of context around the cursor. Note that this makes the +" text scroll if you mouse-click near the start or end of the window. +set scrolloff=5 + +" Do incremental searching when it's possible to timeout. +if has('reltime') + set incsearch +endif + +" Do not recognize octal numbers for Ctrl-A and Ctrl-X, most users find it +" confusing. +set nrformats-=octal + +" REMOVED: No need for Win32GUI support +" For Win32 GUI: remove 't' flag from 'guioptions': no tearoff menu entries. +" if has('win32') +" set guioptions-=t +" endif + +" Don't use Q for Ex mode, use it for formatting. Except for Select mode. +" Revert with ":unmap Q". +map Q gq +sunmap Q + +" CTRL-U in insert mode deletes a lot. Use CTRL-G u to first break undo, +" so that you can undo CTRL-U after inserting a line break. +" Revert with ":iunmap ". +inoremap u + +" In many terminal emulators the mouse works just fine. By enabling it you +" can position the cursor, Visually select and scroll with the mouse. +" Only xterm can grab the mouse events when using the shift key, for other +" terminals use ":", select text and press Esc. +if has('mouse') + if &term =~ 'xterm' + set mouse=a + else + set mouse=nvi + endif +endif + +" Only do this part when Vim was compiled with the +eval feature. +if 1 + + " Enable file type detection. + " Use the default filetype settings, so that mail gets 'tw' set to 72, + " 'cindent' is on in C files, etc. + " Also load indent files, to automatically do language-dependent indenting. + " Revert with ":filetype off". + filetype plugin indent on + + " Put these in an autocmd group, so that you can revert them with: + " ":augroup vimStartup | exe 'au!' | augroup END" + augroup vimStartup + au! + + " When editing a file, always jump to the last known cursor position. + " Don't do it when the position is invalid, when inside an event handler + " (happens when dropping a file on gvim) and for a commit message (it's + " likely a different one than last time). + autocmd BufReadPost * + \ if line("'\"") >= 1 && line("'\"") <= line("$") && &ft !~# 'commit' + \ | exe "normal! g`\"" + \ | endif + + augroup END + + " Quite a few people accidentally type "q:" instead of ":q" and get confused + " by the command line window. Give a hint about how to get out. + " If you don't like this you can put this in your vimrc: + " ":augroup vimHints | exe 'au!' | augroup END" + augroup vimHints + au! + autocmd CmdwinEnter * + \ echohl Todo | + \ echo 'You discovered the command-line window! You can close it with ":q".' | + \ echohl None + augroup END + +endif + +" Switch syntax highlighting on when the terminal has colors or when using the +" GUI (which always has colors). +if &t_Co > 2 || has("gui_running") + " Revert with ":syntax off". + syntax on + + " I like highlighting strings inside C comments. + " Revert with ":unlet c_comment_strings". + let c_comment_strings=1 +endif + +" Convenient command to see the difference between the current buffer and the +" file it was loaded from, thus the changes you made. +" Only define it when not defined already. +" Revert with: ":delcommand DiffOrig". +if !exists(":DiffOrig") + command DiffOrig vert new | set bt=nofile | r ++edit # | 0d_ | diffthis + \ | wincmd p | diffthis +endif + +if has('langmap') && exists('+langremap') + " Prevent that the langmap option applies to characters that result from a + " mapping. If set (default), this may break plugins (but it's backward + " compatible). + set nolangremap +endif + +" ================================================================================== +" ====================== CUSTOM CONFIGURATIONS BELOW =========================== +" ================================================================================== + +" Indentation changes +set tabstop=4 +set softtabstop=4 +set shiftwidth=4 +set expandtab +set autoindent + +" Search highlights +set hlsearch +set incsearch + +" Toggles numbers on the side +set number + +" Splits window towards right +set splitbelow splitright + +" Change movement between windows +map h +map j +map k +map l + +" Change autocomplete " +map + +" Maps opening the :NERDTree plugin with Ctrl-T +nnoremap :NERDTree + +" Automatically open NERDTree upon open " +autocmd VimEnter * NERDTree | wincmd p + +" Automatically close NERDTree if it is the only window remaining " +autocmd BufEnter * if tabpagenr('$') == 1 && winnr('$') == 1 && exists('b:NERDTree') && b:NERDTree.isTabTree() | quit | endif + +" Show NERDTree on every tab " +autocmd BufWinEnter * if &buftype != 'quickfix' && getcmdwintype() == '' | silent NERDTreeMirror | endif + +" Show hidden files in NERDTree " +let NERDTreeShowHidden=1 + -- cgit v1.2.3-18-g5258