diff options
-rw-r--r-- | script/core/noder.lua | 6 | ||||
-rw-r--r-- | script/core/searcher.lua | 16 |
2 files changed, 19 insertions, 3 deletions
diff --git a/script/core/noder.lua b/script/core/noder.lua index 04066160..ee5c4975 100644 --- a/script/core/noder.lua +++ b/script/core/noder.lua @@ -1444,6 +1444,12 @@ function m.compileNode(noders, source) local defID = 'def:' .. id collector.subscribe(uri, defID, noders) + local fieldID = m.getLastID(id) + if fieldID then + local defNodeID = 'field:' .. fieldID + collector.subscribe(uri, defNodeID, noders) + end + if guide.isGlobal(source) then local defAnyID = 'def:g:' collector.subscribe(uri, defAnyID, noders) diff --git a/script/core/searcher.lua b/script/core/searcher.lua index f2b9b291..4ce89fd1 100644 --- a/script/core/searcher.lua +++ b/script/core/searcher.lua @@ -775,7 +775,8 @@ function m.searchRefsByID(status, suri, expect, mode) local crossed = {} if mode == 'def' or mode == 'alldef' - or field then + or field + or hasCall(field) then for _, guri in ceach('def:' .. id) do if uri == guri then goto CONTINUE @@ -783,6 +784,15 @@ function m.searchRefsByID(status, suri, expect, mode) searchID(guri, id, field, uri) ::CONTINUE:: end + elseif mode == 'field' + or mode == 'allfield' then + for _, guri in ceach('field:' .. id) do + if uri == guri then + goto CONTINUE + end + searchID(guri, id, field, uri) + ::CONTINUE:: + end else for _, guri in ceach(id) do if crossed[guri] then @@ -929,9 +939,9 @@ function m.searchRefsByID(status, suri, expect, mode) end local stepCount = 0 - local stepMaxCount = 1e4 + local stepMaxCount = 1e3 if mode == 'allref' or mode == 'alldef' then - stepMaxCount = 1e5 + stepMaxCount = 1e4 end function searchStep(uri, id, field) |