]> git.lizzy.rs Git - rust.git/commitdiff
Do not consider fields matched by wildcard patterns to be used
authorSeo Sanghyeon <sanxiyn@gmail.com>
Mon, 22 Jun 2015 12:36:14 +0000 (21:36 +0900)
committerSeo Sanghyeon <sanxiyn@gmail.com>
Mon, 22 Jun 2015 12:36:14 +0000 (21:36 +0900)
src/librustc/middle/dead.rs
src/test/compile-fail/lint-dead-code-4.rs

index e618aa5a5b75dcb4d3ce651f485b582baa0386e3..fd810429c86e03dc79fb4250ed5a50457ed5d2fc 100644 (file)
@@ -172,6 +172,9 @@ fn handle_field_pattern_match(&mut self, lhs: &ast::Pat,
         };
         let fields = ty::lookup_struct_fields(self.tcx, id);
         for pat in pats {
+            if let ast::PatWild(ast::PatWildSingle) = pat.node.pat.node {
+                continue;
+            }
             let field_id = fields.iter()
                 .find(|field| field.name == pat.node.ident.name).unwrap().id;
             self.live_symbols.insert(field_id.node);
index 529113ace4ef9f7933b882c45a5b155843a2541d..8e37dd805d56d14fdee1a6f7d8fdee4afcbd1eda 100644 (file)
@@ -25,14 +25,15 @@ enum XYZ {
     X, //~ ERROR variant is never used
     Y { //~ ERROR variant is never used
         a: String,
-        b: isize //~ ERROR: struct field is never used
+        b: i32, //~ ERROR: struct field is never used
+        c: i32, //~ ERROR: struct field is never used
     },
     Z
 }
 
 fn field_match_in_patterns(b: XYZ) -> String {
     match b {
-        XYZ::Y { a, .. } => a,
+        XYZ::Y { a, b: _, .. } => a,
         _ => "".to_string()
     }
 }
@@ -40,6 +41,7 @@ fn field_match_in_patterns(b: XYZ) -> String {
 struct Bar {
     x: usize, //~ ERROR: struct field is never used
     b: bool,
+    c: bool, //~ ERROR: struct field is never used
     _guard: ()
 }
 
@@ -49,13 +51,13 @@ struct Baz {
 }
 
 fn field_match_in_let(f: Bar) -> bool {
-    let Bar { b, .. } = f;
+    let Bar { b, c: _, .. } = f;
     b
 }
 
 fn main() {
     field_read(Foo { x: 1, b: false });
     field_match_in_patterns(XYZ::Z);
-    field_match_in_let(Bar { x: 42, b: true, _guard: () });
+    field_match_in_let(Bar { x: 42, b: true, c: false, _guard: () });
     let _ = Baz { x: 0 };
 }