From 1ac9617318bd66905c7a563c8fb028392c83611f Mon Sep 17 00:00:00 2001 From: Mads Marquart Date: Sun, 17 Jul 2022 01:40:00 +0200 Subject: [PATCH] Document the associated function `class` --- objc2-foundation/src/declare_macro.rs | 8 ++++++++ objc2-foundation/src/macros.rs | 18 ++++++++++++++++++ objc2-foundation/src/object.rs | 2 ++ 3 files changed, 28 insertions(+) diff --git a/objc2-foundation/src/declare_macro.rs b/objc2-foundation/src/declare_macro.rs index 6daaa0a3f..d3c9beb97 100644 --- a/objc2-foundation/src/declare_macro.rs +++ b/objc2-foundation/src/declare_macro.rs @@ -681,6 +681,14 @@ macro_rules! declare_class { // Creation impl $name { + #[doc = concat!( + "Get a reference to the Objective-C class `", + stringify!($name), + "`.", + "\n\n", + "May register the class if it wasn't already.", + )] + // TODO: Allow users to configure this? $v fn class() -> &'static $crate::objc2::runtime::Class { // TODO: Use `core::cell::LazyCell` use $crate::__std::sync::Once; diff --git a/objc2-foundation/src/macros.rs b/objc2-foundation/src/macros.rs index dffbb3b8f..aa424d015 100644 --- a/objc2-foundation/src/macros.rs +++ b/objc2-foundation/src/macros.rs @@ -13,6 +13,10 @@ /// The traits [`objc2::RefEncode`] and [`objc2::Message`] are implemented to /// allow sending messages to the object and using it in [`objc2::rc::Id`]. /// +/// An associated function `class` is created on the object as a convenient +/// shorthand so that you can do `MyObject::class()` instead of +/// `class!(MyObject)`. +/// /// [`Deref`] and [`DerefMut`] are implemented and delegate to the first /// superclass (direct parent). Auto traits are inherited from this superclass /// as well (this macro effectively just creates a newtype wrapper around the @@ -96,6 +100,13 @@ macro_rules! extern_class { } impl $name { + #[doc = concat!( + "Get a reference to the Objective-C class `", + stringify!($name), + "`.", + )] + #[inline] + // TODO: Allow users to configure this? $v fn class() -> &'static $crate::objc2::runtime::Class { $crate::objc2::class!($name) } @@ -169,6 +180,13 @@ macro_rules! __inner_extern_class { } impl<$($t $(: $b)?),*> $name<$($t),*> { + #[doc = concat!( + "Get a reference to the Objective-C class `", + stringify!($name), + "`.", + )] + #[inline] + // TODO: Allow users to configure this? $v fn class() -> &'static $crate::objc2::runtime::Class { $crate::objc2::class!($name) } diff --git a/objc2-foundation/src/object.rs b/objc2-foundation/src/object.rs index 974a68c80..2c8484ce7 100644 --- a/objc2-foundation/src/object.rs +++ b/objc2-foundation/src/object.rs @@ -13,6 +13,8 @@ __inner_extern_class! { } impl NSObject { + /// Get a reference to the Objective-C class `NSObject`. + #[inline] pub fn class() -> &'static Class { class!(NSObject) }