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 [[ 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 = {} function :a() :remove() end ]] TEST [[ local function f() return <~ () end!> end local = f() ]] TEST [[ local function f() return nil, <~ () end!> end local _, = f() ]] TEST [[ table.() function table.() end ]] TEST [[ local mt = {} mt.x = 1 local obj = setmetatable({}, mt) print(obj.) ]] --TEST [[ -----@class -----@type -----@type --]] -- --TEST [[ -----@class -----@type -----@type --]]