diff options
Diffstat (limited to 'server/src')
-rw-r--r-- | server/src/core/completion.lua | 18 | ||||
-rw-r--r-- | server/src/utility.lua | 15 |
2 files changed, 25 insertions, 8 deletions
diff --git a/server/src/core/completion.lua b/server/src/core/completion.lua index 23bd224c..cf9a1a90 100644 --- a/server/src/core/completion.lua +++ b/server/src/core/completion.lua @@ -222,6 +222,16 @@ local function searchFields(vm, source, word, callback) if source:get 'object' and v:getType() ~= 'function' then goto CONTINUE end + if k == word then + local ok = v:eachInfo(function (_, src) + if src ~= source then + return true + end + end) + if not ok then + goto CONTINUE + end + end if matchKey(word, k) then map[k] = v end @@ -509,7 +519,7 @@ local function searchSpecial(vm, source, word, callback, pos) end end -local function makeList(source, word) +local function makeList(source, pos, word) local list = {} local mark = {} return function (name, src, kind, data) @@ -517,7 +527,9 @@ local function makeList(source, word) return end if word == name then - return + if src and src.start <= pos and src.finish >= pos then + return + end end if mark[name] then return @@ -547,7 +559,7 @@ return function (vm, pos, word, oldText) return nil end end - local callback, list = makeList(source, word) + local callback, list = makeList(source, pos, word) searchSpecial(vm, source, word, callback, pos) searchCallArg(vm, source, word, callback, pos) searchSource(vm, source, word, callback) diff --git a/server/src/utility.lua b/server/src/utility.lua index 3f0df110..a4072510 100644 --- a/server/src/utility.lua +++ b/server/src/utility.lua @@ -10,6 +10,8 @@ local next = next local rawset = rawset local move = table.move local setmetatable = setmetatable +local tableSort = table.sort +local mathType = math.type local TAB = setmetatable({}, { __index = function (self, n) self[n] = string_rep('\t', n) @@ -41,16 +43,19 @@ function table.dump(tbl) else KEY[key] = key end - elseif math_type(key) == 'integer' then - KEY[key] = ('[%d]'):format(key) + elseif mathType(key) == 'integer' then + KEY[key] = ('[%03d]'):format(key) else KEY[key] = ('<%s>'):format(key) end keys[#keys+1] = key end - table_sort(keys, function (a, b) - return KEY[a] < KEY[b] - end) + local mt = getmetatable(tbl) + if not mt or not mt.__pairs then + tableSort(keys, function (a, b) + return KEY[a] < KEY[b] + end) + end for _, key in ipairs(keys) do local value = tbl[key] local tp = type(value) |