From 10ee2acdd26a7f1298c6f6d6b7af9b469fe29b87 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Sat, 4 May 2024 14:41:41 +0200 Subject: Merging upstream version 1.70.0+dfsg2. Signed-off-by: Daniel Baumann --- .../tests/use_macro_outside_crate.rs | 28 ++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 vendor/core-foundation/tests/use_macro_outside_crate.rs (limited to 'vendor/core-foundation/tests') diff --git a/vendor/core-foundation/tests/use_macro_outside_crate.rs b/vendor/core-foundation/tests/use_macro_outside_crate.rs new file mode 100644 index 000000000..ff1c17d4c --- /dev/null +++ b/vendor/core-foundation/tests/use_macro_outside_crate.rs @@ -0,0 +1,28 @@ +#[macro_use] +extern crate core_foundation; + +use core_foundation::base::{CFComparisonResult, TCFType}; +use std::os::raw::c_void; + +// sys equivalent stuff that must be declared + +#[repr(C)] +pub struct __CFFooBar(c_void); + +pub type CFFooBarRef = *const __CFFooBar; + +extern "C" { + pub fn CFFooBarGetTypeID() -> core_foundation::base::CFTypeID; + pub fn fake_compare( + this: CFFooBarRef, + other: CFFooBarRef, + context: *mut c_void, + ) -> CFComparisonResult; +} + +// Try to use the macros outside of the crate + +declare_TCFType!(CFFooBar, CFFooBarRef); +impl_TCFType!(CFFooBar, CFFooBarRef, CFFooBarGetTypeID); +impl_CFTypeDescription!(CFFooBar); +impl_CFComparison!(CFFooBar, fake_compare); -- cgit v1.2.3