diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2019-11-16 01:12:07 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2019-11-16 01:12:07 +0800 |
commit | 333a10fd656b48a063092127c610348d861c2f74 (patch) | |
tree | c9fea7eea15285ce05150b6a5707430d28f42d88 /server-beta/test/highlight | |
parent | cc7584f46c50eafbcd6a78c0daea611b6cb98800 (diff) | |
download | lua-language-server-333a10fd656b48a063092127c610348d861c2f74.zip |
core.highlight
Diffstat (limited to 'server-beta/test/highlight')
-rw-r--r-- | server-beta/test/highlight/init.lua | 57 |
1 files changed, 30 insertions, 27 deletions
diff --git a/server-beta/test/highlight/init.lua b/server-beta/test/highlight/init.lua index 6b8ab355..ebde9204 100644 --- a/server-beta/test/highlight/init.lua +++ b/server-beta/test/highlight/init.lua @@ -1,6 +1,5 @@ -local core = require 'core' -local parser = require 'parser' -local buildVM = require 'vm' +local core = require 'core.highlight' +local files = require 'files' local function catch_target(script) local list = {} @@ -10,7 +9,10 @@ local function catch_target(script) if not start then break end - list[#list+1] = { start + 2, finish - 2 } + list[#list+1] = { + start = start + 2, + finish = finish - 2, + } cur = finish + 1 end return list @@ -32,53 +34,54 @@ local function founded(targets, results) return true end -function TEST(newName) - return function (script) - local target = catch_target(script) - local start = script:find('<?', 1, true) - local finish = script:find('?>', 1, true) - local pos = (start + finish) // 2 + 1 - local new_script = script:gsub('<[!?]', ' '):gsub('[!?]>', ' ') - local ast = parser:parse(new_script, 'lua', 'Lua 5.3') - assert(ast) - local vm = buildVM(ast) - assert(vm) +function TEST(script) + files.removeAll() + local target = catch_target(script) + local start = script:find('<?', 1, true) + local finish = script:find('?>', 1, true) + local pos = (start + finish) // 2 + 1 + local new_script = script:gsub('<[!?]', ' '):gsub('[!?]>', ' ') + files.setText('', new_script) - local positions = core.highlight(vm, pos) - if positions then - assert(founded(target, positions)) - else - assert(#target == 0) - end + local positions = core('', pos) + if positions then + assert(founded(target, positions)) + else + assert(#target == 0) end end -TEST 'b' [[ +TEST [[ local <?a?> = 1 ]] -TEST 'b' [[ +TEST [[ local <?a?> = 1 <!a!> = 2 <!a!> = <!a!> ]] -TEST 'b' [[ +TEST [[ t.<?a?> = 1 a = t.<!a!> ]] -TEST 'b' [[ +TEST [[ t[<!'a'!>] = 1 a = t.<?a?> ]] -TEST 'b' [[ +TEST [[ +t[<?'a'?>] = 1 +a = t.<!a!> +]] + +TEST [[ :: <?a?> :: goto <!a!> ]] -TEST 'b' [[ +TEST [[ local function f(<!a!>) return <?a?> end |