summaryrefslogtreecommitdiff
path: root/lua/nvim-treesitter/query.lua
diff options
context:
space:
mode:
authorSteven Sojka <steelsojka@users.noreply.github.com>2020-08-22 09:10:28 -0500
committerGitHub <noreply@github.com>2020-08-22 09:10:28 -0500
commit3b2cb65d4cfc6e86026f8cc6bf63c180d271ebe3 (patch)
tree462836d0e88a0672ccf538d81ddf80011493d56b /lua/nvim-treesitter/query.lua
parent53fda90be0ae56b6b8b47af1f8a86733447532c5 (diff)
parent3fe8bbcf9c238c70ffd7a01982d98981b346984e (diff)
Merge pull request #330 from steelsojka/fix-do-not-reattach
fix(modules): do not reattach if already attached
Diffstat (limited to 'lua/nvim-treesitter/query.lua')
-rw-r--r--lua/nvim-treesitter/query.lua19
1 files changed, 5 insertions, 14 deletions
diff --git a/lua/nvim-treesitter/query.lua b/lua/nvim-treesitter/query.lua
index 4a2ce57d..2dd85e2a 100644
--- a/lua/nvim-treesitter/query.lua
+++ b/lua/nvim-treesitter/query.lua
@@ -2,20 +2,11 @@ local api = vim.api
local ts = vim.treesitter
local utils = require'nvim-treesitter.utils'
local parsers = require'nvim-treesitter.parsers'
+local caching = require'nvim-treesitter.caching'
local M = {}
-local default_dict = {
- __index = function(table, key)
- local exists = rawget(table, key)
- if not exists then
- table[key] = {}
- end
- return rawget(table, key)
- end
-}
-
-local query_cache = setmetatable({}, default_dict)
+local query_cache = caching.create_buffer_cache()
-- Some treesitter grammars extend others.
-- We can use that to import the queries of the base language
@@ -55,17 +46,17 @@ local function read_query_files(filenames)
end
local function update_cached_matches(bufnr, changed_tick, query_group)
- query_cache[query_group][bufnr] = {tick=changed_tick, cache=( M.collect_group_results(bufnr, query_group) or {} )}
+ query_cache.set(query_group, bufnr, {tick=changed_tick, cache=( M.collect_group_results(bufnr, query_group) or {} )})
end
function M.get_matches(bufnr, query_group)
local bufnr = bufnr or api.nvim_get_current_buf()
- local cached_local = query_cache[query_group][bufnr]
+ local cached_local = query_cache.get(query_group, bufnr)
if not cached_local or api.nvim_buf_get_changedtick(bufnr) > cached_local.tick then
update_cached_matches(bufnr,api.nvim_buf_get_changedtick(bufnr), query_group)
end
- return query_cache[query_group][bufnr].cache
+ return query_cache.get(query_group, bufnr).cache
end
local function filter_files(file_list)