From 0a7f756709d448e97fb2b73a6501db4ada5969e0 Mon Sep 17 00:00:00 2001 From: Manuel Cillero Date: Mon, 10 Jul 2023 20:01:07 +0200 Subject: [PATCH] =?UTF-8?q?=F0=9F=9A=A7=20Revisa=20macros=20externas=20al?= =?UTF-8?q?=20core?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- pagetop-minimal/src/module/menu.rs | 2 +- pagetop/src/config.rs | 26 +------------------------- pagetop/src/locale.rs | 2 +- pagetop/src/util.rs | 27 ++++++++++++++++++++++++++- 4 files changed, 29 insertions(+), 28 deletions(-) diff --git a/pagetop-minimal/src/module/menu.rs b/pagetop-minimal/src/module/menu.rs index b1188eac..27107fee 100644 --- a/pagetop-minimal/src/module/menu.rs +++ b/pagetop-minimal/src/module/menu.rs @@ -2,7 +2,7 @@ use pagetop::prelude::*; use_handle!(MODULE_MENU); -use_locale!(LOCALE_MENU["src/module/menu/locales"]); +use_locale!(LOCALE_MENU in "src/module/menu/locales"); pub struct Menu; diff --git a/pagetop/src/config.rs b/pagetop/src/config.rs index b3ee4a3b..be332e00 100644 --- a/pagetop/src/config.rs +++ b/pagetop/src/config.rs @@ -119,6 +119,7 @@ mod path; mod source; mod value; +use crate::default_settings; use crate::LazyStatic; use crate::config::data::ConfigData; @@ -158,31 +159,6 @@ pub static CONFIG: LazyStatic = LazyStatic::new(|| { settings }); -#[macro_export] -/// Define un conjunto de ajustes de configuración usando tipos seguros y valores predefinidos. -/// -/// Detiene la aplicación con un panic! si no pueden asignarse los ajustes de configuración. -/// -/// Ver [`Cómo añadir ajustes de configuración`](config/index.html#cómo-añadir-ajustes-de-configuración). -macro_rules! default_settings { - ( $($key:literal => $value:literal),* $(,)? ) => { - #[doc = concat!( - "Assigned or predefined values for configuration settings associated with the ", - "[`Settings`] structure." - )] - pub static SETTINGS: $crate::LazyStatic = $crate::LazyStatic::new(|| { - let mut settings = $crate::config::CONFIG.clone(); - $( - settings.set_default($key, $value).unwrap(); - )* - match settings.try_into() { - Ok(s) => s, - Err(e) => panic!("Error parsing settings: {}", e), - } - }); - }; -} - #[derive(Debug, Deserialize)] /// Configuration settings for the [`[app]`](App), [`[database]`](Database), [`[dev]`](Dev), /// [`[log]`](Log), and [`[server]`](Server) sections (see [`SETTINGS`]). diff --git a/pagetop/src/locale.rs b/pagetop/src/locale.rs index f5567e57..6e8ee8a8 100644 --- a/pagetop/src/locale.rs +++ b/pagetop/src/locale.rs @@ -84,7 +84,7 @@ //! ``` //! use pagetop::prelude::*; //! -//! use_locale!(LOCALE_SAMPLE["path/to/locale"]); +//! use_locale!(LOCALE_SAMPLE in "path/to/locale"); //! ``` //! //! Usa el componente [L10n](crate::core::component::l10n::L10n) para incluir textos y contenidos diff --git a/pagetop/src/util.rs b/pagetop/src/util.rs index 40d847cc..43cd925f 100644 --- a/pagetop/src/util.rs +++ b/pagetop/src/util.rs @@ -80,6 +80,31 @@ macro_rules! kv { }}; } +#[macro_export] +/// Define un conjunto de ajustes de configuración usando tipos seguros y valores predefinidos. +/// +/// Detiene la aplicación con un panic! si no pueden asignarse los ajustes de configuración. +/// +/// Ver [`Cómo añadir ajustes de configuración`](config/index.html#cómo-añadir-ajustes-de-configuración). +macro_rules! default_settings { + ( $($key:literal => $value:literal),* $(,)? ) => { + #[doc = concat!( + "Assigned or predefined values for configuration settings associated with the ", + "[`Settings`] structure." + )] + pub static SETTINGS: $crate::LazyStatic = $crate::LazyStatic::new(|| { + let mut settings = $crate::config::CONFIG.clone(); + $( + settings.set_default($key, $value).unwrap(); + )* + match settings.try_into() { + Ok(s) => s, + Err(e) => panic!("Error parsing settings: {}", e), + } + }); + }; +} + #[macro_export] macro_rules! use_handle { ( $HANDLE:ident ) => { @@ -111,7 +136,7 @@ macro_rules! use_locale { }; } }; - ( $LOCALES:ident[$dir_locales:literal] $(, $core_locales:literal)? ) => { + ( $LOCALES:ident in $dir_locales:literal $(, $core_locales:literal)? ) => { use $crate::locale::*; fluent_templates::static_loader! {