Move group_label where it belongs

This commit is contained in:
Aleksey Kladov 2020-05-05 20:42:52 +02:00
parent 6c2414430a
commit aee22c73c3
2 changed files with 6 additions and 7 deletions

View file

@ -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 {

View file

@ -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,
} }