diff options
author | Azul <azul@riseup.net> | 2020-10-09 20:05:33 +0200 |
---|---|---|
committer | Azul <azul@riseup.net> | 2020-10-26 17:47:09 +0100 |
commit | d662a80e8f7c96b72708e4124546f72d2712ed40 (patch) | |
tree | beb51cb910bdb1448e4a3edfe4059dca78eb7e8e /openpgp/src/seal.rs | |
parent | 3fc8654d33c8c57542250eda8e910a2ffa0b8a81 (diff) |
openpgp: seal the Preferences trait
[Seal] the `cert::Preferences` trait
so it cannot be implemented for types outside this crate.
Therefore it can be extended in a non-breaking way.
Attempts to implement the trait will not compile.
refers: #538
[seal]: https://rust-lang.github.io/api-guidelines/future-proofing.html#sealed-traits-protect-against-downstream-implementations-c-sealed
Diffstat (limited to 'openpgp/src/seal.rs')
-rw-r--r-- | openpgp/src/seal.rs | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/openpgp/src/seal.rs b/openpgp/src/seal.rs new file mode 100644 index 00000000..bfdbd1e4 --- /dev/null +++ b/openpgp/src/seal.rs @@ -0,0 +1,46 @@ +//! [Sealing Traits] +//! +//! [sealing traits:] https://rust-lang.github.io/api-guidelines/future-proofing.html#sealed-traits-protect-against-downstream-implementations-c-sealed +//! +//! Prevent the implementation of traits outside of the crate +//! to allow extension of the traits at a later time. +//! +//! Mark a trait as sealed by deriving it from seal::Sealed. +//! +//! Only Implementations of seal::Sealed will be able to implement the trait. +//! Since seal::Sealed is only visible inside the crate +//! sealed traits can only be implemented in the crate. + +/// This trait is used to [seal] other traits so they cannot +/// be implemented for types outside this crate. +/// Therefore they can be extended in a non-breaking way. +/// +/// [seal]: https://rust-lang.github.io/api-guidelines/future-proofing.html#sealed-traits-protect-against-downstream-implementations-c-sealed +/// +/// # Examples +/// +/// For example the [`cert::Preferences`] trait is sealed. +/// Therefore attempts to implement it will not compile: +/// +/// [`cert::Preferences`]: ../cert/trait.Preferences.html +/// +/// ```compile_fail +/// # extern crate sequoia_openpgp as openpgp; +/// use openpgp::cert::prelude::*; +/// use openpgp::cert::Preferences; +/// use openpgp::types::*; +/// +/// pub struct InvalidComponentAmalgamation {} +/// impl<'a> Preferences<'a> for InvalidComponentAmalgamation { //~ ERROR `_x @` is not allowed in a tuple +/// fn preferred_symmetric_algorithms(&self) +/// -> Option<&'a [SymmetricAlgorithm]> { None } +/// fn preferred_hash_algorithms(&self) -> Option<&'a [HashAlgorithm]> { None } +/// fn preferred_compression_algorithms(&self) +/// -> Option<&'a [CompressionAlgorithm]> { None } +/// fn preferred_aead_algorithms(&self) -> Option<&'a [AEADAlgorithm]> { None } +/// fn key_server_preferences(&self) -> Option<KeyServerPreferences> { None } +/// fn preferred_key_server(&self) -> Option<&'a [u8]> { None } +/// fn features(&self) -> Option<Features> { None } +/// } +/// ``` +pub trait Sealed {} |