diff options
author | Parménides GV <parmegv@sdf.org> | 2013-05-28 20:14:01 +0200 |
---|---|---|
committer | Parménides GV <parmegv@sdf.org> | 2013-05-28 20:14:01 +0200 |
commit | 086a98886a5b28c1f9426fd40c093bf2affa960e (patch) | |
tree | d574ef0d1a6e2e64de3498c6d0c240e9f59b37a0 | |
parent | be9dc79cff4b04b2bb6af6dbbe679a0c8a5f6df4 (diff) |
Starting basic adt vim plugin.
If I execute AndroidRun, run.sh is not called but echoes are printed.
-rw-r--r-- | vim-plugin/basic-adt.vim | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/vim-plugin/basic-adt.vim b/vim-plugin/basic-adt.vim new file mode 100644 index 00000000..366b3f20 --- /dev/null +++ b/vim-plugin/basic-adt.vim @@ -0,0 +1,47 @@ +function! AndroidRun() + let new_project_root = s:Find_in_parent("AndroidManifest.xml", s:windowdir() ,$HOME) + echo "Found Android Project at: " . new_project_root + echo "Windowdir: " . s:windowdir() + if new_project_root != "Nothing" + let b:project_root = new_project_root + new + set buftype=nofile + silent! exec "r!../run.sh SII b:project_root + endif +endfunc + +" Find_in_parent +" " find the file argument and returns the path to it. +" " Starting with the current working dir, it walks up the parent folders +" " until it finds the file, or it hits the stop dir. +" " If it doesn't find it, it returns "Nothing" +function s:Find_in_parent(fln,flsrt,flstp) + let here = a:flsrt + while ( strlen( here) > 0 ) + if filereadable( here . "/" . a:fln ) + return here + endif + let fr = match(here, "/[^/]*$") + if fr == -1 + break + endif + let here = strpart(here, 0, fr) + if here == a:flstp + break + endif + endwhile + return "Nothing" +endfunc + +" windowdir +" " Gets the directory for the file in the current window +" " Or the current working dir if there isn't one for the window. +" " Use tr to allow that other OS paths, too +function s:windowdir() + if winbufnr(0) == -1 + let unislash = getcwd() + else + let unislash = fnamemodify(bufname(winbufnr(0)), ':p:h') + endif + return tr(unislash, '\', '/') +endfunc |