9950: Fix codegen for is_method documentation r=yoshuawuyts a=yoshuawuyts

While authoring https://github.com/rust-lang/rust/pull/88154 I realized that the codegen for the `enum_generate_is_method` assist currently generates invalid paths, and used snake case instead of spaces for the docs description. This fixes both issues. Thanks!

Co-authored-by: Yoshua Wuyts <yoshuawuyts@gmail.com>
This commit is contained in:
bors[bot] 2021-08-19 11:31:46 +00:00 committed by GitHub
commit f696fb51c3
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 59 additions and 4 deletions

View file

@ -28,6 +28,8 @@ use crate::{
// //
// impl Version { // impl Version {
// /// Returns `true` if the version is [`Minor`]. // /// Returns `true` if the version is [`Minor`].
// ///
// /// [`Minor`]: Version::Minor
// fn is_minor(&self) -> bool { // fn is_minor(&self) -> bool {
// matches!(self, Self::Minor) // matches!(self, Self::Minor)
// } // }
@ -43,7 +45,8 @@ pub(crate) fn generate_enum_is_method(acc: &mut Assists, ctx: &AssistContext) ->
ast::StructKind::Unit => "", ast::StructKind::Unit => "",
}; };
let enum_lowercase_name = to_lower_snake_case(&parent_enum.name()?.to_string()); let enum_name = parent_enum.name()?;
let enum_lowercase_name = to_lower_snake_case(&enum_name.to_string()).replace('_', " ");
let fn_name = format!("is_{}", &to_lower_snake_case(&variant_name.text())); let fn_name = format!("is_{}", &to_lower_snake_case(&variant_name.text()));
// Return early if we've found an existing new fn // Return early if we've found an existing new fn
@ -57,11 +60,18 @@ pub(crate) fn generate_enum_is_method(acc: &mut Assists, ctx: &AssistContext) ->
|builder| { |builder| {
let vis = parent_enum.visibility().map_or(String::new(), |v| format!("{} ", v)); let vis = parent_enum.visibility().map_or(String::new(), |v| format!("{} ", v));
let method = format!( let method = format!(
" /// Returns `true` if the {} is [`{}`]. " /// Returns `true` if the {} is [`{variant}`].
///
/// [`{variant}`]: {}::{variant}
{}fn {}(&self) -> bool {{ {}fn {}(&self) -> bool {{
matches!(self, Self::{}{}) matches!(self, Self::{variant}{})
}}", }}",
enum_lowercase_name, variant_name, vis, fn_name, variant_name, pattern_suffix, enum_lowercase_name,
enum_name,
vis,
fn_name,
pattern_suffix,
variant = variant_name
); );
add_method_to_adt(builder, &parent_enum, impl_def, &method); add_method_to_adt(builder, &parent_enum, impl_def, &method);
@ -93,6 +103,8 @@ enum Variant {
impl Variant { impl Variant {
/// Returns `true` if the variant is [`Minor`]. /// Returns `true` if the variant is [`Minor`].
///
/// [`Minor`]: Variant::Minor
fn is_minor(&self) -> bool { fn is_minor(&self) -> bool {
matches!(self, Self::Minor) matches!(self, Self::Minor)
} }
@ -137,6 +149,8 @@ enum Variant {
impl Variant { impl Variant {
/// Returns `true` if the variant is [`Minor`]. /// Returns `true` if the variant is [`Minor`].
///
/// [`Minor`]: Variant::Minor
fn is_minor(&self) -> bool { fn is_minor(&self) -> bool {
matches!(self, Self::Minor(..)) matches!(self, Self::Minor(..))
} }
@ -162,6 +176,8 @@ enum Variant {
impl Variant { impl Variant {
/// Returns `true` if the variant is [`Minor`]. /// Returns `true` if the variant is [`Minor`].
///
/// [`Minor`]: Variant::Minor
fn is_minor(&self) -> bool { fn is_minor(&self) -> bool {
matches!(self, Self::Minor { .. }) matches!(self, Self::Minor { .. })
} }
@ -179,6 +195,8 @@ enum Variant { Undefined }
impl Variant { impl Variant {
/// Returns `true` if the variant is [`Undefined`]. /// Returns `true` if the variant is [`Undefined`].
///
/// [`Undefined`]: Variant::Undefined
fn is_undefined(&self) -> bool { fn is_undefined(&self) -> bool {
matches!(self, Self::Undefined) matches!(self, Self::Undefined)
} }
@ -204,6 +222,8 @@ pub(crate) enum Variant {
impl Variant { impl Variant {
/// Returns `true` if the variant is [`Minor`]. /// Returns `true` if the variant is [`Minor`].
///
/// [`Minor`]: Variant::Minor
pub(crate) fn is_minor(&self) -> bool { pub(crate) fn is_minor(&self) -> bool {
matches!(self, Self::Minor) matches!(self, Self::Minor)
} }
@ -224,6 +244,8 @@ enum Variant {
impl Variant { impl Variant {
/// Returns `true` if the variant is [`Minor`]. /// Returns `true` if the variant is [`Minor`].
///
/// [`Minor`]: Variant::Minor
fn is_minor(&self) -> bool { fn is_minor(&self) -> bool {
matches!(self, Self::Minor) matches!(self, Self::Minor)
} }
@ -236,14 +258,45 @@ impl Variant {
impl Variant { impl Variant {
/// Returns `true` if the variant is [`Minor`]. /// Returns `true` if the variant is [`Minor`].
///
/// [`Minor`]: Variant::Minor
fn is_minor(&self) -> bool { fn is_minor(&self) -> bool {
matches!(self, Self::Minor) matches!(self, Self::Minor)
} }
/// Returns `true` if the variant is [`Major`]. /// Returns `true` if the variant is [`Major`].
///
/// [`Major`]: Variant::Major
fn is_major(&self) -> bool { fn is_major(&self) -> bool {
matches!(self, Self::Major) matches!(self, Self::Major)
} }
}"#,
);
}
#[test]
fn test_generate_enum_is_variant_names() {
check_assist(
generate_enum_is_method,
r#"
enum GeneratorState {
Yielded,
Complete$0,
Major,
}"#,
r#"enum GeneratorState {
Yielded,
Complete,
Major,
}
impl GeneratorState {
/// Returns `true` if the generator state is [`Complete`].
///
/// [`Complete`]: GeneratorState::Complete
fn is_complete(&self) -> bool {
matches!(self, Self::Complete)
}
}"#, }"#,
); );
} }

View file

@ -723,6 +723,8 @@ enum Version {
impl Version { impl Version {
/// Returns `true` if the version is [`Minor`]. /// Returns `true` if the version is [`Minor`].
///
/// [`Minor`]: Version::Minor
fn is_minor(&self) -> bool { fn is_minor(&self) -> bool {
matches!(self, Self::Minor) matches!(self, Self::Minor)
} }