about summary refs log tree commit diff
path: root/src/libsyntax
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2017-12-10 00:57:40 +0000
committerbors <bors@rust-lang.org>2017-12-10 00:57:40 +0000
commitc89e206eedee079c4620eacbfb4e3bc6cf392fc8 (patch)
treed362e737537921ce60a13c88139b708e63e29a01 /src/libsyntax
parent8db163e53dab4f188a60bf24b4d6ebeb1ea5cab1 (diff)
parent3024c1434a667425d30e4b0785857381323712aa (diff)
downloadrust-c89e206eedee079c4620eacbfb4e3bc6cf392fc8.tar.gz
rust-c89e206eedee079c4620eacbfb4e3bc6cf392fc8.zip
Auto merge of #46602 - mbrubeck:try, r=kennytm
Replace option_try macros and match with ? operator

None
Diffstat (limited to 'src/libsyntax')
-rw-r--r--src/libsyntax/attr.rs11
-rw-r--r--src/libsyntax/parse/token.rs5
2 files changed, 4 insertions, 12 deletions
diff --git a/src/libsyntax/attr.rs b/src/libsyntax/attr.rs
index 8bd7399092f..e5e95002e10 100644
--- a/src/libsyntax/attr.rs
+++ b/src/libsyntax/attr.rs
@@ -1123,10 +1123,7 @@ impl MetaItem {
             _ => return None,
         };
         let list_closing_paren_pos = tokens.peek().map(|tt| tt.span().hi());
-        let node = match MetaItemKind::from_tokens(tokens) {
-            Some(node) => node,
-            _ => return None,
-        };
+        let node = MetaItemKind::from_tokens(tokens)?;
         let hi = match node {
             MetaItemKind::NameValue(ref lit) => lit.span.hi(),
             MetaItemKind::List(..) => list_closing_paren_pos.unwrap_or(span.hi()),
@@ -1182,10 +1179,8 @@ impl MetaItemKind {
         let mut tokens = delimited.into_trees().peekable();
         let mut result = Vec::new();
         while let Some(..) = tokens.peek() {
-            match NestedMetaItemKind::from_tokens(&mut tokens) {
-                Some(item) => result.push(respan(item.span(), item)),
-                None => return None,
-            }
+            let item = NestedMetaItemKind::from_tokens(&mut tokens)?;
+            result.push(respan(item.span(), item));
             match tokens.next() {
                 None | Some(TokenTree::Token(_, Token::Comma)) => {}
                 _ => return None,
diff --git a/src/libsyntax/parse/token.rs b/src/libsyntax/parse/token.rs
index ff87f146c0a..26f39f60880 100644
--- a/src/libsyntax/parse/token.rs
+++ b/src/libsyntax/parse/token.rs
@@ -620,10 +620,7 @@ fn prepend_attrs(sess: &ParseSess,
                  span: syntax_pos::Span)
     -> Option<tokenstream::TokenStream>
 {
-    let tokens = match tokens {
-        Some(tokens) => tokens,
-        None => return None,
-    };
+    let tokens = tokens?;
     if attrs.len() == 0 {
         return Some(tokens.clone())
     }