add buffer_dir expansion value

This commit is contained in:
Yudjinn 2025-02-27 11:41:00 -07:00
parent 0efa8207d8
commit d8b68b79dd
2 changed files with 20 additions and 0 deletions

View file

@ -46,6 +46,7 @@ The following variables are supported:
| `cursor_line` | The line number of the primary cursor in the currently focused document, starting at 1. |
| `cursor_column` | The column number of the primary cursor in the currently focused document, starting at 1. This is counted as the number of grapheme clusters from the start of the line rather than bytes or codepoints. |
| `buffer_name` | The relative path of the currently focused document. `[scratch]` is expanded instead for scratch buffers. |
| `buffer_dir` | The path of the directory containing the currently focused document. Returns current working dir for scratch buffers and failures to evaluate parent. |
| `line_ending` | A string containing the line ending of the currently focused document. For example on Unix systems this is usually a line-feed character (`\n`) but on Windows systems this may be a carriage-return plus a line-feed (`\r\n`). The line ending kind of the currently focused document can be inspected with the `:line-ending` command. |
Aside from editor variables, the following expansions may be used:

View file

@ -31,6 +31,8 @@ pub enum Variable {
///
/// This corresponds to `crate::Document::display_name`.
BufferName,
/// The directory name housing the currently focused document.
BufferDir,
/// A string containing the line-ending of the currently focused document.
LineEnding,
}
@ -40,6 +42,7 @@ impl Variable {
Self::CursorLine,
Self::CursorColumn,
Self::BufferName,
Self::BufferDir,
Self::LineEnding,
];
@ -48,6 +51,7 @@ impl Variable {
Self::CursorLine => "cursor_line",
Self::CursorColumn => "cursor_column",
Self::BufferName => "buffer_name",
Self::BufferDir => "buffer_dir",
Self::LineEnding => "line_ending",
}
}
@ -57,6 +61,7 @@ impl Variable {
"cursor_line" => Some(Self::CursorLine),
"cursor_column" => Some(Self::CursorColumn),
"buffer_name" => Some(Self::BufferName),
"buffer_dir" => Some(Self::BufferDir),
"line_ending" => Some(Self::LineEnding),
_ => None,
}
@ -214,6 +219,20 @@ fn expand_variable(editor: &Editor, variable: Variable) -> Result<Cow<'static, s
Ok(Cow::Borrowed(crate::document::SCRATCH_BUFFER_NAME))
}
}
Variable::BufferDir => {
// This follows the partial reimpl of `display_name` from `Variable::BufferName`
if let Some(path) = doc.relative_path() {
if let Some(dir_path) = path.parent() {
return Ok(Cow::Owned(dir_path.to_string_lossy().into_owned()));
};
};
// Default to current working dir for scratch buffers and files with no parent dir
Ok(Cow::Owned(
helix_stdx::env::current_working_dir()
.to_string_lossy()
.into_owned(),
))
}
Variable::LineEnding => Ok(Cow::Borrowed(doc.line_ending.as_str())),
}
}