diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2022-08-25 18:42:34 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2022-08-25 18:42:34 +0800 |
commit | f0375c8fb10c9205be49ec9cbbaa83a9c0638641 (patch) | |
tree | c78afb285f144e5419b22257993914ebc49d38ed /script/core | |
parent | 95deef9c3415dfa83b39a4e4f039dc7728fce544 (diff) | |
download | lua-language-server-f0375c8fb10c9205be49ec9cbbaa83a9c0638641.zip |
update document-symbol
Diffstat (limited to 'script/core')
-rw-r--r-- | script/core/document-symbol.lua | 66 |
1 files changed, 56 insertions, 10 deletions
diff --git a/script/core/document-symbol.lua b/script/core/document-symbol.lua index 90d312e3..2c9caafb 100644 --- a/script/core/document-symbol.lua +++ b/script/core/document-symbol.lua @@ -3,6 +3,7 @@ local files = require 'files' local guide = require 'parser.guide' local define = require 'proto.define' local util = require 'utility' +local vm = require 'vm' local function buildName(source, text) local uri = guide.getUri(source) @@ -29,6 +30,9 @@ local function buildName(source, text) return text:sub(startOffset + 1, finishOffset) end end + if source.type == 'tableexp' then + return ('[%d]'):format(source.tindex) + end local finishOffset = guide.positionToOffset(state, source.finish) return text:sub(startOffset + 1, finishOffset) end @@ -53,8 +57,9 @@ local function buildFunctionParams(func) end local function buildTable(tbl) + local uri = guide.getUri(tbl) local buf = {} - for i = 1, 3 do + for i = 1, 5 do local field = tbl[i] if not field then break @@ -62,10 +67,34 @@ local function buildTable(tbl) if field.type == 'tablefield' and field.field then buf[#buf+1] = ('%s'):format(field.field[1]) + elseif field.type == 'tableindex' + and field.index then + local view = vm.getInfer(field.index):viewLiterals() + or vm.getInfer(field.index):view(uri) + buf[#buf+1] = ('[%s]'):format(view) + elseif field.type == 'tableexp' then + buf[#buf+1] = ('[%s]'):format(field.tindex) end end - if #tbl > 3 then - buf[#buf+1] = ('...(+%d)'):format(#tbl - 3) + if #tbl > 5 then + buf[#buf+1] = ('...(+%d)'):format(#tbl - 5) + end + return table.concat(buf, ', ') +end + +local function buildArray(tbl) + local uri = guide.getUri(tbl) + local buf = {} + for i = 1, 5 do + local field = tbl[i] + if not field then + break + end + buf[#buf+1] = vm.getInfer(field):viewLiterals() + or vm.getInfer(field):view(uri) + end + if #tbl > 5 then + buf[#buf+1] = ('...(+%d)'):format(#tbl - 5) end return table.concat(buf, ', ') end @@ -100,6 +129,9 @@ local function buildValue(source, text, used, symbols) end range = { source.index.start, source.index.finish } sRange = { source.index.start, source.index.finish } + elseif source.type == 'tableexp' then + range = { source.value.start, source.value.finish } + sRange = { source.value.start, source.value.finish } elseif source.type == 'setfield' then if not source.field then return @@ -136,10 +168,21 @@ local function buildValue(source, text, used, symbols) end elseif source.value.type == 'table' then kind = define.SymbolKind.Object + local lastField = source.value[#source.value] if #source.value > 0 then - details[#details+1] = '{' - details[#details+1] = buildTable(source.value) - details[#details+1] = '}' + if lastField.type == 'tableexp' + and lastField.tindex == #source.value then + -- Array + kind = define.SymbolKind.Array + details[#details+1] = '[' + details[#details+1] = buildArray(source.value) + details[#details+1] = ']' + else + -- Object + details[#details+1] = '{' + details[#details+1] = buildTable(source.value) + details[#details+1] = '}' + end end valueRange = { source.value.start, source.value.finish } elseif source.value.type == 'select' then @@ -192,7 +235,6 @@ local function buildAnonymousFunction(source, text, used, symbols) } end ----@async local function buildSource(source, text, used, symbols) if source.type == 'local' or source.type == 'setlocal' @@ -202,10 +244,8 @@ local function buildSource(source, text, used, symbols) or source.type == 'tablefield' or source.type == 'tableexp' or source.type == 'tableindex' then - await.delay() buildValue(source, text, used, symbols) elseif source.type == 'function' then - await.delay() buildAnonymousFunction(source, text, used, symbols) end end @@ -220,8 +260,14 @@ local function makeSymbol(uri) local symbols = {} local used = {} - guide.eachSource(ast.ast, function (source) ---@async + local i = 0 + ---@async + guide.eachSource(ast.ast, function (source) buildSource(source, text, used, symbols) + i = i + 1 + if i % 1000 == 0 then + await.delay() + end end) return symbols |