aboutsummaryrefslogtreecommitdiff
path: root/scripts/geneval.lua
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2016-06-19 16:41:08 +0200
committerBjörn Linse <bjorn.linse@gmail.com>2016-08-31 21:57:04 +0200
commit7e2348f2b1b487c875bbcf6c6711a276f9063040 (patch)
tree9c00dc0c619c419e2819ad1a324a3aaf5b185aff /scripts/geneval.lua
parent87e054bb24cd4ba8cd06eb1a65f956c6bcce222d (diff)
downloadrneovim-7e2348f2b1b487c875bbcf6c6711a276f9063040.tar.gz
rneovim-7e2348f2b1b487c875bbcf6c6711a276f9063040.tar.bz2
rneovim-7e2348f2b1b487c875bbcf6c6711a276f9063040.zip
eval: use gperf to generate the hash of builtin functions
make api functions highlighted as builtins in vim.vim
Diffstat (limited to 'scripts/geneval.lua')
-rw-r--r--scripts/geneval.lua29
1 files changed, 22 insertions, 7 deletions
diff --git a/scripts/geneval.lua b/scripts/geneval.lua
index 396e7b81db..75a8bdfab3 100644
--- a/scripts/geneval.lua
+++ b/scripts/geneval.lua
@@ -3,6 +3,7 @@ mpack = require('mpack')
local nvimsrcdir = arg[1]
local autodir = arg[2]
local metadata_file = arg[3]
+local funcs_file = arg[4]
if nvimsrcdir == '--help' then
print([[
@@ -19,20 +20,34 @@ package.path = nvimsrcdir .. '/?.lua;' .. package.path
local funcsfname = autodir .. '/funcs.generated.h'
-local funcspipe = io.open(funcsfname .. '.hsh', 'w')
+local gperfpipe = io.open(funcsfname .. '.gperf', 'wb')
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,
+ data='&handle_'..fun.name,
}
end
+local funcsdata = io.open(funcs_file, 'w')
+funcsdata:write(mpack.pack(funcs))
+funcsdata:close()
+
+gperfpipe:write([[
+%language=ANSI-C
+%global-table
+%define initializer-suffix ,0,0,NULL,NULL
+%define word-array-name functions
+%define hash-function-name hash_internal_func_gperf
+%define lookup-function-name find_internal_func_gperf
+%omit-struct-type
+%struct-type
+VimLFuncDef;
+%%
+]])
for name, def in pairs(funcs) do
args = def.args or 0
@@ -43,7 +58,7 @@ for name, def in pairs(funcs) do
end
func = def.func or ('f_' .. name)
data = def.data or "NULL"
- local val = ('{ %s, %s, &%s, %s }'):format(args[1], args[2], func, data)
- funcspipe:write(name .. '\n' .. val .. '\n')
+ gperfpipe:write(('%s, %s, %s, &%s, (FunPtr)%s\n')
+ :format(name, args[1], args[2], func, data))
end
-funcspipe:close()
+gperfpipe:close()