diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-01-21 17:42:08 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-01-21 17:42:08 +0800 |
commit | e9818422596439666f2cf17d6fe83c472809320d (patch) | |
tree | 3361e7d258bce98fe10ad41a1cbdd2c9f329c2b7 /server/src | |
parent | ed21959eea02f2479ec87b6798d38b368542d881 (diff) | |
download | lua-language-server-e9818422596439666f2cf17d6fe83c472809320d.zip |
修正自动完成的BUG
Diffstat (limited to 'server/src')
-rw-r--r-- | server/src/core/completion.lua | 68 | ||||
-rw-r--r-- | server/src/method/textDocument/completion.lua | 6 |
2 files changed, 38 insertions, 36 deletions
diff --git a/server/src/core/completion.lua b/server/src/core/completion.lua index 6c49fbb0..15aa65ec 100644 --- a/server/src/core/completion.lua +++ b/server/src/core/completion.lua @@ -218,19 +218,19 @@ local function getDocument(var, source) return nil end -local function searchAsLocal(vm, pos, result, callback) - searchFields(result.key, result.source, vm.results.locals[1], nil, function (var) +local function searchAsLocal(vm, word, pos, result, callback) + searchFields(word, result.source, vm.results.locals[1], nil, function (var) callback(var, CompletionItemKind.Variable) end) -- 支持 local function - if matchKey(result.key, 'function') then + if matchKey(word, 'function') then callback('function', CompletionItemKind.Keyword) end end -local function searchAsArg(vm, pos, result, callback) - searchFields(result.key, result.source, vm.results.locals[1], nil, function (var) +local function searchAsArg(vm, word, pos, result, callback) + searchFields(word, result.source, vm.results.locals[1], nil, function (var) if var.value.lib then return end @@ -238,23 +238,23 @@ local function searchAsArg(vm, pos, result, callback) end) end -local function searchAsGlobal(vm, pos, result, callback) - if result.key == '' then +local function searchAsGlobal(vm, word, pos, result, callback) + if word == '' or word == nil then return end - searchLocals(vm, pos, result.key, function (var) + searchLocals(vm, pos, word, function (var) callback(var, CompletionItemKind.Variable) end) - searchFields(result.key, result.source, vm.results.locals[1], nil, function (var) + searchFields(word, result.source, vm.results.locals[1], nil, function (var) callback(var, CompletionItemKind.Field) end) - searchKeyWords(result.key, function (name) + searchKeyWords(word, function (name) callback(name, CompletionItemKind.Keyword) end) end -local function searchAsSuffix(result, callback) - searchFields(result.key, result.source, result.parent, result.source.object, function (var) +local function searchAsSuffix(result, word, callback) + searchFields(word, result.source, result.parent, result.source.object, function (var) callback(var, CompletionItemKind.Field) end) end @@ -307,16 +307,16 @@ local function searchInArg(vm, inCall, inString, callback) end end -local function searchAsIndex(vm, pos, result, callback) - searchLocals(vm, pos, result.key, function (var) +local function searchAsIndex(vm, word, pos, result, callback) + searchLocals(vm, pos, word, function (var) callback(var, CompletionItemKind.Variable) end) for _, index in ipairs(vm.results.indexs) do - if matchKey(result.key, index.key) then + if matchKey(word, index.key) then callback(index.key, CompletionItemKind.Property) end end - searchFields(result.key, result.source, vm.results.locals[1], nil, function (var) + searchFields(word, result.source, vm.results.locals[1], nil, function (var) callback(var, CompletionItemKind.Field) end) end @@ -381,9 +381,10 @@ local function isContainPos(obj, pos) return false end -local function findString(vm, pos) +local function findString(vm, word, pos) + local finishPos = pos + #word - 1 for _, source in ipairs(vm.results.strings) do - if isContainPos(source, pos) then + if isContainPos(source, finishPos) then return source end end @@ -400,11 +401,12 @@ local function findArgCount(args, pos) end -- 找出范围包含pos的call -local function findCall(vm, pos) +local function findCall(vm, word, pos) + local finishPos = pos + #word - 1 local results = {} for _, call in ipairs(vm.results.calls) do - if isContainPos(call.args, pos) then - local n = findArgCount(call.args, pos) + if isContainPos(call.args, finishPos) then + local n = findArgCount(call.args, finishPos) local var = vm.results.sources[call.lastObj] if var then results[#results+1] = { @@ -457,22 +459,22 @@ local function makeList(list, source) return callback end -local function searchInResult(result, source, vm, pos, callback) +local function searchInResult(result, word, source, vm, pos, callback) if result.type == 'local' then if source.isArg then - searchAsArg(vm, pos, result, callback) + searchAsArg(vm, word, pos, result, callback) elseif source.isLocal then - searchAsLocal(vm, pos, result, callback) + searchAsLocal(vm, word, pos, result, callback) else - searchAsGlobal(vm, pos, result, callback) + searchAsGlobal(vm, word, pos, result, callback) end elseif result.type == 'field' then if source.isIndex then - searchAsIndex(vm, pos, result, callback) + searchAsIndex(vm, word, pos, result, callback) elseif result.parent and result.parent.value and result.parent.value.ENV == true then - searchAsGlobal(vm, pos, result, callback) + searchAsGlobal(vm, word, pos, result, callback) else - searchAsSuffix(result, callback) + searchAsSuffix(result, word, callback) end end end @@ -560,8 +562,8 @@ end return function (vm, pos, word) local list = {} local callback = makeList(list) - local inCall = findCall(vm, pos) - local inString = findString(vm, pos) + local inCall = findCall(vm, word, pos) + local inString = findString(vm, word, pos) if inCall then searchInArg(vm, inCall, inString, callback) end @@ -573,13 +575,11 @@ return function (vm, pos, word) end if isValidResult(result) then callback = makeList(list, source) - searchInResult(result, source, vm, pos, callback) + searchInResult(result, word, source, vm, pos, callback) searchAllWords(result.key, vm, callback) clearList(list, source) else - if word then - searchAllWords(word, vm, callback) - end + searchAllWords(word, vm, callback) end end if #list == 0 then diff --git a/server/src/method/textDocument/completion.lua b/server/src/method/textDocument/completion.lua index 25cb155a..1e9030b8 100644 --- a/server/src/method/textDocument/completion.lua +++ b/server/src/method/textDocument/completion.lua @@ -30,13 +30,15 @@ local function findStartPos(pos, buf) end local function findWord(position, text) + local word = text for i = position-1, 1, -1 do local c = text:sub(i, i) if not c:find '%w' then - return text:sub(i+1, position) + word = text:sub(i+1, position) + break end end - return text:sub(1, position) + return word:match('^(%w*)') end return function (lsp, params) |