mirror of
https://github.com/helix-editor/helix.git
synced 2025-04-04 11:27:46 +03:00
Include macro attributes to impls, structs, enums, functions etc. textobjects (#2494)
This commit is contained in:
parent
301ed9b48f
commit
62fd1f6999
2 changed files with 76 additions and 35 deletions
|
@ -234,6 +234,7 @@ pub struct TextObjectQuery {
|
||||||
pub query: Query,
|
pub query: Query,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Debug)]
|
||||||
pub enum CapturedNode<'a> {
|
pub enum CapturedNode<'a> {
|
||||||
Single(Node<'a>),
|
Single(Node<'a>),
|
||||||
/// Guaranteed to be not empty
|
/// Guaranteed to be not empty
|
||||||
|
@ -268,12 +269,12 @@ impl TextObjectQuery {
|
||||||
/// and support for this is partial and could use improvement.
|
/// and support for this is partial and could use improvement.
|
||||||
///
|
///
|
||||||
/// ```query
|
/// ```query
|
||||||
/// ;; supported:
|
|
||||||
/// (comment)+ @capture
|
/// (comment)+ @capture
|
||||||
///
|
///
|
||||||
/// ;; unsupported:
|
/// ; OR
|
||||||
/// (
|
/// (
|
||||||
/// (comment)+
|
/// (comment)*
|
||||||
|
/// .
|
||||||
/// (function)
|
/// (function)
|
||||||
/// ) @capture
|
/// ) @capture
|
||||||
/// ```
|
/// ```
|
||||||
|
@ -299,28 +300,29 @@ impl TextObjectQuery {
|
||||||
let capture_idx = capture_names
|
let capture_idx = capture_names
|
||||||
.iter()
|
.iter()
|
||||||
.find_map(|cap| self.query.capture_index_for_name(cap))?;
|
.find_map(|cap| self.query.capture_index_for_name(cap))?;
|
||||||
let captures = cursor.matches(&self.query, node, RopeProvider(slice));
|
|
||||||
|
|
||||||
let nodes = captures.flat_map(move |mat| {
|
let nodes = cursor
|
||||||
let captures = mat.captures.iter().filter(move |c| c.index == capture_idx);
|
.captures(&self.query, node, RopeProvider(slice))
|
||||||
let nodes = captures.map(|c| c.node);
|
.filter_map(move |(mat, _)| {
|
||||||
let pattern_idx = mat.pattern_index;
|
let nodes: Vec<_> = mat
|
||||||
let quantifier = self.query.capture_quantifiers(pattern_idx)[capture_idx as usize];
|
.captures
|
||||||
|
.iter()
|
||||||
|
.filter_map(|x| {
|
||||||
|
if x.index == capture_idx {
|
||||||
|
Some(x.node)
|
||||||
|
} else {
|
||||||
|
None
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.collect();
|
||||||
|
|
||||||
let iter: Box<dyn Iterator<Item = CapturedNode>> = match quantifier {
|
if nodes.len() > 1 {
|
||||||
CaptureQuantifier::OneOrMore | CaptureQuantifier::ZeroOrMore => {
|
Some(CapturedNode::Grouped(nodes))
|
||||||
let nodes: Vec<Node> = nodes.collect();
|
} else {
|
||||||
if nodes.is_empty() {
|
nodes.into_iter().map(CapturedNode::Single).next()
|
||||||
Box::new(std::iter::empty())
|
|
||||||
} else {
|
|
||||||
Box::new(std::iter::once(CapturedNode::Grouped(nodes)))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
_ => Box::new(nodes.map(CapturedNode::Single)),
|
});
|
||||||
};
|
|
||||||
|
|
||||||
iter
|
|
||||||
});
|
|
||||||
Some(nodes)
|
Some(nodes)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1122,8 +1124,8 @@ pub(crate) fn generate_edits(
|
||||||
use std::sync::atomic::{AtomicUsize, Ordering};
|
use std::sync::atomic::{AtomicUsize, Ordering};
|
||||||
use std::{iter, mem, ops, str, usize};
|
use std::{iter, mem, ops, str, usize};
|
||||||
use tree_sitter::{
|
use tree_sitter::{
|
||||||
CaptureQuantifier, Language as Grammar, Node, Parser, Point, Query, QueryCaptures, QueryCursor,
|
Language as Grammar, Node, Parser, Point, Query, QueryCaptures, QueryCursor, QueryError,
|
||||||
QueryError, QueryMatch, Range, TextProvider, Tree,
|
QueryMatch, Range, TextProvider, Tree,
|
||||||
};
|
};
|
||||||
|
|
||||||
const CANCELLATION_CHECK_INTERVAL: usize = 100;
|
const CANCELLATION_CHECK_INTERVAL: usize = 100;
|
||||||
|
|
|
@ -1,23 +1,62 @@
|
||||||
(function_item
|
(
|
||||||
body: (_) @function.inside) @function.around
|
[
|
||||||
|
(attribute_item)+
|
||||||
|
(line_comment)+
|
||||||
|
]*
|
||||||
|
.
|
||||||
|
(function_item
|
||||||
|
body: (_) @function.inside)) @function.around
|
||||||
|
|
||||||
(struct_item
|
(
|
||||||
body: (_) @class.inside) @class.around
|
[
|
||||||
|
(attribute_item)+
|
||||||
|
(line_comment)+
|
||||||
|
]*
|
||||||
|
.
|
||||||
|
(struct_item
|
||||||
|
body: (_) @class.inside)) @class.around
|
||||||
|
|
||||||
(enum_item
|
(
|
||||||
body: (_) @class.inside) @class.around
|
[
|
||||||
|
(attribute_item)+
|
||||||
|
(line_comment)+
|
||||||
|
]*
|
||||||
|
.
|
||||||
|
(enum_item
|
||||||
|
body: (_) @class.inside)) @class.around
|
||||||
|
|
||||||
(union_item
|
(
|
||||||
body: (_) @class.inside) @class.around
|
[
|
||||||
|
(attribute_item)+
|
||||||
|
(line_comment)+
|
||||||
|
]*
|
||||||
|
.
|
||||||
|
(union_item
|
||||||
|
body: (_) @class.inside)) @class.around
|
||||||
|
|
||||||
(trait_item
|
(
|
||||||
body: (_) @class.inside) @class.around
|
[
|
||||||
|
(attribute_item)+
|
||||||
|
(line_comment)+
|
||||||
|
]*
|
||||||
|
.
|
||||||
|
(trait_item
|
||||||
|
body: (_) @class.inside)) @class.around
|
||||||
|
|
||||||
(impl_item
|
(
|
||||||
body: (_) @class.inside) @class.around
|
[
|
||||||
|
(attribute_item)+
|
||||||
|
(line_comment)+
|
||||||
|
]*
|
||||||
|
.
|
||||||
|
(impl_item
|
||||||
|
body: (_) @class.inside)) @class.around
|
||||||
|
|
||||||
(parameters
|
(parameters
|
||||||
(_) @parameter.inside)
|
(_) @parameter.inside)
|
||||||
|
|
||||||
|
(type_parameters
|
||||||
|
(_) @parameter.inside)
|
||||||
|
|
||||||
(closure_parameters
|
(closure_parameters
|
||||||
(_) @parameter.inside)
|
(_) @parameter.inside)
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue