From 4e2ee5cc454ea39fcd93270a9d6dfcb9370f5406 Mon Sep 17 00:00:00 2001 From: Pierre Habouzit Date: Tue, 13 Nov 2012 16:55:24 +0100 Subject: [PATCH] Install pathogen, minor tweaks --- config/zsh/20_environment | 2 +- config/zsh/60_prompt | 2 +- ctags | 8 ++ gitconfig | 6 +- ssh/config | 3 + vim/autoload/pathogen.vim | 254 ++++++++++++++++++++++++++++++++++++++ vim/filetype.vim | 1 + vimrc | 16 ++- 8 files changed, 286 insertions(+), 6 deletions(-) create mode 100644 vim/autoload/pathogen.vim diff --git a/config/zsh/20_environment b/config/zsh/20_environment index bc2958a..30b6660 100644 --- a/config/zsh/20_environment +++ b/config/zsh/20_environment @@ -31,7 +31,7 @@ else *:${HOME}/local/bin:*) ;; *) - PATH="/usr/lib/ccache:${HOME}/local/bin:${HOME}/bin:${PATH}" + PATH="${HOME}/bin:/usr/local/bin:${PATH}" case $(uname) in Darwin) ;; diff --git a/config/zsh/60_prompt b/config/zsh/60_prompt index 5c7b02d..241075a 100644 --- a/config/zsh/60_prompt +++ b/config/zsh/60_prompt @@ -32,7 +32,7 @@ precmd() { branch="$(cut -c1-7 "$git_dir/HEAD")..." fi - psvar[1]="${$(readlink "$(git rev-parse --show-cdup)./")/$HOME/~}" + psvar[1]="${$(greadlink -m "$(git rev-parse --show-cdup)./")/$HOME/~}" psvar[2]="${branch#refs/heads/}" } diff --git a/ctags b/ctags index 535a880..855110c 100644 --- a/ctags +++ b/ctags @@ -2,3 +2,11 @@ -o.tags --excmd=pattern --c-kinds=cdefgmpstuvx +--langdef=objc +--langmap=objc:.m.h +--regex-objc=/^[[:space:]]*[-+][[:space:]]*\([[:alpha:]]+[[:space:]]*\*?\)[[:space:]]*([[:alnum:]]+):[[:space:]]*\(/\1/m,method/ +--regex-objc=/^[[:space:]]*[-+][[:space:]]*\([[:alpha:]]+[[:space:]]*\*?\)[[:space:]]*([[:alnum:]]+)[[:space:]]*\{/\1/m,method/ +--regex-objc=/^[[:space:]]*[-+][[:space:]]*\([[:alpha:]]+[[:space:]]*\*?\)[[:space:]]*([[:alnum:]]+)[[:space:]]*\;/\1/m,method/ +--regex-objc=/^[[:space:]]*\@property[[:space:]]+.*[[:space:]]+\*?(.*);$/\1/p,property/ +--regex-objc=/^[[:space:]]*\@implementation[[:space:]]+(.*)$/\1/c,class/ +--regex-objc=/^[[:space:]]*\@interface[[:space:]]+(.*)[[:space:]]+:.*{/\1/i,interface/ diff --git a/gitconfig b/gitconfig index 4914567..81fa0a7 100644 --- a/gitconfig +++ b/gitconfig @@ -27,7 +27,7 @@ [user] name = Pierre Habouzit - email = madcoder@debian.org + email = phabouzit@apple.com [color] ui = auto @@ -52,6 +52,7 @@ [merge] verbosity = 1 conflictstyle = diff3 + tool = opendiff [clean] requireForce = false [pack] @@ -80,6 +81,7 @@ [url "ssh://git.debian.org"] pushInsteadOf = git://git.debian.org pushInsteadOf = git.debian.org: - [branch "*"] mergeoptions = -Xpatience +[credential] + helper = osxkeychain diff --git a/ssh/config b/ssh/config index 8901416..a9da820 100644 --- a/ssh/config +++ b/ssh/config @@ -11,6 +11,9 @@ Host *.apple.com Host *.inria.fr User habouzit +Host iMad + HostName 17.77.254.59 + #--- madism --- Host hephaistos User root diff --git a/vim/autoload/pathogen.vim b/vim/autoload/pathogen.vim new file mode 100644 index 0000000..b5eb618 --- /dev/null +++ b/vim/autoload/pathogen.vim @@ -0,0 +1,254 @@ +" pathogen.vim - path option manipulation +" Maintainer: Tim Pope +" Version: 2.0 + +" Install in ~/.vim/autoload (or ~\vimfiles\autoload). +" +" For management of individually installed plugins in ~/.vim/bundle (or +" ~\vimfiles\bundle), adding `call pathogen#infect()` to your .vimrc +" prior to `filetype plugin indent on` is the only other setup necessary. +" +" The API is documented inline below. For maximum ease of reading, +" :set foldmethod=marker + +if exists("g:loaded_pathogen") || &cp + finish +endif +let g:loaded_pathogen = 1 + +" Point of entry for basic default usage. Give a directory name to invoke +" pathogen#runtime_append_all_bundles() (defaults to "bundle"), or a full path +" to invoke pathogen#runtime_prepend_subdirectories(). Afterwards, +" pathogen#cycle_filetype() is invoked. +function! pathogen#infect(...) abort " {{{1 + let source_path = a:0 ? a:1 : 'bundle' + if source_path =~# '[\\/]' + call pathogen#runtime_prepend_subdirectories(source_path) + else + call pathogen#runtime_append_all_bundles(source_path) + endif + call pathogen#cycle_filetype() +endfunction " }}}1 + +" Split a path into a list. +function! pathogen#split(path) abort " {{{1 + if type(a:path) == type([]) | return a:path | endif + let split = split(a:path,'\\\@"),'!isdirectory(v:val)')) && (!filereadable(dir.sep.'doc'.sep.'tags') || filewritable(dir.sep.'doc'.sep.'tags')) + helptags `=dir.'/doc'` + endif + endfor +endfunction " }}}1 + +command! -bar Helptags :call pathogen#helptags() + +" Like findfile(), but hardcoded to use the runtimepath. +function! pathogen#runtime_findfile(file,count) "{{{1 + let rtp = pathogen#join(1,pathogen#split(&rtp)) + let file = findfile(a:file,rtp,a:count) + if file ==# '' + return '' + else + return fnamemodify(file,':p') + endif +endfunction " }}}1 + +" Backport of fnameescape(). +function! pathogen#fnameescape(string) " {{{1 + if exists('*fnameescape') + return fnameescape(a:string) + elseif a:string ==# '-' + return '\-' + else + return substitute(escape(a:string," \t\n*?[{`$\\%#'\"|!<"),'^[+>]','\\&','') + endif +endfunction " }}}1 + +if exists(':Vedit') + finish +endif + +function! s:find(count,cmd,file,lcd) " {{{1 + let rtp = pathogen#join(1,pathogen#split(&runtimepath)) + let file = pathogen#runtime_findfile(a:file,a:count) + if file ==# '' + return "echoerr 'E345: Can''t find file \"".a:file."\" in runtimepath'" + elseif a:lcd + let path = file[0:-strlen(a:file)-2] + execute 'lcd `=path`' + return a:cmd.' '.pathogen#fnameescape(a:file) + else + return a:cmd.' '.pathogen#fnameescape(file) + endif +endfunction " }}}1 + +function! s:Findcomplete(A,L,P) " {{{1 + let sep = pathogen#separator() + let cheats = { + \'a': 'autoload', + \'d': 'doc', + \'f': 'ftplugin', + \'i': 'indent', + \'p': 'plugin', + \'s': 'syntax'} + if a:A =~# '^\w[\\/]' && has_key(cheats,a:A[0]) + let request = cheats[a:A[0]].a:A[1:-1] + else + let request = a:A + endif + let pattern = substitute(request,'/\|\'.sep,'*'.sep,'g').'*' + let found = {} + for path in pathogen#split(&runtimepath) + let path = expand(path, ':p') + let matches = split(glob(path.sep.pattern),"\n") + call map(matches,'isdirectory(v:val) ? v:val.sep : v:val') + call map(matches,'expand(v:val, ":p")[strlen(path)+1:-1]') + for match in matches + let found[match] = 1 + endfor + endfor + return sort(keys(found)) +endfunction " }}}1 + +command! -bar -bang -range=1 -nargs=1 -complete=customlist,s:Findcomplete Ve :execute s:find(,'edit',,0) +command! -bar -bang -range=1 -nargs=1 -complete=customlist,s:Findcomplete Vedit :execute s:find(,'edit',,0) +command! -bar -bang -range=1 -nargs=1 -complete=customlist,s:Findcomplete Vopen :execute s:find(,'edit',,1) +command! -bar -bang -range=1 -nargs=1 -complete=customlist,s:Findcomplete Vsplit :execute s:find(,'split',,1) +command! -bar -bang -range=1 -nargs=1 -complete=customlist,s:Findcomplete Vvsplit :execute s:find(,'vsplit',,1) +command! -bar -bang -range=1 -nargs=1 -complete=customlist,s:Findcomplete Vtabedit :execute s:find(,'tabedit',,1) +command! -bar -bang -range=1 -nargs=1 -complete=customlist,s:Findcomplete Vpedit :execute s:find(,'pedit',,1) +command! -bar -bang -range=1 -nargs=1 -complete=customlist,s:Findcomplete Vread :execute s:find(,'read',,1) + +" vim:set et sw=2: diff --git a/vim/filetype.vim b/vim/filetype.vim index 65cd4b9..2042a4f 100644 --- a/vim/filetype.vim +++ b/vim/filetype.vim @@ -3,6 +3,7 @@ if exists("did_load_filetypes") endif augroup filetypedetect + au BufRead,BufNewFile *.sb setf scheme au BufRead,BufNewFile *.JS setf javascript au BufRead,BufNewFile *.jas setf asm au BufRead,BufNewFile *.swfml setf xml diff --git a/vimrc b/vimrc index 61c93a3..c2992b3 100644 --- a/vimrc +++ b/vimrc @@ -140,8 +140,12 @@ map g :bo cw 8 " {{{ Mappings " {{{ Tab Key magic ... -vmap >gv -vmap >gv +xnoremap >gv +snoremap >gv +vnoremap sabine Sabine " }}} + +call pathogen#infect() +let g:clang_complete_copen=1 +let g:clang_snippets=1 +let g:clang_complete_patterns=1 +let g:clang_snippets_engine = 'clang_complete' +set completeopt=menu,longest +set concealcursor=inv -- 2.20.1