diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2022-06-07 20:15:05 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2022-06-07 20:15:05 +0800 |
commit | 4b87fcfa6ccea234a4878a95ffb2c9bbf32c6f17 (patch) | |
tree | 6e5c57c3faa6e0a4e363d21e92e0e88c2cf94cb3 /script/vm | |
parent | 83b2804fb7e2219b7147ebd7bc877fa47816bbb9 (diff) | |
download | lua-language-server-4b87fcfa6ccea234a4878a95ffb2c9bbf32c6f17.zip |
#1192 improve `[[--@as number]]`
cache ases and search with dichotomy
Diffstat (limited to 'script/vm')
-rw-r--r-- | script/vm/compiler.lua | 43 |
1 files changed, 38 insertions, 5 deletions
diff --git a/script/vm/compiler.lua b/script/vm/compiler.lua index 797fa901..1c3be7c8 100644 --- a/script/vm/compiler.lua +++ b/script/vm/compiler.lua @@ -519,14 +519,47 @@ local function bindAs(source) if not docs then return end - for _, doc in ipairs(docs) do - if doc.type == 'doc.as' and doc.originalComment.start == source.finish + 2 then - if doc.as then - vm.setNode(source, vm.compileNode(doc.as), true) + local ases = docs._asCache + if not ases then + ases = {} + docs._asCache = ases + for _, doc in ipairs(docs) do + if doc.type == 'doc.as' and doc.as then + ases[#ases+1] = doc end - return true + end + table.sort(ases, function (a, b) + return a.start < b.start + end) + end + + local max = #ases + local index + local left = 1 + local right = max + for _ = 1, 1000 do + index = left + (right - left) // 2 + if index <= left then + index = left + break + elseif index >= right then + index = right + break + end + local doc = ases[index] + if doc.originalComment.start < source.finish + 2 then + left = index + 1 + else + right = index end end + + local doc = ases[index] + if doc and doc.originalComment.start == source.finish + 2 then + vm.setNode(source, vm.compileNode(doc.as), true) + return true + end + return false end |