aboutsummaryrefslogtreecommitdiff
path: root/vim/autoload
diff options
context:
space:
mode:
authorTom Ryder <tom@sanctum.geek.nz>2020-04-25 22:34:39 +1200
committerTom Ryder <tom@sanctum.geek.nz>2020-04-25 22:34:39 +1200
commitf0ef30a4c5eed9f0b15bdcd9bdd1093aba72348e (patch)
tree72c88db4b186bff5f7ed2a0d50755ece682cfa48 /vim/autoload
parentHandle invalid XDG cache home (diff)
downloaddotfiles-f0ef30a4c5eed9f0b15bdcd9bdd1093aba72348e.tar.gz
dotfiles-f0ef30a4c5eed9f0b15bdcd9bdd1093aba72348e.zip
Improve compliance/sanity of XDG implementation
Diffstat (limited to 'vim/autoload')
-rw-r--r--vim/autoload/xdg.vim45
1 files changed, 27 insertions, 18 deletions
diff --git a/vim/autoload/xdg.vim b/vim/autoload/xdg.vim
index 675cf460..62d515c1 100644
--- a/vim/autoload/xdg.vim
+++ b/vim/autoload/xdg.vim
@@ -7,6 +7,8 @@ let s:defaults = {
\ 'XDG_DATA_DIRS': '/usr/local/share/:/usr/share/',
\}
+let s:subdir = 'vim'
+
function! s:Get(name) abort
let name = a:name
let env = environ()
@@ -23,31 +25,38 @@ function! s:Absolute(path) abort
return a:path =~# '^[/~]'
endfunction
-function! xdg#CacheDir(name) abort
- let name = a:name
- let home = s:Get('XDG_CACHE_HOME')
+function! s:Home(name) abort
+ let home = s:Get(a:name)
if !s:Absolute(home)
return ''
endif
- return join([home, name], '/')
+ return join([home, s:subdir], '/')
endfunction
-function! xdg#ConfigDirs(name) abort
- let name = a:name
- let home = s:Get('XDG_CONFIG_HOME')
- let dirs = split(s:Get('XDG_CONFIG_DIRS'), ':')
- return map(
- \ filter(insert(dirs, home), 's:Absolute(v:val)')
- \,'join([v:val, name], "/")'
- \)
+function! xdg#CacheHome() abort
+ return s:Home('XDG_CACHE_HOME')
endfunction
-function! xdg#DataDirs(name) abort
- let name = a:name
- let home = s:Get('XDG_DATA_HOME')
- let dirs = split(s:Get('XDG_DATA_DIRS'), ':')
+function! xdg#ConfigHome() abort
+ return s:Home('XDG_CONFIG_HOME')
+endfunction
+
+function! xdg#DataHome() abort
+ return s:Home('XDG_DATA_HOME')
+endfunction
+
+function! s:Dirs(name) abort
+ let dirs = split(s:Get(a:name), ':')
return map(
- \ filter(insert(dirs, home), 's:Absolute(v:val)')
- \,'join([v:val, name], "/")'
+ \ filter(dirs, 's:Absolute(v:val)')
+ \,'join([v:val, s:subdir], "/")'
\)
endfunction
+
+function! xdg#ConfigDirs() abort
+ return s:Dirs('XDG_CONFIG_DIRS')
+endfunction
+
+function! xdg#DataDirs() abort
+ return s:Dirs('XDG_DATA_DIRS')
+endfunction