feat: show current language when no argument is provided (#5895)
This commit is contained in:
parent
a1a6d5f334
commit
78a1e2db60
4 changed files with 15 additions and 4 deletions
|
@ -59,7 +59,7 @@
|
||||||
| `:hsplit-new`, `:hnew` | Open a scratch buffer in a horizontal split. |
|
| `:hsplit-new`, `:hnew` | Open a scratch buffer in a horizontal split. |
|
||||||
| `:tutor` | Open the tutorial. |
|
| `:tutor` | Open the tutorial. |
|
||||||
| `:goto`, `:g` | Goto line number. |
|
| `:goto`, `:g` | Goto line number. |
|
||||||
| `:set-language`, `:lang` | Set the language of current buffer. |
|
| `:set-language`, `:lang` | Set the language of current buffer (show current language if no value specified). |
|
||||||
| `:set-option`, `:set` | Set a config option at runtime.<br>For example to disable smart case search, use `:set search.smart-case false`. |
|
| `:set-option`, `:set` | Set a config option at runtime.<br>For example to disable smart case search, use `:set search.smart-case false`. |
|
||||||
| `:toggle-option`, `:toggle` | Toggle a boolean config option at runtime.<br>For example to toggle smart case search, use `:toggle search.smart-case`. |
|
| `:toggle-option`, `:toggle` | Toggle a boolean config option at runtime.<br>For example to toggle smart case search, use `:toggle search.smart-case`. |
|
||||||
| `:get-option`, `:get` | Get the current value of a config option. |
|
| `:get-option`, `:get` | Get the current value of a config option. |
|
||||||
|
|
|
@ -6,6 +6,7 @@ use crate::job::Job;
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
||||||
use helix_core::encoding;
|
use helix_core::encoding;
|
||||||
|
use helix_view::document::DEFAULT_LANGUAGE_NAME;
|
||||||
use helix_view::editor::{Action, CloseError, ConfigEvent};
|
use helix_view::editor::{Action, CloseError, ConfigEvent};
|
||||||
use serde_json::Value;
|
use serde_json::Value;
|
||||||
use ui::completers::{self, Completer};
|
use ui::completers::{self, Completer};
|
||||||
|
@ -1697,13 +1698,20 @@ fn language(
|
||||||
return Ok(());
|
return Ok(());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if args.is_empty() {
|
||||||
|
let doc = doc!(cx.editor);
|
||||||
|
let language = &doc.language_name().unwrap_or(DEFAULT_LANGUAGE_NAME);
|
||||||
|
cx.editor.set_status(language.to_string());
|
||||||
|
return Ok(());
|
||||||
|
}
|
||||||
|
|
||||||
if args.len() != 1 {
|
if args.len() != 1 {
|
||||||
anyhow::bail!("Bad arguments. Usage: `:set-language language`");
|
anyhow::bail!("Bad arguments. Usage: `:set-language language`");
|
||||||
}
|
}
|
||||||
|
|
||||||
let doc = doc_mut!(cx.editor);
|
let doc = doc_mut!(cx.editor);
|
||||||
|
|
||||||
if args[0] == "text" {
|
if args[0] == DEFAULT_LANGUAGE_NAME {
|
||||||
doc.set_language(None, None)
|
doc.set_language(None, None)
|
||||||
} else {
|
} else {
|
||||||
doc.set_language_by_language_id(&args[0], cx.editor.syn_loader.clone())?;
|
doc.set_language_by_language_id(&args[0], cx.editor.syn_loader.clone())?;
|
||||||
|
@ -2414,7 +2422,7 @@ pub const TYPABLE_COMMAND_LIST: &[TypableCommand] = &[
|
||||||
TypableCommand {
|
TypableCommand {
|
||||||
name: "set-language",
|
name: "set-language",
|
||||||
aliases: &["lang"],
|
aliases: &["lang"],
|
||||||
doc: "Set the language of current buffer.",
|
doc: "Set the language of current buffer (show current language if no value specified).",
|
||||||
fun: language,
|
fun: language,
|
||||||
completer: Some(completers::language),
|
completer: Some(completers::language),
|
||||||
},
|
},
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
use helix_core::{coords_at_pos, encoding, Position};
|
use helix_core::{coords_at_pos, encoding, Position};
|
||||||
use helix_lsp::lsp::DiagnosticSeverity;
|
use helix_lsp::lsp::DiagnosticSeverity;
|
||||||
|
use helix_view::document::DEFAULT_LANGUAGE_NAME;
|
||||||
use helix_view::{
|
use helix_view::{
|
||||||
document::{Mode, SCRATCH_BUFFER_NAME},
|
document::{Mode, SCRATCH_BUFFER_NAME},
|
||||||
graphics::Rect,
|
graphics::Rect,
|
||||||
|
@ -405,7 +406,7 @@ fn render_file_type<F>(context: &mut RenderContext, write: F)
|
||||||
where
|
where
|
||||||
F: Fn(&mut RenderContext, String, Option<Style>) + Copy,
|
F: Fn(&mut RenderContext, String, Option<Style>) + Copy,
|
||||||
{
|
{
|
||||||
let file_type = context.doc.language_name().unwrap_or("text");
|
let file_type = context.doc.language_name().unwrap_or(DEFAULT_LANGUAGE_NAME);
|
||||||
|
|
||||||
write(context, format!(" {} ", file_type), None);
|
write(context, format!(" {} ", file_type), None);
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,6 +39,8 @@ const BUF_SIZE: usize = 8192;
|
||||||
|
|
||||||
const DEFAULT_INDENT: IndentStyle = IndentStyle::Tabs;
|
const DEFAULT_INDENT: IndentStyle = IndentStyle::Tabs;
|
||||||
|
|
||||||
|
pub const DEFAULT_LANGUAGE_NAME: &str = "text";
|
||||||
|
|
||||||
pub const SCRATCH_BUFFER_NAME: &str = "[scratch]";
|
pub const SCRATCH_BUFFER_NAME: &str = "[scratch]";
|
||||||
|
|
||||||
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
|
#[derive(Debug, Copy, Clone, PartialEq, Eq, Hash)]
|
||||||
|
|
Loading…
Add table
Reference in a new issue