mirror of
https://github.com/rust-lang/rust-analyzer
synced 2025-01-14 22:24:14 +00:00
Move group_label where it belongs
This commit is contained in:
parent
6c2414430a
commit
aee22c73c3
2 changed files with 6 additions and 7 deletions
|
@ -38,8 +38,7 @@ impl AssistInfo {
|
||||||
|
|
||||||
pub(crate) fn into_resolved(self) -> Option<ResolvedAssist> {
|
pub(crate) fn into_resolved(self) -> Option<ResolvedAssist> {
|
||||||
let label = self.label;
|
let label = self.label;
|
||||||
let group_label = self.group_label;
|
self.action.map(|action| ResolvedAssist { label, action })
|
||||||
self.action.map(|action| ResolvedAssist { label, group_label, action })
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -100,7 +99,7 @@ impl<'a> AssistCtx<'a> {
|
||||||
label: impl Into<String>,
|
label: impl Into<String>,
|
||||||
f: impl FnOnce(&mut ActionBuilder),
|
f: impl FnOnce(&mut ActionBuilder),
|
||||||
) -> Option<Assist> {
|
) -> Option<Assist> {
|
||||||
let label = AssistLabel::new(id, label.into());
|
let label = AssistLabel::new(id, label.into(), None);
|
||||||
|
|
||||||
let mut info = AssistInfo::new(label);
|
let mut info = AssistInfo::new(label);
|
||||||
if self.should_compute_edit {
|
if self.should_compute_edit {
|
||||||
|
@ -158,7 +157,7 @@ impl<'a> AssistGroup<'a> {
|
||||||
label: impl Into<String>,
|
label: impl Into<String>,
|
||||||
f: impl FnOnce(&mut ActionBuilder),
|
f: impl FnOnce(&mut ActionBuilder),
|
||||||
) {
|
) {
|
||||||
let label = AssistLabel::new(id, label.into());
|
let label = AssistLabel::new(id, label.into(), Some(self.group.clone()));
|
||||||
|
|
||||||
let mut info = AssistInfo::new(label).with_group(self.group.clone());
|
let mut info = AssistInfo::new(label).with_group(self.group.clone());
|
||||||
if self.ctx.should_compute_edit {
|
if self.ctx.should_compute_edit {
|
||||||
|
|
|
@ -35,16 +35,17 @@ pub struct AssistLabel {
|
||||||
pub id: AssistId,
|
pub id: AssistId,
|
||||||
/// Short description of the assist, as shown in the UI.
|
/// Short description of the assist, as shown in the UI.
|
||||||
pub label: String,
|
pub label: String,
|
||||||
|
pub group: Option<GroupLabel>,
|
||||||
}
|
}
|
||||||
|
|
||||||
#[derive(Clone, Debug)]
|
#[derive(Clone, Debug)]
|
||||||
pub struct GroupLabel(pub String);
|
pub struct GroupLabel(pub String);
|
||||||
|
|
||||||
impl AssistLabel {
|
impl AssistLabel {
|
||||||
pub(crate) fn new(id: AssistId, label: String) -> AssistLabel {
|
pub(crate) fn new(id: AssistId, label: String, group: Option<GroupLabel>) -> AssistLabel {
|
||||||
// FIXME: make fields private, so that this invariant can't be broken
|
// FIXME: make fields private, so that this invariant can't be broken
|
||||||
assert!(label.starts_with(|c: char| c.is_uppercase()));
|
assert!(label.starts_with(|c: char| c.is_uppercase()));
|
||||||
AssistLabel { label, id }
|
AssistLabel { id, label, group }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -60,7 +61,6 @@ pub struct AssistAction {
|
||||||
#[derive(Debug, Clone)]
|
#[derive(Debug, Clone)]
|
||||||
pub struct ResolvedAssist {
|
pub struct ResolvedAssist {
|
||||||
pub label: AssistLabel,
|
pub label: AssistLabel,
|
||||||
pub group_label: Option<GroupLabel>,
|
|
||||||
pub action: AssistAction,
|
pub action: AssistAction,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue