From c712e33cbcb85c333547988776fb9d67d9fc6d34 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D1=80=D1=82=D1=91=D0=BC=20=D0=9F=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=BE=D0=B2=20=5BArtyom=20Pavlov=5D?= Date: Wed, 15 Nov 2023 19:38:38 +0300 Subject: [PATCH] Fix `missing_debug_implementations` for some crates --- async-signature/src/lib.rs | 7 ++++++- cipher/src/lib.rs | 7 ++++++- crypto-common/src/lib.rs | 2 +- crypto/src/lib.rs | 2 +- digest/src/core_api/ct_variable.rs | 11 +++++++++++ digest/src/lib.rs | 2 +- digest/src/mac.rs | 6 ++++++ kem/src/kem.rs | 10 ++++++++-- kem/src/lib.rs | 2 +- password-hash/src/lib.rs | 7 ++++++- password-hash/src/params.rs | 1 + signature/src/lib.rs | 1 + signature_derive/src/lib.rs | 1 + universal-hash/src/lib.rs | 2 +- 14 files changed, 51 insertions(+), 10 deletions(-) diff --git a/async-signature/src/lib.rs b/async-signature/src/lib.rs index fde8ca241..8c59952ca 100644 --- a/async-signature/src/lib.rs +++ b/async-signature/src/lib.rs @@ -5,7 +5,12 @@ )] #![cfg_attr(docsrs, feature(doc_auto_cfg))] #![forbid(unsafe_code)] -#![warn(missing_docs, rust_2018_idioms, unused_qualifications)] +#![warn( + missing_docs, + rust_2018_idioms, + unused_qualifications, + missing_debug_implementations +)] pub use signature::{self, Error}; diff --git a/cipher/src/lib.rs b/cipher/src/lib.rs index 7554690ea..ba485aa5a 100644 --- a/cipher/src/lib.rs +++ b/cipher/src/lib.rs @@ -11,7 +11,12 @@ html_logo_url = "https://raw.githubusercontent.com/RustCrypto/media/6ee8e381/logo.svg", html_favicon_url = "https://raw.githubusercontent.com/RustCrypto/media/6ee8e381/logo.svg" )] -#![warn(missing_docs, rust_2018_idioms, unused_lifetimes)] +#![warn( + missing_docs, + rust_2018_idioms, + unused_lifetimes, + missing_debug_implementations +)] pub use crypto_common; pub use inout; diff --git a/crypto-common/src/lib.rs b/crypto-common/src/lib.rs index 247746a64..2c2cb8dc9 100644 --- a/crypto-common/src/lib.rs +++ b/crypto-common/src/lib.rs @@ -7,7 +7,7 @@ html_favicon_url = "https://raw.githubusercontent.com/RustCrypto/media/6ee8e381/logo.svg" )] #![forbid(unsafe_code)] -#![warn(missing_docs, rust_2018_idioms)] +#![warn(missing_docs, rust_2018_idioms, missing_debug_implementations)] #[cfg(feature = "std")] extern crate std; diff --git a/crypto/src/lib.rs b/crypto/src/lib.rs index c28db6fce..3839e2fc8 100644 --- a/crypto/src/lib.rs +++ b/crypto/src/lib.rs @@ -6,7 +6,7 @@ html_favicon_url = "https://raw.githubusercontent.com/RustCrypto/media/8f1a9894/logo.svg" )] #![forbid(unsafe_code)] -#![warn(rust_2018_idioms)] +#![warn(rust_2018_idioms, missing_debug_implementations)] pub use crypto_common as common; diff --git a/digest/src/core_api/ct_variable.rs b/digest/src/core_api/ct_variable.rs index b93e7ea77..20df390e7 100644 --- a/digest/src/core_api/ct_variable.rs +++ b/digest/src/core_api/ct_variable.rs @@ -162,6 +162,17 @@ where const OID: ObjectIdentifier = O::OID; } +impl fmt::Debug for CtVariableCoreWrapper +where + T: VariableOutputCore + AlgorithmName, + OutSize: ArraySize + IsLessOrEqual, + LeEq: NonZero, +{ + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + Self::write_alg_name(f) + } +} + /// Implement dummy type with hidden docs which is used to "carry" hasher /// OID for [`CtVariableCoreWrapper`]. #[macro_export] diff --git a/digest/src/lib.rs b/digest/src/lib.rs index 1bb0d5325..5f9f56f71 100644 --- a/digest/src/lib.rs +++ b/digest/src/lib.rs @@ -29,7 +29,7 @@ html_logo_url = "https://raw.githubusercontent.com/RustCrypto/media/6ee8e381/logo.svg", html_favicon_url = "https://raw.githubusercontent.com/RustCrypto/media/6ee8e381/logo.svg" )] -#![warn(missing_docs, rust_2018_idioms)] +#![warn(missing_docs, rust_2018_idioms, missing_debug_implementations)] #[cfg(feature = "alloc")] #[macro_use] diff --git a/digest/src/mac.rs b/digest/src/mac.rs index f39e9e32a..25c0c550d 100644 --- a/digest/src/mac.rs +++ b/digest/src/mac.rs @@ -241,6 +241,12 @@ impl PartialEq for CtOutput { impl Eq for CtOutput {} +impl fmt::Debug for CtOutput { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + f.write_str("CtOutput { ... }") + } +} + /// Error type for when the [`Output`] of a [`Mac`] /// is not equal to the expected value. #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)] diff --git a/kem/src/kem.rs b/kem/src/kem.rs index 4e7853672..1963883ef 100644 --- a/kem/src/kem.rs +++ b/kem/src/kem.rs @@ -2,7 +2,7 @@ use crate::errors::Error; -use core::fmt::Debug; +use core::fmt; use generic_array::{ArrayLength, GenericArray}; use rand_core::{CryptoRng, RngCore}; @@ -10,7 +10,7 @@ use zeroize::{Zeroize, ZeroizeOnDrop}; /// Trait impl'd by concrete types that represent an encapsulated key. This is intended to be, in /// essence, a bag of bytes. -pub trait EncappedKey: AsRef<[u8]> + Debug + Sized { +pub trait EncappedKey: AsRef<[u8]> + fmt::Debug + Sized { /// The size, in bytes, of an encapsulated key. type EncappedKeySize: ArrayLength; @@ -38,6 +38,12 @@ pub trait EncappedKey: AsRef<[u8]> + Debug + Sized { /// The shared secret that results from key exchange. pub struct SharedSecret(GenericArray); +impl fmt::Debug for SharedSecret { + fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result { + f.write_str("SharedSecret { ... }") + } +} + // Zero the secret on drop impl Drop for SharedSecret { fn drop(&mut self) { diff --git a/kem/src/lib.rs b/kem/src/lib.rs index 5230bc663..7faf1d05c 100644 --- a/kem/src/lib.rs +++ b/kem/src/lib.rs @@ -7,7 +7,7 @@ html_root_url = "https://docs.rs/kem" )] #![forbid(unsafe_code)] -#![warn(missing_docs, unused_qualifications)] +#![warn(missing_docs, unused_qualifications, missing_debug_implementations)] #[cfg(feature = "std")] extern crate std; diff --git a/password-hash/src/lib.rs b/password-hash/src/lib.rs index 4ba94a099..8b8f62ba1 100644 --- a/password-hash/src/lib.rs +++ b/password-hash/src/lib.rs @@ -6,7 +6,12 @@ html_favicon_url = "https://raw.githubusercontent.com/RustCrypto/media/8f1a9894/logo.svg" )] #![forbid(unsafe_code)] -#![warn(missing_docs, rust_2018_idioms, unused_lifetimes)] +#![warn( + missing_docs, + rust_2018_idioms, + unused_lifetimes, + missing_debug_implementations +)] //! //! # Usage diff --git a/password-hash/src/params.rs b/password-hash/src/params.rs index 68648777e..c9d89caee 100644 --- a/password-hash/src/params.rs +++ b/password-hash/src/params.rs @@ -239,6 +239,7 @@ impl fmt::Debug for ParamsString { } /// Iterator over algorithm parameters stored in a [`ParamsString`] struct. +#[derive(Debug)] pub struct Iter<'a> { inner: Option>, } diff --git a/signature/src/lib.rs b/signature/src/lib.rs index c90f5cc8a..902499fe8 100644 --- a/signature/src/lib.rs +++ b/signature/src/lib.rs @@ -12,6 +12,7 @@ missing_docs, rust_2018_idioms, unused_lifetimes, + missing_debug_implementations, unused_qualifications )] diff --git a/signature_derive/src/lib.rs b/signature_derive/src/lib.rs index 1afb0aaa2..14930789b 100644 --- a/signature_derive/src/lib.rs +++ b/signature_derive/src/lib.rs @@ -6,6 +6,7 @@ rust_2018_idioms, trivial_casts, unused_import_braces, + missing_debug_implementations, unused_qualifications )] diff --git a/universal-hash/src/lib.rs b/universal-hash/src/lib.rs index 5fef8a6b4..0cfa03a5a 100644 --- a/universal-hash/src/lib.rs +++ b/universal-hash/src/lib.rs @@ -6,7 +6,7 @@ html_favicon_url = "https://raw.githubusercontent.com/RustCrypto/media/8f1a9894/logo.svg" )] #![forbid(unsafe_code)] -#![warn(missing_docs, rust_2018_idioms)] +#![warn(missing_docs, rust_2018_idioms, missing_debug_implementations)] #[cfg(feature = "std")] extern crate std;