Skip to content

Commit 7a2eebd

Browse files
committed
Add initial_contents field for CreateFile
1 parent 414576f commit 7a2eebd

File tree

5 files changed

+47
-50
lines changed

5 files changed

+47
-50
lines changed

crates/assists/src/assist_context.rs

Lines changed: 2 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -285,10 +285,9 @@ impl AssistBuilder {
285285
}
286286
}
287287
pub(crate) fn create_file(&mut self, dst: AnchoredPathBuf, content: impl Into<String>) {
288-
let file_system_edit = FileSystemEdit::CreateFile { dst: dst.clone() };
288+
let file_system_edit =
289+
FileSystemEdit::CreateFile { dst: dst.clone(), initial_contents: content.into() };
289290
self.file_system_edits.push(file_system_edit);
290-
self.edit_file(dst.anchor);
291-
self.insert(TextSize::from(0), content)
292291
}
293292

294293
fn finish(mut self) -> SourceChange {

crates/assists/src/tests.rs

Lines changed: 16 additions & 36 deletions
Original file line numberDiff line numberDiff line change
@@ -107,47 +107,27 @@ fn check(handler: Handler, before: &str, expected: ExpectedResult, assist_label:
107107
&& source_change.file_system_edits.len() == 0;
108108
source_change.source_file_edits.sort_by_key(|it| it.file_id);
109109

110-
let mut created_file_ids = Vec::new();
111110
let mut buf = String::new();
112-
for file_system_edit in source_change.file_system_edits.clone() {
113-
match file_system_edit {
114-
FileSystemEdit::CreateFile { dst } => {
115-
created_file_ids.push(dst.anchor);
116-
}
117-
_ => (),
111+
for source_file_edit in source_change.source_file_edits {
112+
let mut text = db.file_text(source_file_edit.file_id).as_ref().to_owned();
113+
source_file_edit.edit.apply(&mut text);
114+
if !skip_header {
115+
let sr = db.file_source_root(source_file_edit.file_id);
116+
let sr = db.source_root(sr);
117+
let path = sr.path_for_file(&source_file_edit.file_id).unwrap();
118+
format_to!(buf, "//- {}\n", path)
118119
}
120+
buf.push_str(&text);
119121
}
120122

121-
for source_file_edit in source_change.source_file_edits {
122-
if created_file_ids.contains(&source_file_edit.file_id) {
123-
let target_dst = source_change
124-
.file_system_edits
125-
.iter()
126-
.find_map(|f| match f {
127-
FileSystemEdit::CreateFile { dst } => {
128-
if dst.anchor == source_file_edit.file_id {
129-
Some(&dst.path)
130-
} else {
131-
None
132-
}
133-
}
134-
_ => None,
135-
})
136-
.unwrap();
137-
format_to!(buf, "//- {}\n", target_dst);
138-
let mut text = String::new();
139-
source_file_edit.edit.apply(&mut text);
140-
buf.push_str(&text);
141-
} else {
142-
let mut text = db.file_text(source_file_edit.file_id).as_ref().to_owned();
143-
source_file_edit.edit.apply(&mut text);
144-
if !skip_header {
145-
let sr = db.file_source_root(source_file_edit.file_id);
146-
let sr = db.source_root(sr);
147-
let path = sr.path_for_file(&source_file_edit.file_id).unwrap();
148-
format_to!(buf, "//- {}\n", path)
123+
for file_system_edit in source_change.file_system_edits.clone() {
124+
match file_system_edit {
125+
FileSystemEdit::CreateFile { dst, initial_contents } => {
126+
let target_dst = dst.path;
127+
format_to!(buf, "//- {}\n", target_dst);
128+
buf.push_str(&initial_contents);
149129
}
150-
buf.push_str(&text);
130+
_ => (),
151131
}
152132
}
153133

crates/ide/src/diagnostics/fixes.rs

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -40,6 +40,7 @@ impl DiagnosticWithFix for UnresolvedModule {
4040
anchor: self.file.original_file(sema.db),
4141
path: self.candidate.clone(),
4242
},
43+
initial_contents: "".to_string(),
4344
}
4445
.into(),
4546
unresolved_module.syntax().text_range(),

crates/ide_db/src/source_change.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -44,7 +44,7 @@ impl From<Vec<SourceFileEdit>> for SourceChange {
4444

4545
#[derive(Debug, Clone)]
4646
pub enum FileSystemEdit {
47-
CreateFile { dst: AnchoredPathBuf },
47+
CreateFile { dst: AnchoredPathBuf, initial_contents: String },
4848
MoveFile { src: FileId, dst: AnchoredPathBuf },
4949
}
5050

crates/rust-analyzer/src/to_proto.rs

Lines changed: 27 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -634,30 +634,47 @@ pub(crate) fn snippet_text_document_edit(
634634
Ok(lsp_ext::SnippetTextDocumentEdit { text_document, edits })
635635
}
636636

637-
pub(crate) fn resource_op(
637+
pub(crate) fn snippet_text_document_ops(
638638
snap: &GlobalStateSnapshot,
639639
file_system_edit: FileSystemEdit,
640-
) -> lsp_types::ResourceOp {
640+
) -> Vec<lsp_ext::SnippetDocumentChangeOperation> {
641+
let mut ops = Vec::new();
641642
match file_system_edit {
642-
FileSystemEdit::CreateFile { dst } => {
643+
FileSystemEdit::CreateFile { dst, initial_contents } => {
643644
let uri = snap.anchored_path(&dst);
644-
lsp_types::ResourceOp::Create(lsp_types::CreateFile {
645-
uri,
645+
let create_file = lsp_types::ResourceOp::Create(lsp_types::CreateFile {
646+
uri: uri.clone(),
646647
options: None,
647648
annotation_id: None,
648-
})
649+
});
650+
ops.push(lsp_ext::SnippetDocumentChangeOperation::Op(create_file));
651+
if !initial_contents.is_empty() {
652+
let text_document =
653+
lsp_types::OptionalVersionedTextDocumentIdentifier { uri, version: None };
654+
let range = range(&LineIndex::new(""), TextRange::empty(TextSize::from(0)));
655+
let text_edit = lsp_ext::SnippetTextEdit {
656+
range,
657+
new_text: initial_contents,
658+
insert_text_format: Some(lsp_types::InsertTextFormat::PlainText),
659+
};
660+
let edit_file =
661+
lsp_ext::SnippetTextDocumentEdit { text_document, edits: vec![text_edit] };
662+
ops.push(lsp_ext::SnippetDocumentChangeOperation::Edit(edit_file));
663+
}
649664
}
650665
FileSystemEdit::MoveFile { src, dst } => {
651666
let old_uri = snap.file_id_to_url(src);
652667
let new_uri = snap.anchored_path(&dst);
653-
lsp_types::ResourceOp::Rename(lsp_types::RenameFile {
668+
let rename_file = lsp_types::ResourceOp::Rename(lsp_types::RenameFile {
654669
old_uri,
655670
new_uri,
656671
options: None,
657672
annotation_id: None,
658-
})
673+
});
674+
ops.push(lsp_ext::SnippetDocumentChangeOperation::Op(rename_file))
659675
}
660676
}
677+
ops
661678
}
662679

663680
pub(crate) fn snippet_workspace_edit(
@@ -666,8 +683,8 @@ pub(crate) fn snippet_workspace_edit(
666683
) -> Result<lsp_ext::SnippetWorkspaceEdit> {
667684
let mut document_changes: Vec<lsp_ext::SnippetDocumentChangeOperation> = Vec::new();
668685
for op in source_change.file_system_edits {
669-
let op = resource_op(&snap, op);
670-
document_changes.push(lsp_ext::SnippetDocumentChangeOperation::Op(op));
686+
let ops = snippet_text_document_ops(snap, op);
687+
document_changes.extend_from_slice(&ops);
671688
}
672689
for edit in source_change.source_file_edits {
673690
let edit = snippet_text_document_edit(&snap, source_change.is_snippet, edit)?;

0 commit comments

Comments
 (0)