2020-06-02 09:57:01 +08:00
|
|
|
#![allow(unused)]
|
2021-03-22 11:18:48 +08:00
|
|
|
pub mod auto_pairs;
|
2021-02-18 17:35:39 +08:00
|
|
|
pub mod comment;
|
2021-03-11 15:31:49 +08:00
|
|
|
pub mod diagnostic;
|
2020-09-10 12:55:18 +08:00
|
|
|
pub mod graphemes;
|
2020-10-04 16:15:43 +08:00
|
|
|
mod history;
|
2020-10-14 11:01:41 +08:00
|
|
|
pub mod indent;
|
2020-09-21 17:24:16 +08:00
|
|
|
pub mod macros;
|
2021-03-22 16:58:49 +08:00
|
|
|
pub mod match_brackets;
|
2021-03-18 12:39:34 +08:00
|
|
|
pub mod movement;
|
2021-02-22 14:50:41 +08:00
|
|
|
pub mod object;
|
2020-09-17 13:57:49 +08:00
|
|
|
mod position;
|
2020-10-06 15:00:23 +08:00
|
|
|
pub mod register;
|
2021-03-11 09:44:38 +08:00
|
|
|
pub mod search;
|
2020-09-29 00:01:27 +08:00
|
|
|
pub mod selection;
|
2021-05-30 16:52:46 +08:00
|
|
|
mod state;
|
2020-09-12 18:36:49 +08:00
|
|
|
pub mod syntax;
|
2020-05-25 12:02:21 +08:00
|
|
|
mod transaction;
|
2020-05-20 17:14:51 +08:00
|
|
|
|
2021-02-18 17:34:22 +08:00
|
|
|
pub(crate) fn find_first_non_whitespace_char2(line: RopeSlice) -> Option<usize> {
|
|
|
|
// find first non-whitespace char
|
2021-02-18 17:45:41 +08:00
|
|
|
for (start, ch) in line.chars().enumerate() {
|
2021-02-18 17:34:22 +08:00
|
|
|
// TODO: could use memchr with chunks?
|
|
|
|
if ch != ' ' && ch != '\t' && ch != '\n' {
|
|
|
|
return Some(start);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
None
|
|
|
|
}
|
|
|
|
pub(crate) fn find_first_non_whitespace_char(text: RopeSlice, line_num: usize) -> Option<usize> {
|
|
|
|
let line = text.line(line_num);
|
|
|
|
let mut start = text.line_to_char(line_num);
|
|
|
|
|
|
|
|
// find first non-whitespace char
|
|
|
|
for ch in line.chars() {
|
|
|
|
// TODO: could use memchr with chunks?
|
|
|
|
if ch != ' ' && ch != '\t' && ch != '\n' {
|
|
|
|
return Some(start);
|
|
|
|
}
|
|
|
|
start += 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
None
|
|
|
|
}
|
|
|
|
|
2021-05-10 00:02:53 +08:00
|
|
|
pub fn runtime_dir() -> std::path::PathBuf {
|
|
|
|
// runtime env var || dir where binary is located
|
|
|
|
std::env::var("HELIX_RUNTIME")
|
|
|
|
.map(|path| path.into())
|
|
|
|
.unwrap_or_else(|_| {
|
|
|
|
std::env::current_exe()
|
|
|
|
.ok()
|
|
|
|
.and_then(|path| path.parent().map(|path| path.to_path_buf()))
|
|
|
|
.unwrap()
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
2021-04-07 22:56:20 +08:00
|
|
|
pub fn config_dir() -> std::path::PathBuf {
|
|
|
|
// TODO: allow env var override
|
2021-05-10 15:21:55 +08:00
|
|
|
let strategy = choose_base_strategy().expect("Unable to find the config directory!");
|
|
|
|
let mut path = strategy.config_dir();
|
|
|
|
path.push("helix");
|
|
|
|
path
|
2021-04-07 22:56:20 +08:00
|
|
|
}
|
|
|
|
|
2021-06-03 00:19:56 +08:00
|
|
|
pub fn cache_dir() -> std::path::PathBuf {
|
|
|
|
// TODO: allow env var override
|
|
|
|
let strategy = choose_base_strategy().expect("Unable to find the config directory!");
|
|
|
|
let mut path = strategy.cache_dir();
|
|
|
|
path.push("helix");
|
|
|
|
path
|
|
|
|
}
|
|
|
|
|
|
|
|
use etcetera::base_strategy::{choose_base_strategy, BaseStrategy};
|
|
|
|
|
2020-06-05 13:02:10 +08:00
|
|
|
pub use ropey::{Rope, RopeSlice};
|
2020-09-29 00:00:35 +08:00
|
|
|
|
2020-05-28 13:45:44 +08:00
|
|
|
pub use tendril::StrTendril as Tendril;
|
|
|
|
|
2020-09-29 00:01:27 +08:00
|
|
|
#[doc(inline)]
|
|
|
|
pub use {regex, tree_sitter};
|
|
|
|
|
2021-03-18 12:39:34 +08:00
|
|
|
pub use position::{coords_at_pos, pos_at_coords, Position};
|
2021-03-22 11:40:07 +08:00
|
|
|
pub use selection::{Range, Selection};
|
2021-04-01 10:01:11 +08:00
|
|
|
pub use smallvec::SmallVec;
|
2020-09-17 13:57:49 +08:00
|
|
|
pub use syntax::Syntax;
|
2020-05-25 12:02:21 +08:00
|
|
|
|
2020-10-20 12:58:34 +08:00
|
|
|
pub use diagnostic::Diagnostic;
|
2020-10-04 16:15:43 +08:00
|
|
|
pub use history::History;
|
2020-05-25 12:02:21 +08:00
|
|
|
pub use state::State;
|
|
|
|
|
2020-10-23 17:48:03 +08:00
|
|
|
pub use transaction::{Assoc, Change, ChangeSet, Operation, Transaction};
|