mirror of
https://github.com/helix-editor/helix.git
synced 2024-11-22 17:36:19 +04:00
commands: Implement expand_selection.
This commit is contained in:
parent
33c67f1388
commit
6cfb1acb9d
@ -5,6 +5,7 @@
|
|||||||
mod history;
|
mod history;
|
||||||
pub mod indent;
|
pub mod indent;
|
||||||
pub mod macros;
|
pub mod macros;
|
||||||
|
pub mod object;
|
||||||
mod position;
|
mod position;
|
||||||
pub mod register;
|
pub mod register;
|
||||||
pub mod selection;
|
pub mod selection;
|
||||||
|
32
helix-core/src/object.rs
Normal file
32
helix-core/src/object.rs
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
use crate::{Range, RopeSlice, Selection, Syntax};
|
||||||
|
use smallvec::smallvec;
|
||||||
|
|
||||||
|
// TODO: to contract_selection we'd need to store the previous ranges before expand.
|
||||||
|
// Maybe just contract to the first child node?
|
||||||
|
pub fn expand_selection(syntax: &Syntax, text: RopeSlice, selection: &Selection) -> Selection {
|
||||||
|
let tree = syntax.root_layer.tree.as_ref().unwrap();
|
||||||
|
|
||||||
|
selection.transform(|range| {
|
||||||
|
let from = text.char_to_byte(range.from());
|
||||||
|
let to = text.char_to_byte(range.to());
|
||||||
|
|
||||||
|
// find parent of a descendant that matches the range
|
||||||
|
let parent = match tree
|
||||||
|
.root_node()
|
||||||
|
.descendant_for_byte_range(from, to)
|
||||||
|
.and_then(|node| node.parent())
|
||||||
|
{
|
||||||
|
Some(parent) => parent,
|
||||||
|
None => return range,
|
||||||
|
};
|
||||||
|
|
||||||
|
let from = text.byte_to_char(parent.start_byte());
|
||||||
|
let to = text.byte_to_char(parent.end_byte());
|
||||||
|
|
||||||
|
if range.head < range.anchor {
|
||||||
|
Range::new(to, from)
|
||||||
|
} else {
|
||||||
|
Range::new(from, to)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
@ -1,6 +1,7 @@
|
|||||||
use helix_core::{
|
use helix_core::{
|
||||||
comment, graphemes,
|
comment, graphemes,
|
||||||
indent::TAB_WIDTH,
|
indent::TAB_WIDTH,
|
||||||
|
object,
|
||||||
regex::{self, Regex},
|
regex::{self, Regex},
|
||||||
register, selection,
|
register, selection,
|
||||||
state::{Direction, Granularity, State},
|
state::{Direction, Granularity, State},
|
||||||
@ -1023,3 +1024,15 @@ pub fn toggle_comments(cx: &mut Context) {
|
|||||||
|
|
||||||
doc.apply(&transaction);
|
doc.apply(&transaction);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// tree sitter node selection
|
||||||
|
|
||||||
|
pub fn expand_selection(cx: &mut Context) {
|
||||||
|
let doc = cx.doc();
|
||||||
|
|
||||||
|
if let Some(syntax) = &doc.syntax {
|
||||||
|
let text = doc.text().slice(..);
|
||||||
|
let selection = object::expand_selection(syntax, text, doc.selection());
|
||||||
|
doc.set_selection(selection);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
@ -164,10 +164,11 @@ pub fn default() -> Keymaps {
|
|||||||
vec![alt!('s')] => commands::split_selection_on_newline,
|
vec![alt!('s')] => commands::split_selection_on_newline,
|
||||||
vec![shift!('S')] => commands::split_selection,
|
vec![shift!('S')] => commands::split_selection,
|
||||||
vec![key!(';')] => commands::collapse_selection,
|
vec![key!(';')] => commands::collapse_selection,
|
||||||
// TODO should be alt(;)
|
|
||||||
vec![alt!(';')] => commands::flip_selections,
|
vec![alt!(';')] => commands::flip_selections,
|
||||||
vec![key!('%')] => commands::select_all,
|
vec![key!('%')] => commands::select_all,
|
||||||
vec![key!('x')] => commands::select_line,
|
vec![key!('x')] => commands::select_line,
|
||||||
|
// TODO: figure out what key to use
|
||||||
|
vec![key!('[')] => commands::expand_selection,
|
||||||
vec![key!('/')] => commands::search,
|
vec![key!('/')] => commands::search,
|
||||||
vec![key!('n')] => commands::search_next,
|
vec![key!('n')] => commands::search_next,
|
||||||
vec![key!('*')] => commands::search_selection,
|
vec![key!('*')] => commands::search_selection,
|
||||||
|
Loading…
Reference in New Issue
Block a user