2019-09-30 08:58:53 +00:00
|
|
|
//! FIXME: write short doc here
|
|
|
|
|
2020-02-06 11:52:32 +00:00
|
|
|
use either::Either;
|
|
|
|
use ra_assists::{AssistAction, AssistLabel};
|
2019-07-04 20:05:17 +00:00
|
|
|
use ra_db::{FilePosition, FileRange};
|
2020-02-06 15:26:43 +00:00
|
|
|
use ra_ide_db::{imports_locator::ImportsLocatorIde, RootDatabase};
|
2020-02-06 11:52:32 +00:00
|
|
|
|
2020-02-06 15:26:43 +00:00
|
|
|
use crate::{FileId, SourceChange, SourceFileEdit};
|
2019-02-03 18:26:35 +00:00
|
|
|
|
2019-02-24 10:53:35 +00:00
|
|
|
pub use ra_assists::AssistId;
|
|
|
|
|
|
|
|
#[derive(Debug)]
|
|
|
|
pub struct Assist {
|
|
|
|
pub id: AssistId,
|
2020-01-01 23:39:01 +00:00
|
|
|
pub label: String,
|
2020-01-11 22:40:36 +00:00
|
|
|
pub change_data: Either<SourceChange, Vec<SourceChange>>,
|
2019-02-24 10:53:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
pub(crate) fn assists(db: &RootDatabase, frange: FileRange) -> Vec<Assist> {
|
2019-12-24 00:19:09 +00:00
|
|
|
ra_assists::assists_with_imports_locator(db, frange, ImportsLocatorIde::new(db))
|
2019-02-03 18:26:35 +00:00
|
|
|
.into_iter()
|
2020-01-11 22:40:36 +00:00
|
|
|
.map(|assist| {
|
2019-02-03 18:26:35 +00:00
|
|
|
let file_id = frange.file_id;
|
2020-01-11 22:40:36 +00:00
|
|
|
let assist_label = &assist.label;
|
2020-01-01 23:39:01 +00:00
|
|
|
Assist {
|
|
|
|
id: assist_label.id,
|
|
|
|
label: assist_label.label.clone(),
|
2020-01-11 22:40:36 +00:00
|
|
|
change_data: match assist.action_data {
|
|
|
|
Either::Left(action) => {
|
|
|
|
Either::Left(action_to_edit(action, file_id, assist_label))
|
|
|
|
}
|
|
|
|
Either::Right(actions) => Either::Right(
|
|
|
|
actions
|
|
|
|
.into_iter()
|
|
|
|
.map(|action| action_to_edit(action, file_id, assist_label))
|
|
|
|
.collect(),
|
|
|
|
),
|
|
|
|
},
|
2020-01-01 23:39:01 +00:00
|
|
|
}
|
2019-02-03 18:26:35 +00:00
|
|
|
})
|
2019-02-03 16:27:36 +00:00
|
|
|
.collect()
|
|
|
|
}
|
2020-01-01 23:39:01 +00:00
|
|
|
|
|
|
|
fn action_to_edit(
|
|
|
|
action: AssistAction,
|
|
|
|
file_id: FileId,
|
|
|
|
assist_label: &AssistLabel,
|
|
|
|
) -> SourceChange {
|
|
|
|
let file_edit = SourceFileEdit { file_id, edit: action.edit };
|
|
|
|
SourceChange::source_file_edit(
|
|
|
|
action.label.unwrap_or_else(|| assist_label.label.clone()),
|
|
|
|
file_edit,
|
|
|
|
)
|
|
|
|
.with_cursor_opt(action.cursor_position.map(|offset| FilePosition { offset, file_id }))
|
|
|
|
}
|