diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2022-01-07 16:21:25 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2022-01-07 16:21:25 +0800 |
commit | 6194e11b4153a4fba16a5ba15876581b8d3cde43 (patch) | |
tree | 01b24dc08ca58d96ca1050df2063a2a9e5c8f8c7 | |
parent | 63576455aae64574b8e1f989d4380233c5d0bf66 (diff) | |
download | lua-language-server-6194e11b4153a4fba16a5ba15876581b8d3cde43.zip |
update semantic-tokens
-rw-r--r-- | script/core/semantic-tokens.lua | 154 | ||||
-rw-r--r-- | script/parser/newparser.lua | 2 |
2 files changed, 68 insertions, 88 deletions
diff --git a/script/core/semantic-tokens.lua b/script/core/semantic-tokens.lua index 1b6b0a7e..40e7af18 100644 --- a/script/core/semantic-tokens.lua +++ b/script/core/semantic-tokens.lua @@ -91,10 +91,19 @@ local Care = util.switch() modifieres = modifiers, } end) + : case 'local' : case 'getlocal' : case 'setlocal' : call(function (source, options, results) - local loc = source.node + if source.locPos then + results[#results+1] = { + start = source.locPos, + finish = source.locPos + #'local', + type = define.TokenTypes.keyword, + modifieres = define.TokenModifiers.declaration, + } + end + local loc = source.node or source -- 1. 值为函数的局部变量 | Local variable whose value is a function if loc.refs then for _, ref in ipairs(loc.refs) do @@ -108,19 +117,27 @@ local Care = util.switch() end end end - -- 2. 对象 | Object - if source.parent.type == 'getmethod' - or source.parent.type == 'setmethod' - and source.parent.node == source then + -- 3. 特殊变量 | Special variableif source[1] == '_ENV' then + if loc[1] == '_ENV' then + results[#results+1] = { + start = source.start, + finish = source.finish, + type = define.TokenTypes.variable, + modifieres = define.TokenModifiers.readonly, + } return end - -- 3. 特殊变量 | Special variable - if source[1] == '_ENV' - or source[1] == 'self' then + if loc[1] == 'self' then + results[#results+1] = { + start = source.start, + finish = source.finish, + type = define.TokenTypes.variable, + modifieres = define.TokenModifiers.abstract, + } return end -- 4. 函数的参数 | Function parameters - if loc.parent and loc.parent.type == 'funcargs' then + if source.parent and source.parent.type == 'funcargs' then results[#results+1] = { start = source.start, finish = source.finish, @@ -207,99 +224,57 @@ local Care = util.switch() and source.parent.node == source then return end - local isLocal = loc.parent ~= guide.getRoot(loc) + local mod + if source.type == 'local' then + mod = define.TokenModifiers.declaration + end -- 8. 其他 | Other results[#results+1] = { start = source.start, finish = source.finish, type = define.TokenTypes.variable, - modifieres = isLocal and define.TokenModifiers['local'] or nil, + modifieres = mod, } end) - : case 'local' - : call(function (source, options, results) -- Local declaration, i.e. "local x", "local y = z", or "local function() end" - if source[1] == '_ENV' - or source[1] == 'self' then - return - end - if source.parent and source.parent.type == 'funcargs' then - results[#results+1] = { - start = source.start, - finish = source.finish, - type = define.TokenTypes.parameter, - modifieres = define.TokenModifiers.declaration, - } - return - end - if source.value then - local isFunction = false - - if options.isEnhanced then - isFunction = source.value.type == 'function' or infer.hasType(source.value, 'function') - else - isFunction = source.value.type == 'function' - end - - if isFunction then - -- Function declaration, either a new one or an alias for another one + : case 'function' + : case 'ifblock' + : case 'elseifblock' + : case 'elseblock' + : case 'do' + : case 'for' + : case 'loop' + : case 'in' + : case 'while' + : case 'repeat' + : call(function (source, options, results) + local keyword = source.keyword + if keyword then + for i = 1, #keyword, 2 do results[#results+1] = { - start = source.start, - finish = source.finish, - type = define.TokenTypes['function'], - modifieres = define.TokenModifiers.declaration, + start = keyword[i], + finish = keyword[i + 1], + type = define.TokenTypes.keyword, } - return - end - end - if source.value and source.value.type == 'table' and source.bindDocs then - for _, doc in ipairs(source.bindDocs) do - if doc.type == "doc.class" then - -- Class declaration (explicit) - results[#results+1] = { - start = source.start, - finish = source.finish, - type = define.TokenTypes.class, - modifieres = define.TokenModifiers.declaration, - } - return - end end end - if source.attrs then - for _, attr in ipairs(source.attrs) do - local name = attr[1] - if name == 'const' then - results[#results+1] = { - start = source.start, - finish = source.finish, - type = define.TokenTypes.variable, - modifieres = define.TokenModifiers.declaration | define.TokenModifiers.static, - } - return - elseif name == 'close' then - results[#results+1] = { - start = source.start, - finish = source.finish, - type = define.TokenTypes.variable, - modifieres = define.TokenModifiers.declaration | define.TokenModifiers.abstract, - } - return - end - end - end - - local isLocal = source.parent ~= guide.getRoot(source) - local modifiers = define.TokenModifiers.declaration - - if isLocal then - modifiers = modifiers | define.TokenModifiers.definition + end) + : case 'if' + : call(function (source, options, results) + local offset = guide.positionToOffset(options.state, source.finish) + if options.text:sub(offset - 2, offset) == 'end' then + results[#results+1] = { + start = source.finish - #'end', + finish = source.finish, + type = define.TokenTypes.keyword, + } end - + end) + : case 'return' + : call(function (source, options, results) results[#results+1] = { start = source.start, - finish = source.finish, - type = define.TokenTypes.variable, - modifieres = modifiers, + finish = source.start + #'return', + type = define.TokenTypes.keyword, } end) : case 'doc.return.name' @@ -386,6 +361,9 @@ return function (uri, start, finish) end local options = { + uri = uri, + state = state, + text = files.getText(uri), isEnhanced = config.get(uri, 'Lua.color.mode') == 'SemanticEnhanced', } diff --git a/script/parser/newparser.lua b/script/parser/newparser.lua index 7ff5dca9..b7868646 100644 --- a/script/parser/newparser.lua +++ b/script/parser/newparser.lua @@ -2796,6 +2796,7 @@ local function compileExpAsAction(exp) end local function parseLocal() + local locPos = getPosition(Tokens[Index], 'left') Index = Index + 2 skipSpace() local word = peekWord() @@ -2828,6 +2829,7 @@ local function parseLocal() return nil end local loc = createLocal(name, parseLocalAttrs()) + loc.locPos = locPos loc.effect = maxinteger pushActionIntoCurrentChunk(loc) skipSpace() |