aboutsummaryrefslogtreecommitdiff
path: root/src/tree_sitter/get_changed_ranges.h
diff options
context:
space:
mode:
authorBjörn Linse <bjorn.linse@gmail.com>2019-09-28 18:35:02 +0200
committerGitHub <noreply@github.com>2019-09-28 18:35:02 +0200
commite933426299b44db6715f6f61ab76aee57478110e (patch)
treeffca71781f4e06460fa9b98be68cb02a23d5e0bd /src/tree_sitter/get_changed_ranges.h
parent0d9a3c86a1c7143187398e6cb6005ed06a5e2fde (diff)
parent9fa850991dbe8984996afdc149b5b32dc248197e (diff)
downloadrneovim-e933426299b44db6715f6f61ab76aee57478110e.tar.gz
rneovim-e933426299b44db6715f6f61ab76aee57478110e.tar.bz2
rneovim-e933426299b44db6715f6f61ab76aee57478110e.zip
Merge pull request #10124 from bfredl/tree-sitter-api
Tree-sitter step 1: vendor runtime lib + add lua API
Diffstat (limited to 'src/tree_sitter/get_changed_ranges.h')
-rw-r--r--src/tree_sitter/get_changed_ranges.h36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/tree_sitter/get_changed_ranges.h b/src/tree_sitter/get_changed_ranges.h
new file mode 100644
index 0000000000..a1f1dbb430
--- /dev/null
+++ b/src/tree_sitter/get_changed_ranges.h
@@ -0,0 +1,36 @@
+#ifndef TREE_SITTER_GET_CHANGED_RANGES_H_
+#define TREE_SITTER_GET_CHANGED_RANGES_H_
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include "./tree_cursor.h"
+#include "./subtree.h"
+
+typedef Array(TSRange) TSRangeArray;
+
+void ts_range_array_get_changed_ranges(
+ const TSRange *old_ranges, unsigned old_range_count,
+ const TSRange *new_ranges, unsigned new_range_count,
+ TSRangeArray *differences
+);
+
+bool ts_range_array_intersects(
+ const TSRangeArray *self, unsigned start_index,
+ uint32_t start_byte, uint32_t end_byte
+);
+
+unsigned ts_subtree_get_changed_ranges(
+ const Subtree *old_tree, const Subtree *new_tree,
+ TreeCursor *cursor1, TreeCursor *cursor2,
+ const TSLanguage *language,
+ const TSRangeArray *included_range_differences,
+ TSRange **ranges
+);
+
+#ifdef __cplusplus
+}
+#endif
+
+#endif // TREE_SITTER_GET_CHANGED_RANGES_H_