local core = require 'core.reference' local files = require 'files' local function catch_target(script) local list = {} local cur = 1 while true do local start, finish = script:find('<[!?].-[!?]>', cur) if not start then break end list[#list+1] = { start + 2, finish - 2 } cur = finish + 1 end return list end local function founded(targets, results) if #targets ~= #results then return false end for _, target in ipairs(targets) do for _, result in ipairs(results) do if target[1] == result[1] and target[2] == result[2] then goto NEXT end end do return false end ::NEXT:: end return true end function TEST(script) files.removeAll() local target = catch_target(script) local start = script:find('<[?~]') local finish = script:find('[?~]>') local pos = (start + finish) // 2 + 1 local new_script = script:gsub('<[!?~]', ' '):gsub('[!?~]>', ' ') files.setText('', new_script) local results = core('', pos) if results then local positions = {} for i, result in ipairs(results) do positions[i] = { result.target.start, result.target.finish } end assert(founded(target, positions)) else assert(#target == 0) end end TEST [[ local = 1 = ]] TEST [[ = 1 = ]] TEST [[ local t t. = 1 t. = t. ]] TEST [[ t. = 1 t. = t. ]] TEST [[ :: :: goto if true then goto end ]] TEST [[ :: :: goto if true then goto end ]] TEST [[ local a = 1 local = 1 = ]] TEST [[ local t = { = 1 } print(t.) ]] TEST [[ local t = { = 1 } print(t.) ]] TEST [[ local t = { [] = 1 } print(t.) ]] --TEST [[ --local = {} --function :a() -- :remove() --end --]] TEST [[ local function f() return <~function~> () end end local = f() ]] TEST [[ local function f() return nil, <~function~> () end end local _, = f() ]] TEST [[ table.() function table.() end ]] TEST [[ local mt = {} local = setmetatable({}, mt) ]] TEST [[ local mt = {} mt.x = 1 local obj = setmetatable({}, mt) print(obj.) ]] TEST [[ local x local function f() return x end local = f() ]] TEST [[ local local function f() return end local y = f() ]] TEST [[ local x local function f() return function () return x end end local = f()() ]] TEST [[ local local function f() return function () return end end local y = f()() ]] TEST [[ local mt = {} mt.__index = mt function mt:add(a, b) end local function init() return setmetatable({}, mt) end local = init() :add() ]] TEST [[ local mt = {} mt.__index = mt function mt:add(a, b) end local function init() return setmetatable({}, mt) end local t = init() t:() ]] TEST [[ local t = {} t. = 1 t[a.b.x] = 1 ]] --TEST [[ --local t = {} --t.x = 1 --t[a.b.] = 1 --]] TEST [[ local t local f = t. f() return { f = f, } ]] TEST [[ self = { results = { = {}, } } self[self.results.] = lbl ]] TEST [[ a.b. = 1 print(a.b.) ]] --TEST [[ -----@class -----@type -----@type --]] -- --TEST [[ -----@class -----@type -----@type --]]