" Load the doxygen syntax
let b:load_doxygen_syntax = 1
-augroup fswitch
- au BufEnter *.h let b:fswitchdst = 'cpp,c'
- au BufEnter *.h let b:fswitchlocs = 'reg:|include.*|source|'
- au BufEnter *.cpp let b:fswitchdst = 'h'
- au BufEnter *.cpp let b:fswitchlocs = 'reg:|source|include/**|'
+augroup fswitch_cpp
+ au!
+ au BufEnter *.h let b:fswitchdst = 'c,cpp'
+ au BufEnter *.h let b:fswitchlocs = '.,reg:|include.*|src|'
+ au BufEnter *.hpp let b:fswitchdst = 'cpp,c'
+ au BufEnter *.hpp let b:fswitchlocs = '.,reg:|include.*|src|'
+ au BufEnter *.cpp let b:fswitchdst = 'hpp,h'
+ au BufEnter *.cpp let b:fswitchlocs = '.,reg:|src|include/**|'
augroup END
+let g:switch_custom_definitions =
+ \ [
+ \ ['EXPECT_FALSE', 'EXPECT_TRUE'],
+ \ ['EXPECT_EQ', 'EXPECT_NE'],
+ \ ['EXPECT_LT', 'EXPECT_GT'],
+ \ ['ASSERT_FALSE', 'ASSERT_TRUE'],
+ \ ['ASSERT_EQ', 'ASSERT_NE'],
+ \ ['ASSERT_LT', 'ASSERT_GT']
+ \ ]
+
+let g:switch_const_definitions =
+ \ [ {
+ \ '\%(const \)\@!\([[:alnum:]_:<>]\{-}\) \%(&\)\@!': 'const \1 ',
+ \ 'const \([[:alnum:]_:<>]\{-}\) &\@!': 'const \1 &' ,
+ \ 'const \([[:alnum:]_:<>]\{-}\) &': '\1 '
+ \ } ]
+
+nnoremap <buffer> <leader>c :call switch#Switch(g:switch_const_definitions, {})<cr>
+
nnoremap <buffer> gd :YcmCompleter GoTo<CR>
nnoremap <buffer> <C-W>d :vs<CR>:YcmCompleter GoTo<CR>
setlocal errorformat+=%*[^[]\[%tRROR\]%m\ \[%f:%l\]
setlocal errorformat+=%*[^[]\[%tARNING\]%m\ \[%f:%l\]
+packadd termdebug
+let g:termdebug_wide = 1
+function! s:Debug(...)
+ tabedit %
+ let t:debug_tab=1
+ au BufDelete !gdb ++once if exists('t:debug_tab') | tabclose | endif
+endfunction
+command! -nargs=* -complete=file -bang Debug call <SID>Debug() | Termdebug<bang> <args>
+command! -nargs=+ -complete=file -bang DebugCommand call <SID>Debug() | TermdebugCommand<bang> <args>
+
setlocal foldmethod=syntax
" set foldlevel according to number of matches of 'namespace' and 'class' not
" containing ';'