diff options
author | Björn Linse <bjorn.linse@gmail.com> | 2020-01-25 13:29:52 +0100 |
---|---|---|
committer | Björn Linse <bjorn.linse@gmail.com> | 2020-02-07 09:22:55 +0100 |
commit | 7ce9a5c7da0fb5d6117cf9526c39e01faf7e908d (patch) | |
tree | 79dbef5225a1e09dcef257d0992ec8b9e4724190 /src/nvim/api/vim.c | |
parent | 405f49a9b16c5668a033b8be959564abc5f852ba (diff) | |
download | rneovim-7ce9a5c7da0fb5d6117cf9526c39e01faf7e908d.tar.gz rneovim-7ce9a5c7da0fb5d6117cf9526c39e01faf7e908d.tar.bz2 rneovim-7ce9a5c7da0fb5d6117cf9526c39e01faf7e908d.zip |
api: add nvim_get_runtime_file for finding runtime files
Diffstat (limited to 'src/nvim/api/vim.c')
-rw-r--r-- | src/nvim/api/vim.c | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/src/nvim/api/vim.c b/src/nvim/api/vim.c index 9c58ce853b..29ec0207ba 100644 --- a/src/nvim/api/vim.c +++ b/src/nvim/api/vim.c @@ -703,6 +703,35 @@ ArrayOf(String) nvim_list_runtime_paths(void) return rv; } +/// Find files in runtime directories +/// +/// 'name' can contain wildcards. For example +/// nvim_get_runtime_file("colors/*.vim", true) will return all color +/// scheme files. +/// +/// It is not an error to not find any files. An empty array is returned then. +/// +/// @param name pattern of files to search for +/// @param all whether to return all matches or only the first +/// @return list of absolute paths to the found files +ArrayOf(String) nvim_get_runtime_file(String name, Boolean all) + FUNC_API_SINCE(7) +{ + Array rv = ARRAY_DICT_INIT; + if (!name.data) { + return rv; + } + int flags = DIP_START | (all ? DIP_ALL : 0); + do_in_runtimepath((char_u *)name.data, flags, find_runtime_cb, &rv); + return rv; +} + +static void find_runtime_cb(char_u *fname, void *cookie) +{ + Array *rv = (Array *)cookie; + ADD(*rv, STRING_OBJ(cstr_to_string((char *)fname))); +} + /// Changes the global working directory. /// /// @param dir Directory path |