|
|
@ -890,12 +890,12 @@ mod cmd {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
fn write(editor: &mut Editor, args: &[&str], event: PromptEvent) {
|
|
|
|
fn write(editor: &mut Editor, args: &[&str], event: PromptEvent) {
|
|
|
|
let id = editor.view().doc;
|
|
|
|
let (view, doc) = editor.current();
|
|
|
|
let doc = &mut editor.documents[id];
|
|
|
|
|
|
|
|
if doc.path().is_none() {
|
|
|
|
if doc.path().is_none() {
|
|
|
|
editor.set_error("cannot write a buffer without a filename".to_string());
|
|
|
|
editor.set_error("cannot write a buffer without a filename".to_string());
|
|
|
|
return;
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
doc.format(view.id); // TODO: merge into save
|
|
|
|
tokio::spawn(doc.save());
|
|
|
|
tokio::spawn(doc.save());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -906,25 +906,7 @@ mod cmd {
|
|
|
|
fn format(editor: &mut Editor, args: &[&str], event: PromptEvent) {
|
|
|
|
fn format(editor: &mut Editor, args: &[&str], event: PromptEvent) {
|
|
|
|
let (view, doc) = editor.current();
|
|
|
|
let (view, doc) = editor.current();
|
|
|
|
|
|
|
|
|
|
|
|
if let Some(language_server) = doc.language_server() {
|
|
|
|
doc.format(view.id)
|
|
|
|
// TODO: await, no blocking
|
|
|
|
|
|
|
|
let transaction = helix_lsp::block_on(
|
|
|
|
|
|
|
|
language_server
|
|
|
|
|
|
|
|
.text_document_formatting(doc.identifier(), lsp::FormattingOptions::default()),
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
.map(|edits| {
|
|
|
|
|
|
|
|
helix_lsp::util::generate_transaction_from_edits(
|
|
|
|
|
|
|
|
doc.text(),
|
|
|
|
|
|
|
|
edits,
|
|
|
|
|
|
|
|
language_server.offset_encoding(),
|
|
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if let Ok(transaction) = transaction {
|
|
|
|
|
|
|
|
doc.apply(&transaction, view.id);
|
|
|
|
|
|
|
|
doc.append_changes_to_history(view.id);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub const COMMAND_LIST: &[Command] = &[
|
|
|
|
pub const COMMAND_LIST: &[Command] = &[
|
|
|
@ -2277,7 +2259,8 @@ pub fn space_mode(cx: &mut Context) {
|
|
|
|
'v' => vsplit(cx),
|
|
|
|
'v' => vsplit(cx),
|
|
|
|
'w' => {
|
|
|
|
'w' => {
|
|
|
|
// save current buffer
|
|
|
|
// save current buffer
|
|
|
|
let doc = cx.doc();
|
|
|
|
let (view, doc) = cx.current();
|
|
|
|
|
|
|
|
doc.format(view.id); // TODO: merge into save
|
|
|
|
tokio::spawn(doc.save());
|
|
|
|
tokio::spawn(doc.save());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
'c' => {
|
|
|
|
'c' => {
|
|
|
|