diff options
author | Justus Winter <justus@sequoia-pgp.org> | 2020-08-13 14:58:34 +0200 |
---|---|---|
committer | Justus Winter <justus@sequoia-pgp.org> | 2020-08-13 16:42:58 +0200 |
commit | 6095dd58ea86629e4cce1f887a1ddbb407a3a800 (patch) | |
tree | 07f51bca8b3e70e2a2874b33bf1eb078c2ca86a7 /openpgp/src/crypto/mod.rs | |
parent | 149d77f437f2ac2f2dafa4c424a39263b5ffebdc (diff) |
openpgp: Add examples for Password.
- See #474.
Diffstat (limited to 'openpgp/src/crypto/mod.rs')
-rw-r--r-- | openpgp/src/crypto/mod.rs | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/openpgp/src/crypto/mod.rs b/openpgp/src/crypto/mod.rs index 029e31b3..3c31aae4 100644 --- a/openpgp/src/crypto/mod.rs +++ b/openpgp/src/crypto/mod.rs @@ -153,6 +153,24 @@ impl fmt::Debug for SessionKey { /// /// [`From`]: https://doc.rust-lang.org/std/convert/trait.From.html /// [`mem::Encrypted`]: mem/struct.Encrypted.html +/// +/// # Examples +/// +/// ``` +/// use sequoia_openpgp as openpgp; +/// use openpgp::crypto::Password; +/// +/// // Convert from a &str. +/// let p: Password = "hunter2".into(); +/// +/// // Convert from a &[u8]. +/// let p: Password = b"hunter2"[..].into(); +/// +/// // Convert from a String. +/// let p: Password = String::from("hunter2").into(); +/// +/// // ... +/// ``` #[derive(Clone, PartialEq, Eq)] pub struct Password(mem::Encrypted); @@ -198,6 +216,19 @@ impl fmt::Debug for Password { impl Password { /// Maps the given function over the password. + /// + /// The password is stored encrypted in memory. This function + /// temporarily decrypts it for the given function to use. + /// + /// # Examples + /// + /// ``` + /// use sequoia_openpgp as openpgp; + /// use openpgp::crypto::Password; + /// + /// let p: Password = "hunter2".into(); + /// p.map(|p| assert_eq!(p.as_ref(), &b"hunter2"[..])); + /// ``` pub fn map<F, T>(&self, fun: F) -> T where F: FnMut(&mem::Protected) -> T { |