Merge rust-bitcoin/rust-bitcoin#4049: hashes: Test macros in function scope

8c2439550a hashes: Test macros in function scope (Tobin C. Harding)

Pull request description:

  The two main public macros can be used in function scope - prove it.

  While we are at it prove that additional attributes are supported by them both as well as visability keywords.

ACKs for top commit:
  apoelstra:
    ACK 8c2439550acdf3cb52c78d69eb55160f9d03a139; successfully ran local tests
  Kixunil:
    ACK 8c2439550a

Tree-SHA512: 66d6a9fd142966f6e68e9a5cb849345a77357dc6e415a10507418425a4cf6a1440deaf47515db43b9ec5b5d337d53164c617db165cb2ff782cf6a6e4ff195c77
This commit is contained in:
merge-script 2025-02-17 18:25:14 +00:00
commit bee652d7fd
No known key found for this signature in database
GPG Key ID: C588D63CE41B97C1
1 changed files with 19 additions and 0 deletions

View File

@ -576,6 +576,25 @@ mod test {
fn all_zeros() -> Self { Self::from_byte_array([0; 32]) }
}
#[test]
fn macros_work_in_function_scope() {
use crate::sha256t;
sha256t_tag! {
#[repr(align(2))] // This tests that we can add additional attributes.
pub struct FunctionScopeTag = hash_str("It works");
}
hash_newtype! {
/// Some docs.
#[repr(align(4))] // This tests that we can add additional attributes.
pub struct FunctionScopeHash(pub(crate) sha256t::Hash<FunctionScopeTag>);
}
assert_eq!(2, core::mem::align_of::<FunctionScopeTag>());
assert_eq!(4, core::mem::align_of::<FunctionScopeHash>());
}
// NB: This runs with and without `hex` feature enabled, testing different code paths for each.
#[test]
#[cfg(feature = "alloc")]