blob: 4faab3f135fe8c58c0ad824ae21ff854cd9e453b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
|
return function (source)
local value = source:bindValue()
local func = value:getFunction()
local declarat
if func then
declarat = func.source.name
else
declarat = source
end
if not declarat then
return source:getName() or ''
end
local key
if declarat:get 'simple' then
local simple = declarat:get 'simple'
local chars = {}
for i, obj in ipairs(simple) do
if obj.type == 'name' then
chars[i] = obj[1]
elseif obj.type == 'index' then
chars[i] = '[?]'
elseif obj.type == 'call' then
chars[i] = '(?)'
elseif obj.type == ':' then
chars[i] = ':'
elseif obj.type == '.' then
chars[i] = '.'
else
chars[i] = '*' .. obj.type
end
if obj == declarat then
break
end
end
key = table.concat(chars)
elseif declarat.type == 'name' then
key = declarat[1]
elseif declarat.type == 'string' then
key = ('%q'):format(declarat[1])
elseif declarat.type == 'number' or declarat.type == 'boolean' then
key = tostring(declarat[1])
elseif declarat.type == 'simple' then
local chars = {}
for i, obj in ipairs(declarat) do
if obj.type == 'name' then
chars[i] = obj[1]
elseif obj.type == 'index' then
chars[i] = '[?]'
elseif obj.type == 'call' then
chars[i] = '(?)'
elseif obj.type == ':' then
chars[i] = ':'
elseif obj.type == '.' then
chars[i] = '.'
else
chars[i] = '*' .. obj.type
end
end
-- 这里有个特殊处理
-- function mt:func() 以 mt.func 的形式调用时
-- hover 显示为 mt.func(self)
if chars[#chars-1] == ':' then
if not source:get 'object' then
chars[#chars-1] = '.'
end
elseif chars[#chars-1] == '.' then
if source:get 'object' then
chars[#chars-1] = ':'
end
end
key = table.concat(chars)
else
key = ''
end
return key
end
|