From a88d02fcb74457fb179619694dd36e904377f791 Mon Sep 17 00:00:00 2001 From: PgBiel <9021226+PgBiel@users.noreply.github.com> Date: Fri, 6 Oct 2023 03:08:05 -0300 Subject: [PATCH] Allow #[cfg] to be used with #[constant] --- godot-macros/src/class/godot_api.rs | 11 +++++++++++ .../rust/src/register_tests/constant_test.rs | 19 +++++++++++++++++++ 2 files changed, 30 insertions(+) diff --git a/godot-macros/src/class/godot_api.rs b/godot-macros/src/class/godot_api.rs index 11424c647..5b4531ab0 100644 --- a/godot-macros/src/class/godot_api.rs +++ b/godot-macros/src/class/godot_api.rs @@ -136,6 +136,7 @@ fn transform_inherent_impl(mut decl: Impl) -> Result { .map(|func_def| make_method_registration(&class_name, func_def)); let consts = process_godot_constants(&mut decl)?; + let mut integer_constant_cfg_attrs = Vec::new(); let mut integer_constant_names = Vec::new(); let mut integer_constant_values = Vec::new(); @@ -146,6 +147,15 @@ fn transform_inherent_impl(mut decl: Impl) -> Result { let name = &constant.name; + // Unlike with #[func] and #[signal], we don't remove the attributes from Constant + // signatures within 'process_godot_constants'. + let cfg_attrs = util::extract_cfg_attrs(&constant.attributes) + .into_iter() + .collect::>(); + + // Transport #[cfg] attrs to the FFI glue to ensure constants which were conditionally + // removed from compilation don't cause errors. + integer_constant_cfg_attrs.push(cfg_attrs); integer_constant_names.push(constant.name.to_string()); integer_constant_values.push(quote! { #class_name::#name }); } @@ -157,6 +167,7 @@ fn transform_inherent_impl(mut decl: Impl) -> Result { use ::godot::builtin::StringName; #( + #(#integer_constant_cfg_attrs)* ExportConstant::new( #class_name_obj, ConstantKind::Integer( diff --git a/itest/rust/src/register_tests/constant_test.rs b/itest/rust/src/register_tests/constant_test.rs index c671de9c4..558a9e653 100644 --- a/itest/rust/src/register_tests/constant_test.rs +++ b/itest/rust/src/register_tests/constant_test.rs @@ -40,6 +40,25 @@ impl HasConstants { #[constant] #[cfg(all())] const CONSTANT_RECOGNIZED_WITH_SIMPLE_PATH_ATTRIBUTE_BELOW_CONST_ATTR: bool = true; + + #[constant] + const CFG_REMOVES_CONSTANT: bool = true; + + #[cfg(any())] + #[constant] + const CFG_REMOVES_CONSTANT: bool = false; + + #[constant] + #[cfg(any())] + const CFG_REMOVES_CONSTANT: bool = false; + + #[cfg(any())] + #[constant] + const CFG_REMOVES_CONSTANT_FFI_GLUE: bool = true; + + #[constant] + #[cfg(any())] + const CFG_REMOVES_CONSTANT_FFI_GLUE: bool = true; } #[itest]