diff options
author | 最萌小汐 <sumneko@hotmail.com> | 2021-06-11 16:51:15 +0800 |
---|---|---|
committer | 最萌小汐 <sumneko@hotmail.com> | 2021-06-11 16:51:15 +0800 |
commit | f10dd2af22efeb5330f2da23d615ff7bc213b1eb (patch) | |
tree | 087ae8628570dd93ec6c9df0c7d02e3397a376d7 /script/core | |
parent | d93c5645334b392284a7a171e66d1b82a997a841 (diff) | |
download | lua-language-server-f10dd2af22efeb5330f2da23d615ff7bc213b1eb.zip |
stash
Diffstat (limited to 'script/core')
-rw-r--r-- | script/core/noder.lua | 22 | ||||
-rw-r--r-- | script/core/searcher.lua | 2 |
2 files changed, 23 insertions, 1 deletions
diff --git a/script/core/noder.lua b/script/core/noder.lua index c3679612..86bd311b 100644 --- a/script/core/noder.lua +++ b/script/core/noder.lua @@ -855,6 +855,26 @@ function m.getLastID(id) return lastID end +---测试id是否包含field,如果遇到函数调用则中断 +---@param id string +---@return boolean +function m.hasField(id) + local firstID = m.getFirstID(id) + if firstID == id then + return false + end + local nextChar = id:sub(#firstID + 1, #firstID + 1) + if nextChar ~= SPLIT_CHAR then + return false + end + local next2Char = id:sub(#firstID + 2, #firstID + 2) + if next2Char == RETURN_INDEX + or next2Char == PARAM_INDEX then + return false + end + return true +end + ---把形如 `@file:\\\XXXXX@gv:1|1`拆分成uri与id ---@param id string ---@return uri? string @@ -913,6 +933,7 @@ function m.compileNodes(source) if next(noders) then return noders end + log.debug('compileNodes:', guide.getUri(root)) guide.eachSource(root, function (src) m.pushSource(noders, src) m.compileNode(noders, src) @@ -920,6 +941,7 @@ function m.compileNodes(source) -- Special rule: ('').XX -> stringlib.XX pushBackward(noders, 'str:', 'dn:stringlib') pushBackward(noders, 'dn:string', 'dn:stringlib') + log.debug('compileNodes finish:', guide.getUri(root)) return noders end diff --git a/script/core/searcher.lua b/script/core/searcher.lua index f1dd9508..e7755598 100644 --- a/script/core/searcher.lua +++ b/script/core/searcher.lua @@ -186,7 +186,7 @@ local function crossSearch(status, uri, expect, mode) return end status.lock[uri] = true - await.delay() + --await.delay() if TRACE then log.debug('crossSearch', uri, expect) end |