diff options
-rw-r--r-- | server/src/emmy/class.lua | 6 | ||||
-rw-r--r-- | server/src/emmy/manager.lua | 26 | ||||
-rw-r--r-- | server/test/completion/init.lua | 37 | ||||
-rw-r--r-- | server/test/diagnostics/init.lua | 4 |
4 files changed, 48 insertions, 25 deletions
diff --git a/server/src/emmy/class.lua b/server/src/emmy/class.lua index a7417210..6728e2c4 100644 --- a/server/src/emmy/class.lua +++ b/server/src/emmy/class.lua @@ -50,11 +50,11 @@ function mt:eachField(callback) end end -return function (manager, source) +return function (manager, name, extends, source) local self = setmetatable({ - name = source[1][1], + name = name, source = source.id, - extends = source[2] and source[2][1], + extends = extends, _manager = manager, }, mt) return self diff --git a/server/src/emmy/manager.lua b/server/src/emmy/manager.lua index cce1e0e4..c1d46742 100644 --- a/server/src/emmy/manager.lua +++ b/server/src/emmy/manager.lua @@ -1,4 +1,5 @@ local listMgr = require 'vm.list' +local sourceMgr = require 'vm.source' local newClass = require 'emmy.class' local newType = require 'emmy.type' local newTypeUnit = require 'emmy.typeUnit' @@ -81,11 +82,17 @@ function mt:getClass(name) return list end +function mt:newClass(name, extends, source) + local list = self:getClass(name) + list[source.id] = newClass(self, name, extends, source) + return list[source.id] +end + function mt:addClass(source) local className = source[1][1] - local list = self:getClass(className) - list[source.id] = newClass(self, source) - return list[source.id] + local extends = source[2] and source[2][1] + local class = self:newClass(className, extends, source) + return class end function mt:addType(source) @@ -196,5 +203,18 @@ return function () local self = setmetatable({ _class = {}, }, mt) + + local source = sourceMgr.dummy() + self:newClass('any', nil, source) + self:newClass('string', 'any', source) + self:newClass('number', 'any', source) + self:newClass('integer', 'number', source) + self:newClass('boolean', 'any', source) + self:newClass('table', 'any', source) + self:newClass('function', 'any', source) + self:newClass('nil', 'any', source) + self:newClass('userdata', 'any', source) + self:newClass('thread', 'any', source) + return self end diff --git a/server/test/completion/init.lua b/server/test/completion/init.lua index 0d34a63b..19bf927a 100644 --- a/server/test/completion/init.lua +++ b/server/test/completion/init.lua @@ -807,28 +807,28 @@ TEST [[ } TEST [[ ----@class ABC ----@class BBC : $ +---@class ZABC +---@class ZBBC : Z$ ]] { { - label = 'ABC', + label = 'ZABC', kind = CompletionItemKind.Class, }, { - label = 'BBC', + label = 'ZBBC', kind = CompletionItemKind.Class, }, } TEST [[ ----@class abc +---@class zabc local abcd ----@type a$ +---@type za$ ]] { { - label = 'abc', + label = 'zabc', kind = CompletionItemKind.Class, }, } @@ -838,32 +838,27 @@ TEST [[ local abcd ---@type $ ]] -{ - { - label = 'abc', - kind = CompletionItemKind.Class, - }, -} +(EXISTS) TEST [[ ----@class abc +---@class zabc local abcd ----@type xxx|$ +---@type zxxx|z$ ]] { { - label = 'abc', + label = 'zabc', kind = CompletionItemKind.Class, } } TEST [[ ----@alias abc abb ----@type a$ +---@alias zabc zabb +---@type za$ ]] { { - label = 'abc', + label = 'zabc', kind = CompletionItemKind.Class, }, } @@ -877,6 +872,10 @@ TEST [[ label = 'Class', kind = CompletionItemKind.Class, }, + { + label = 'function', + kind = CompletionItemKind.Class, + }, } TEST [[ diff --git a/server/test/diagnostics/init.lua b/server/test/diagnostics/init.lua index 499ffe78..2ef052bf 100644 --- a/server/test/diagnostics/init.lua +++ b/server/test/diagnostics/init.lua @@ -426,3 +426,7 @@ TEST [[ ---@field <!x!> Class ---@field <!x!> Class ]] + +TEST [[ +---@class Class : any +]] |