aboutsummaryrefslogtreecommitdiff
path: root/scripts/geneval.lua
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2016-06-18 12:06:50 +0200
committerBjörn Linse <bjorn.linse@gmail.com>2016-08-31 21:40:20 +0200
commit3bd3b3b76859b3eef80fa4969147efa881b60f40 (patch)
tree0e70b42651dd91ccb1a16fe4a2222b0e92e9a3d2 /scripts/geneval.lua
parentde3a515123fa417ecce61efebe4bc117b010c657 (diff)
downloadrneovim-3bd3b3b76859b3eef80fa4969147efa881b60f40.tar.gz
rneovim-3bd3b3b76859b3eef80fa4969147efa881b60f40.tar.bz2
rneovim-3bd3b3b76859b3eef80fa4969147efa881b60f40.zip
api: auto generate api function wrappers for viml
Diffstat (limited to 'scripts/geneval.lua')
-rw-r--r--scripts/geneval.lua21
1 files changed, 18 insertions, 3 deletions
diff --git a/scripts/geneval.lua b/scripts/geneval.lua
index c9533d7908..396e7b81db 100644
--- a/scripts/geneval.lua
+++ b/scripts/geneval.lua
@@ -1,5 +1,8 @@
+mpack = require('mpack')
+
local nvimsrcdir = arg[1]
local autodir = arg[2]
+local metadata_file = arg[3]
if nvimsrcdir == '--help' then
print([[
@@ -18,9 +21,20 @@ local funcsfname = autodir .. '/funcs.generated.h'
local funcspipe = io.open(funcsfname .. '.hsh', 'w')
-local funcs = require('eval')
+local funcs = require('eval').funcs
+
+local metadata = mpack.unpack(io.open(arg[3], 'rb'):read("*all"))
+
+for i,fun in ipairs(metadata) do
+ funcs['api_'..fun.name] = {
+ args=#fun.parameters,
+ func='api_wrapper',
+ data='handle_'..fun.name,
+ }
+end
+
-for name, def in pairs(funcs.funcs) do
+for name, def in pairs(funcs) do
args = def.args or 0
if type(args) == 'number' then
args = {args, args}
@@ -28,7 +42,8 @@ for name, def in pairs(funcs.funcs) do
args[2] = 'MAX_FUNC_ARGS'
end
func = def.func or ('f_' .. name)
- local val = ('{ %s, %s, &%s }'):format(args[1], args[2], func)
+ data = def.data or "NULL"
+ local val = ('{ %s, %s, &%s, %s }'):format(args[1], args[2], func, data)
funcspipe:write(name .. '\n' .. val .. '\n')
end
funcspipe:close()