Unnamed repository; edit this file 'description' to name the repository.
Diffstat (limited to 'crates/ide-diagnostics/src/handlers/generic_default_refers_to_self.rs')
-rw-r--r--crates/ide-diagnostics/src/handlers/generic_default_refers_to_self.rs43
1 files changed, 43 insertions, 0 deletions
diff --git a/crates/ide-diagnostics/src/handlers/generic_default_refers_to_self.rs b/crates/ide-diagnostics/src/handlers/generic_default_refers_to_self.rs
new file mode 100644
index 0000000000..3d38159c4f
--- /dev/null
+++ b/crates/ide-diagnostics/src/handlers/generic_default_refers_to_self.rs
@@ -0,0 +1,43 @@
+use crate::{Diagnostic, DiagnosticCode, DiagnosticsContext};
+
+// Diagnostic: generic-default-refers-to-self
+//
+// This diagnostic is shown when a generic default refers to `Self`
+pub(crate) fn generic_default_refers_to_self(
+ ctx: &DiagnosticsContext<'_>,
+ d: &hir::GenericDefaultRefersToSelf,
+) -> Diagnostic {
+ Diagnostic::new_with_syntax_node_ptr(
+ ctx,
+ DiagnosticCode::RustcHardError("E0735"),
+ "generic parameters cannot use `Self` in their defaults",
+ d.segment.map(Into::into),
+ )
+ .stable()
+}
+
+#[cfg(test)]
+mod tests {
+ use crate::tests::check_diagnostics;
+
+ #[test]
+ fn plain_self() {
+ check_diagnostics(
+ r#"
+struct Foo<T = Self>(T);
+ // ^^^^ error: generic parameters cannot use `Self` in their defaults
+"#,
+ );
+ }
+
+ #[test]
+ fn self_as_generic() {
+ check_diagnostics(
+ r#"
+struct Wrapper<T>(T);
+struct Foo<T = Wrapper<Self>>(T);
+ // ^^^^ error: generic parameters cannot use `Self` in their defaults
+"#,
+ );
+ }
+}