From 0af9eca642b244515b0732ab67423a899187da6e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Tomasz=20Mi=C4=85sko?= Date: Thu, 4 Feb 2021 00:00:00 +0000 Subject: [PATCH] Remove unnecessary abstractions from option and result impls Change the implementation of a option and result methods to avoid code generation of additional functions, where a simple match is sufficient. --- library/core/src/option.rs | 30 +++++++++++++++++++++++------ library/core/src/result.rs | 39 +++++++++++++++++++++++++++++--------- 2 files changed, 54 insertions(+), 15 deletions(-) diff --git a/library/core/src/option.rs b/library/core/src/option.rs index f1a0f455cd091..80e3e21d84b83 100644 --- a/library/core/src/option.rs +++ b/library/core/src/option.rs @@ -1060,7 +1060,10 @@ impl Option<&T> { /// ``` #[stable(feature = "copied", since = "1.35.0")] pub fn copied(self) -> Option { - self.map(|&t| t) + match self { + None => None, + Some(t) => Some(*t), + } } } @@ -1079,7 +1082,10 @@ impl Option<&mut T> { /// ``` #[stable(feature = "copied", since = "1.35.0")] pub fn copied(self) -> Option { - self.map(|&mut t| t) + match self { + None => None, + Some(t) => Some(*t), + } } } @@ -1098,7 +1104,10 @@ impl Option<&T> { /// ``` #[stable(feature = "rust1", since = "1.0.0")] pub fn cloned(self) -> Option { - self.map(|t| t.clone()) + match self { + None => None, + Some(t) => Some(t.clone()), + } } } @@ -1117,7 +1126,10 @@ impl Option<&mut T> { /// ``` #[stable(since = "1.26.0", feature = "option_ref_mut_cloned")] pub fn cloned(self) -> Option { - self.map(|t| t.clone()) + match self { + None => None, + Some(t) => Some(t.clone()), + } } } @@ -1259,7 +1271,10 @@ impl Option { /// ``` #[stable(feature = "option_deref", since = "1.40.0")] pub fn as_deref(&self) -> Option<&T::Target> { - self.as_ref().map(|t| t.deref()) + match self { + None => None, + Some(t) => Some(t.deref()), + } } } @@ -1280,7 +1295,10 @@ impl Option { /// ``` #[stable(feature = "option_deref", since = "1.40.0")] pub fn as_deref_mut(&mut self) -> Option<&mut T::Target> { - self.as_mut().map(|t| t.deref_mut()) + match self { + None => None, + Some(t) => Some(t.deref_mut()), + } } } diff --git a/library/core/src/result.rs b/library/core/src/result.rs index 2ce8a703c123e..233f013e18b5d 100644 --- a/library/core/src/result.rs +++ b/library/core/src/result.rs @@ -229,7 +229,7 @@ use crate::iter::{self, FromIterator, FusedIterator, TrustedLen}; use crate::ops::{self, Deref, DerefMut}; -use crate::{convert, fmt, hint}; +use crate::{fmt, hint}; /// `Result` is a type that represents either success ([`Ok`]) or failure ([`Err`]). /// @@ -298,7 +298,7 @@ impl Result { #[inline] #[stable(feature = "rust1", since = "1.0.0")] pub const fn is_err(&self) -> bool { - !self.is_ok() + matches!(*self, Err(_)) } /// Returns `true` if the result is an [`Ok`] value containing the given value. @@ -907,7 +907,10 @@ impl Result<&T, E> { /// ``` #[unstable(feature = "result_copied", reason = "newly added", issue = "63168")] pub fn copied(self) -> Result { - self.map(|&t| t) + match self { + Ok(x) => Ok(*x), + Err(e) => Err(e), + } } } @@ -927,7 +930,10 @@ impl Result<&mut T, E> { /// ``` #[unstable(feature = "result_copied", reason = "newly added", issue = "63168")] pub fn copied(self) -> Result { - self.map(|&mut t| t) + match self { + Ok(x) => Ok(*x), + Err(e) => Err(e), + } } } @@ -947,7 +953,10 @@ impl Result<&T, E> { /// ``` #[unstable(feature = "result_cloned", reason = "newly added", issue = "63168")] pub fn cloned(self) -> Result { - self.map(|t| t.clone()) + match self { + Ok(x) => Ok(x.clone()), + Err(e) => Err(e), + } } } @@ -967,7 +976,10 @@ impl Result<&mut T, E> { /// ``` #[unstable(feature = "result_cloned", reason = "newly added", issue = "63168")] pub fn cloned(self) -> Result { - self.map(|t| t.clone()) + match self { + Ok(x) => Ok(x.clone()), + Err(e) => Err(e), + } } } @@ -1186,7 +1198,10 @@ impl Result { /// ``` #[stable(feature = "inner_deref", since = "1.47.0")] pub fn as_deref(&self) -> Result<&T::Target, &E> { - self.as_ref().map(|t| t.deref()) + match self { + Ok(x) => Ok(x.deref()), + Err(e) => Err(e), + } } } @@ -1211,7 +1226,10 @@ impl Result { /// ``` #[stable(feature = "inner_deref", since = "1.47.0")] pub fn as_deref_mut(&mut self) -> Result<&mut T::Target, &mut E> { - self.as_mut().map(|t| t.deref_mut()) + match self { + Ok(x) => Ok(x.deref_mut()), + Err(e) => Err(e), + } } } @@ -1273,7 +1291,10 @@ impl Result, E> { #[inline] #[unstable(feature = "result_flattening", issue = "70142")] pub fn flatten(self) -> Result { - self.and_then(convert::identity) + match self { + Ok(x) => x, + Err(e) => Err(e), + } } }