diff options
| author | Vadim Petrochenkov <vadim.petrochenkov@gmail.com> | 2016-07-29 23:47:55 +0300 |
|---|---|---|
| committer | Vadim Petrochenkov <vadim.petrochenkov@gmail.com> | 2016-08-13 00:08:14 +0300 |
| commit | 59be332a1b3b190ec5dfdb6768e80f9d312a0c6b (patch) | |
| tree | e44b49f78743634880b525d034b8a82ef651ed2b /src/libsyntax | |
| parent | f55ac6944a88d4da62b30a16cc95893ca050c328 (diff) | |
| download | rust-59be332a1b3b190ec5dfdb6768e80f9d312a0c6b.tar.gz rust-59be332a1b3b190ec5dfdb6768e80f9d312a0c6b.zip | |
Remove restrictions from tuple structs/variants
Hard errors are turned into feature gates
Diffstat (limited to 'src/libsyntax')
| -rw-r--r-- | src/libsyntax/feature_gate.rs | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/src/libsyntax/feature_gate.rs b/src/libsyntax/feature_gate.rs index f550e7d2a05..ad52184a6dc 100644 --- a/src/libsyntax/feature_gate.rs +++ b/src/libsyntax/feature_gate.rs @@ -280,7 +280,11 @@ declare_features! ( (active, dotdot_in_tuple_patterns, "1.10.0", Some(33627)), // Allows `impl Trait` in function return types. - (active, conservative_impl_trait, "1.12.0", Some(34511)) + (active, conservative_impl_trait, "1.12.0", Some(34511)), + + // Allows tuple structs and variants in more contexts, + // Permits numeric fields in struct expressions and patterns. + (active, relaxed_adts, "1.12.0", Some(35626)) ); declare_features! ( @@ -1022,9 +1026,8 @@ impl<'a> Visitor for PostExpansionVisitor<'a> { } PatKind::TupleStruct(_, ref fields, ddpos) if ddpos.is_none() && fields.is_empty() => { - self.context.span_handler.struct_span_err(pattern.span, - "nullary enum variants are written with \ - no trailing `( )`").emit(); + gate_feature_post!(&self, relaxed_adts, pattern.span, + "empty tuple structs patterns are unstable"); } _ => {} } @@ -1107,6 +1110,19 @@ impl<'a> Visitor for PostExpansionVisitor<'a> { visit::walk_impl_item(self, ii); } + fn visit_variant_data(&mut self, vdata: &ast::VariantData, _: ast::Ident, + _: &ast::Generics, _: NodeId, span: Span) { + if vdata.fields().is_empty() { + if vdata.is_tuple() { + gate_feature_post!(&self, relaxed_adts, span, + "empty tuple structs and enum variants are unstable, \ + use unit structs and enum variants instead"); + } + } + + visit::walk_struct_def(self, vdata) + } + fn visit_vis(&mut self, vis: &ast::Visibility) { let span = match *vis { ast::Visibility::Crate(span) => span, |
