From adcdf01cebf43dfc9a97135dc351966ead83c58c Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 17:12:18 +0300 Subject: [PATCH 01/24] program_tools : draft --- module/core/process_tools/Cargo.toml | 16 -- module/core/process_tools/src/process.rs | 1 + module/core/program_tools/Cargo.toml | 57 +++++++ module/core/program_tools/License | 22 +++ module/core/program_tools/Readme.md | 33 +++++ module/core/program_tools/src/lib.rs | 17 +++ module/core/program_tools/src/program.rs | 101 +++++++++++++ .../tests/asset/err_out_test/err_out_err.rs | 8 + .../tests/asset/err_out_test/out_err_out.rs | 9 ++ module/core/program_tools/tests/inc/basic.rs | 7 + module/core/program_tools/tests/inc/mod.rs | 4 + module/core/program_tools/tests/smoke_test.rs | 14 ++ module/core/program_tools/tests/tests.rs | 11 ++ module/core/program_tools/tests/tool/asset.rs | 140 ++++++++++++++++++ module/move/crates_tools/src/lib.rs | 5 - 15 files changed, 424 insertions(+), 21 deletions(-) create mode 100644 module/core/program_tools/Cargo.toml create mode 100644 module/core/program_tools/License create mode 100644 module/core/program_tools/Readme.md create mode 100644 module/core/program_tools/src/lib.rs create mode 100644 module/core/program_tools/src/program.rs create mode 100644 module/core/program_tools/tests/asset/err_out_test/err_out_err.rs create mode 100644 module/core/program_tools/tests/asset/err_out_test/out_err_out.rs create mode 100644 module/core/program_tools/tests/inc/basic.rs create mode 100644 module/core/program_tools/tests/inc/mod.rs create mode 100644 module/core/program_tools/tests/smoke_test.rs create mode 100644 module/core/program_tools/tests/tests.rs create mode 100644 module/core/program_tools/tests/tool/asset.rs diff --git a/module/core/process_tools/Cargo.toml b/module/core/process_tools/Cargo.toml index 7f31dceaa1..f28259801b 100644 --- a/module/core/process_tools/Cargo.toml +++ b/module/core/process_tools/Cargo.toml @@ -28,22 +28,6 @@ all-features = false [features] default = [ "enabled", "process_environment_is_cicd" ] full = [ "enabled", "process_environment_is_cicd" ] -no_std = [ - "former/no_std", - # xxx - # "proper_path_tools/no_std", - # "error_tools/no_std", - # "iter_tools/no_std", - "test_tools/no_std", -] -use_alloc = [ - "no_std", - "former/use_alloc", - # "proper_path_tools/use_alloc", - # "error_tools/use_alloc", - # "iter_tools/use_alloc", - "test_tools/use_alloc", -] enabled = [ "mod_interface/enabled", "former/enabled", diff --git a/module/core/process_tools/src/process.rs b/module/core/process_tools/src/process.rs index eac9643740..db954da17c 100644 --- a/module/core/process_tools/src/process.rs +++ b/module/core/process_tools/src/process.rs @@ -298,6 +298,7 @@ pub( crate ) mod private } } } + impl core::fmt::Display for Report { fn fmt( &self, f : &mut Formatter< '_ > ) -> core::fmt::Result diff --git a/module/core/program_tools/Cargo.toml b/module/core/program_tools/Cargo.toml new file mode 100644 index 0000000000..30faf2edc3 --- /dev/null +++ b/module/core/program_tools/Cargo.toml @@ -0,0 +1,57 @@ +[package] +name = "program_tools" +version = "0.1.0" +edition = "2021" +authors = [ + "Kostiantyn Wandalen ", +] +license = "MIT" +readme = "Readme.md" +documentation = "https://docs.rs/program_tools" +repository = "https://github.com/Wandalen/wTools/tree/master/module/core/program_tools" +homepage = "https://github.com/Wandalen/wTools/tree/master/module/core/program_tools" +description = """ +Compile and run a Rust program. +""" +categories = [ "algorithms", "development-tools" ] +keywords = [ "fundamental", "general-purpose" ] + +[lints] +workspace = true + + +[package.metadata.docs.rs] +features = [ "full" ] +all-features = false + + +[features] +default = [ + "enabled", +] +full = [ + "enabled" + ] + +enabled = [ + "mod_interface/enabled", + "former/enabled", + "proper_path_tools/enabled", + "error_tools/enabled", + "iter_tools/enabled", +] + +[dependencies] +mod_interface = { workspace = true } +former = { workspace = true, features = [ "derive_former" ] } +proper_path_tools = { workspace = true } +error_tools = { workspace = true, features = [ "error_for_app" ] } # qqq : xxx : rid off error_for_app +iter_tools = { workspace = true } + +# ## external +# duct = "0.13.7" + + +[dev-dependencies] +test_tools = { workspace = true } +# assert_fs = { version = "1.1.1" } diff --git a/module/core/program_tools/License b/module/core/program_tools/License new file mode 100644 index 0000000000..6d5ef8559f --- /dev/null +++ b/module/core/program_tools/License @@ -0,0 +1,22 @@ +Copyright Kostiantyn W and Out of the Box Systems (c) 2013-2024 + +Permission is hereby granted, free of charge, to any person +obtaining a copy of this software and associated documentation +files (the "Software"), to deal in the Software without +restriction, including without limitation the rights to use, +copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the +Software is furnished to do so, subject to the following +conditions: + +The above copyright notice and this permission notice shall be +included in all copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES +OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND +NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT +HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, +WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING +FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. diff --git a/module/core/program_tools/Readme.md b/module/core/program_tools/Readme.md new file mode 100644 index 0000000000..daf1b1c108 --- /dev/null +++ b/module/core/program_tools/Readme.md @@ -0,0 +1,33 @@ + + +# Module :: program_tools + + [![experimental](https://raster.shields.io/static/v1?label=&message=experimental&color=orange)](https://github.com/emersion/stability-badges#experimental) [![rust-status](https://github.com/Wandalen/wTools/actions/workflows/module_program_tools_push.yml/badge.svg)](https://github.com/Wandalen/wTools/actions/workflows/module_program_tools_push.yml) [![docs.rs](https://img.shields.io/docsrs/program_tools?color=e3e8f0&logo=docs.rs)](https://docs.rs/program_tools) [![discord](https://img.shields.io/discord/872391416519737405?color=eee&logo=discord&logoColor=eee&label=ask)](https://discord.gg/m3YfbXpUUY) + + +Compile and run a Rust program. + + diff --git a/module/core/program_tools/src/lib.rs b/module/core/program_tools/src/lib.rs new file mode 100644 index 0000000000..fa8616e2be --- /dev/null +++ b/module/core/program_tools/src/lib.rs @@ -0,0 +1,17 @@ +// #![ cfg_attr( feature = "no_std", no_std ) ] +#![ doc( html_logo_url = "https://raw.githubusercontent.com/Wandalen/wTools/master/asset/img/logo_v3_trans_square.png" ) ] +#![ doc( html_favicon_url = "https://raw.githubusercontent.com/Wandalen/wTools/alpha/asset/img/logo_v3_trans_square_icon_small_v2.ico" ) ] +#![ doc( html_root_url = "https://docs.rs/program_tools/latest/program_tools/" ) ] +#![ doc = include_str!( concat!( env!( "CARGO_MANIFEST_DIR" ), "/", "Readme.md" ) ) ] + +#[ cfg( feature = "enabled" ) ] +use mod_interface::mod_interface; + +#[ cfg( feature = "enabled" ) ] +mod_interface! +{ + + /// Compile and run a Rust program. + layer program; + +} diff --git a/module/core/program_tools/src/program.rs b/module/core/program_tools/src/program.rs new file mode 100644 index 0000000000..90a3ffbc90 --- /dev/null +++ b/module/core/program_tools/src/program.rs @@ -0,0 +1,101 @@ +/// Internal namespace. +pub( crate ) mod private +{ + + use former::Former; + use std:: + { + path::{ Path, PathBuf }, + // process::Command, + }; + + #[ derive( Debug, Default, Former ) ] + pub struct SourceFile + { + file_path : PathBuf, + data : GetData, + } + + #[ derive( Debug, Default, Former ) ] + pub struct Entry + { + source_file : SourceFile, + typ : EntryType, + } + + #[ derive( Debug, Default, Former ) ] + pub struct CargoFile + { + file_path : PathBuf, + data : GetData, + } + + #[ derive( Debug, Default, Former ) ] + // #[ debug ] + pub struct Program + { + write_path : Option< PathBuf >, + read_path : Option< PathBuf >, + entries : Vec< Entry >, + sources : Vec< SourceFile >, + cargo_file : Option< CargoFile >, + } + + #[ derive( Debug, Default, Former ) ] + pub struct ProgramRun + { + // #[ embed ] + program : Program, + calls : Vec< ProgramCall >, + } + + #[ derive( Debug ) ] + pub enum GetData + { + FromStr( &'static str ), + FromBin( &'static [ u8 ] ), + FromFile( PathBuf ), + FromString( String ), + } + + impl Default for GetData + { + fn default() -> Self + { + GetData::FromStr( "" ) + } + } + + #[ derive( Debug, Default ) ] + pub struct ProgramCall + { + action : ProgramAction, + current_path : Option< PathBuf >, + args : Vec< String >, + index_of_entry : i32, + } + + #[ derive( Debug, Default ) ] + pub enum ProgramAction + { + #[ default ] + Run, + Build, + Test, + } + + #[ derive( Debug, Default ) ] + pub enum EntryType + { + #[ default ] + Bin, + Lib, + Test, + } + +} + +crate::mod_interface! +{ + // protected use run; +} diff --git a/module/core/program_tools/tests/asset/err_out_test/err_out_err.rs b/module/core/program_tools/tests/asset/err_out_test/err_out_err.rs new file mode 100644 index 0000000000..d6bc10ff45 --- /dev/null +++ b/module/core/program_tools/tests/asset/err_out_test/err_out_err.rs @@ -0,0 +1,8 @@ +fn main() +{ + eprintln!( "This is stderr text" ); + + println!( "This is stdout text" ); + + eprintln!( "This is stderr text" ); +} diff --git a/module/core/program_tools/tests/asset/err_out_test/out_err_out.rs b/module/core/program_tools/tests/asset/err_out_test/out_err_out.rs new file mode 100644 index 0000000000..eeb47d28bf --- /dev/null +++ b/module/core/program_tools/tests/asset/err_out_test/out_err_out.rs @@ -0,0 +1,9 @@ +//! need for tests +fn main() +{ + println!( "This is stdout text" ); + + eprintln!( "This is stderr text" ); + + println!( "This is stdout text" ); +} diff --git a/module/core/program_tools/tests/inc/basic.rs b/module/core/program_tools/tests/inc/basic.rs new file mode 100644 index 0000000000..60c9a81cfb --- /dev/null +++ b/module/core/program_tools/tests/inc/basic.rs @@ -0,0 +1,7 @@ +#[ allow( unused_imports ) ] +use super::*; + +#[ test ] +fn basic() +{ +} diff --git a/module/core/program_tools/tests/inc/mod.rs b/module/core/program_tools/tests/inc/mod.rs new file mode 100644 index 0000000000..d78794e341 --- /dev/null +++ b/module/core/program_tools/tests/inc/mod.rs @@ -0,0 +1,4 @@ +#[ allow( unused_imports ) ] +use super::*; + +mod basic; diff --git a/module/core/program_tools/tests/smoke_test.rs b/module/core/program_tools/tests/smoke_test.rs new file mode 100644 index 0000000000..7fd288e61d --- /dev/null +++ b/module/core/program_tools/tests/smoke_test.rs @@ -0,0 +1,14 @@ + +// #[ cfg( feature = "default" ) ] +#[ test ] +fn local_smoke_test() +{ + ::test_tools::smoke_test_for_local_run(); +} + +// #[ cfg( feature = "default" ) ] +#[ test ] +fn published_smoke_test() +{ + ::test_tools::smoke_test_for_published_run(); +} diff --git a/module/core/program_tools/tests/tests.rs b/module/core/program_tools/tests/tests.rs new file mode 100644 index 0000000000..e353b1d4d9 --- /dev/null +++ b/module/core/program_tools/tests/tests.rs @@ -0,0 +1,11 @@ + +include!( "../../../../module/step/meta/src/module/terminal.rs" ); + +#[ allow( unused_imports ) ] +use program_tools as the_module; + +#[ allow( unused_imports ) ] +use test_tools::exposed::*; + +#[ cfg( feature = "enabled" ) ] +mod inc; diff --git a/module/core/program_tools/tests/tool/asset.rs b/module/core/program_tools/tests/tool/asset.rs new file mode 100644 index 0000000000..7261904225 --- /dev/null +++ b/module/core/program_tools/tests/tool/asset.rs @@ -0,0 +1,140 @@ + +// xxx2 : incorporate the function into a tool + +pub const ASSET_PATH : &str = "tests/asset"; + +macro_rules! ERR_MSG +{ + () + => + { + "Create `.cargo/config.toml` file at root of your project and append it by +``` +[env] +WORKSPACE_PATH = { value = \".\", relative = true } +```" + }; +} + +pub fn path() -> std::io::Result< std::path::PathBuf > +{ + use std:: + { + path::Path, + io::{ self, ErrorKind } + }; + let workspace_path = Path::new( env!( "WORKSPACE_PATH", ERR_MSG!{} ) ); + // dbg!( workspace_path ); + // let crate_path = Path::new( env!( "CARGO_MANIFEST_DIR" ) ); + // dbg!( file!() ); + let dir_path = workspace_path.join( Path::new( file!() ) ); + let dir_path = dir_path.canonicalize()?; + let test_dir = dir_path + .parent() + .ok_or_else( || io::Error::new( ErrorKind::NotFound, format!( "Failed to find parent directory {}", dir_path.display() ) ) )? + .parent() + .ok_or_else( || io::Error::new( ErrorKind::NotFound, format!( "Failed to find parent directory {}", dir_path.display() ) ) )? + .parent() + .ok_or_else( || io::Error::new( ErrorKind::NotFound, format!( "Failed to find parent directory {}", dir_path.display() ) ) )? + ; + // dbg!( &test_dir ); + let assets_path = test_dir.join( Path::new( ASSET_PATH ) ); + // dbg!( &assets_path ); + Ok( assets_path ) +} + +// + +// xxx2 : adjust Former to generate required code easier +// xxx2 : implement the interface + +use former::Former; +use std:: +{ + path::{ Path, PathBuf }, + // process::Command, +}; + +#[ derive( Debug, Default, Former ) ] +pub struct SourceFile +{ + file_path : PathBuf, + data : GetData, +} + +#[ derive( Debug, Default, Former ) ] +pub struct Entry +{ + source_file : SourceFile, + typ : EntryType, +} + +#[ derive( Debug, Default, Former ) ] +pub struct CargoFile +{ + file_path : PathBuf, + data : GetData, +} + +#[ derive( Debug, Default, Former ) ] +// #[ debug ] +pub struct Program +{ + write_path : Option< PathBuf >, + read_path : Option< PathBuf >, + entries : Vec< Entry >, + sources : Vec< SourceFile >, + cargo_file : Option< CargoFile >, +} + +#[ derive( Debug, Default, Former ) ] +pub struct ProgramRun +{ + // #[ embed ] + program : Program, + calls : Vec< ProgramCall >, +} + +#[ derive( Debug ) ] +pub enum GetData +{ + FromStr( &'static str ), + FromBin( &'static [ u8 ] ), + FromFile( PathBuf ), + FromString( String ), +} + +impl Default for GetData +{ + fn default() -> Self + { + GetData::FromStr( "" ) + } +} + +#[ derive( Debug, Default ) ] +pub struct ProgramCall +{ + action : ProgramAction, + current_path : Option< PathBuf >, + args : Vec< String >, + index_of_entry : i32, +} + +#[ derive( Debug, Default ) ] +pub enum ProgramAction +{ + #[ default ] + Run, + Build, + Test, +} + +#[ derive( Debug, Default ) ] +pub enum EntryType +{ + #[ default ] + Bin, + Lib, + Test, +} diff --git a/module/move/crates_tools/src/lib.rs b/module/move/crates_tools/src/lib.rs index 569549e54f..20a89cd7cf 100644 --- a/module/move/crates_tools/src/lib.rs +++ b/module/move/crates_tools/src/lib.rs @@ -1,13 +1,8 @@ #![ doc( html_logo_url = "https://raw.githubusercontent.com/Wandalen/wTools/master/asset/img/logo_v3_trans_square.png" ) ] #![ doc( html_favicon_url = "https://raw.githubusercontent.com/Wandalen/wTools/alpha/asset/img/logo_v3_trans_square_icon_small_v2.ico" ) ] #![ doc( html_root_url = "https://docs.rs/crates_tools/latest/crates_tools/" ) ] - #![ doc = include_str!( concat!( env!( "CARGO_MANIFEST_DIR" ), "/", "Readme.md" ) ) ] -//! -//! Tools to analyse crate files. -//! - /// Internal namespace. #[ cfg( feature = "enabled" ) ] pub( crate ) mod private From e646ede8f99654717b039c831f4a2ad5c9587117 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 17:12:58 +0300 Subject: [PATCH 02/24] collection_tools-v0.5.0 --- Cargo.toml | 2 +- module/core/collection_tools/Cargo.toml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 132c5b038f..0a3921b154 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -104,7 +104,7 @@ default-features = false features = [ "enabled" ] [workspace.dependencies.collection_tools] -version = "~0.4.0" +version = "~0.5.0" path = "module/core/collection_tools" default-features = false diff --git a/module/core/collection_tools/Cargo.toml b/module/core/collection_tools/Cargo.toml index 1c9f60b9b5..e244927ee5 100644 --- a/module/core/collection_tools/Cargo.toml +++ b/module/core/collection_tools/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "collection_tools" -version = "0.4.0" +version = "0.5.0" edition = "2021" authors = [ "Kostiantyn Wandalen ", From 474d61f1a1bf26d0984e56ce2325c56c3778e932 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 17:13:08 +0300 Subject: [PATCH 03/24] interval_adapter-v0.20.0 --- Cargo.toml | 2 +- module/core/interval_adapter/Cargo.toml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 0a3921b154..3cb9f9b628 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -92,7 +92,7 @@ default-features = false # path = "module/core/type_constructor_derive_pair_meta" [workspace.dependencies.interval_adapter] -version = "~0.19.0" +version = "~0.20.0" path = "module/core/interval_adapter" default-features = false features = [ "enabled" ] diff --git a/module/core/interval_adapter/Cargo.toml b/module/core/interval_adapter/Cargo.toml index 218f3b9d96..e02a0aeae2 100644 --- a/module/core/interval_adapter/Cargo.toml +++ b/module/core/interval_adapter/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "interval_adapter" -version = "0.19.0" +version = "0.20.0" edition = "2021" authors = [ "Kostiantyn Wandalen ", From d649b487e75c125fbf1dabf47512da398b39c7d0 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 17:13:26 +0300 Subject: [PATCH 04/24] program_tools : draft --- module/core/program_tools/Cargo.toml | 2 +- module/core/program_tools/src/program.rs | 180 +++++++++++------------ 2 files changed, 91 insertions(+), 91 deletions(-) diff --git a/module/core/program_tools/Cargo.toml b/module/core/program_tools/Cargo.toml index 30faf2edc3..a0f0bbe3f4 100644 --- a/module/core/program_tools/Cargo.toml +++ b/module/core/program_tools/Cargo.toml @@ -43,7 +43,7 @@ enabled = [ [dependencies] mod_interface = { workspace = true } -former = { workspace = true, features = [ "derive_former" ] } +# former = { workspace = true, features = [ "derive_former" ] } proper_path_tools = { workspace = true } error_tools = { workspace = true, features = [ "error_for_app" ] } # qqq : xxx : rid off error_for_app iter_tools = { workspace = true } diff --git a/module/core/program_tools/src/program.rs b/module/core/program_tools/src/program.rs index 90a3ffbc90..ba15d5fa3c 100644 --- a/module/core/program_tools/src/program.rs +++ b/module/core/program_tools/src/program.rs @@ -2,96 +2,96 @@ pub( crate ) mod private { - use former::Former; - use std:: - { - path::{ Path, PathBuf }, - // process::Command, - }; - - #[ derive( Debug, Default, Former ) ] - pub struct SourceFile - { - file_path : PathBuf, - data : GetData, - } - - #[ derive( Debug, Default, Former ) ] - pub struct Entry - { - source_file : SourceFile, - typ : EntryType, - } - - #[ derive( Debug, Default, Former ) ] - pub struct CargoFile - { - file_path : PathBuf, - data : GetData, - } - - #[ derive( Debug, Default, Former ) ] - // #[ debug ] - pub struct Program - { - write_path : Option< PathBuf >, - read_path : Option< PathBuf >, - entries : Vec< Entry >, - sources : Vec< SourceFile >, - cargo_file : Option< CargoFile >, - } - - #[ derive( Debug, Default, Former ) ] - pub struct ProgramRun - { - // #[ embed ] - program : Program, - calls : Vec< ProgramCall >, - } - - #[ derive( Debug ) ] - pub enum GetData - { - FromStr( &'static str ), - FromBin( &'static [ u8 ] ), - FromFile( PathBuf ), - FromString( String ), - } - - impl Default for GetData - { - fn default() -> Self - { - GetData::FromStr( "" ) - } - } - - #[ derive( Debug, Default ) ] - pub struct ProgramCall - { - action : ProgramAction, - current_path : Option< PathBuf >, - args : Vec< String >, - index_of_entry : i32, - } - - #[ derive( Debug, Default ) ] - pub enum ProgramAction - { - #[ default ] - Run, - Build, - Test, - } - - #[ derive( Debug, Default ) ] - pub enum EntryType - { - #[ default ] - Bin, - Lib, - Test, - } +// use former::Former; +// use std:: +// { +// path::{ Path, PathBuf }, +// // process::Command, +// }; +// +// #[ derive( Debug, Default, Former ) ] +// pub struct SourceFile +// { +// file_path : PathBuf, +// data : GetData, +// } +// +// #[ derive( Debug, Default, Former ) ] +// pub struct Entry +// { +// source_file : SourceFile, +// typ : EntryType, +// } +// +// #[ derive( Debug, Default, Former ) ] +// pub struct CargoFile +// { +// file_path : PathBuf, +// data : GetData, +// } +// +// #[ derive( Debug, Default, Former ) ] +// // #[ debug ] +// pub struct Program +// { +// write_path : Option< PathBuf >, +// read_path : Option< PathBuf >, +// entries : Vec< Entry >, +// sources : Vec< SourceFile >, +// cargo_file : Option< CargoFile >, +// } +// +// #[ derive( Debug, Default, Former ) ] +// pub struct ProgramRun +// { +// // #[ embed ] +// program : Program, +// calls : Vec< ProgramCall >, +// } +// +// #[ derive( Debug ) ] +// pub enum GetData +// { +// FromStr( &'static str ), +// FromBin( &'static [ u8 ] ), +// FromFile( PathBuf ), +// FromString( String ), +// } +// +// impl Default for GetData +// { +// fn default() -> Self +// { +// GetData::FromStr( "" ) +// } +// } +// +// #[ derive( Debug, Default ) ] +// pub struct ProgramCall +// { +// action : ProgramAction, +// current_path : Option< PathBuf >, +// args : Vec< String >, +// index_of_entry : i32, +// } +// +// #[ derive( Debug, Default ) ] +// pub enum ProgramAction +// { +// #[ default ] +// Run, +// Build, +// Test, +// } +// +// #[ derive( Debug, Default ) ] +// pub enum EntryType +// { +// #[ default ] +// Bin, +// Lib, +// Test, +// } } From 536a936423224e28dc9a55292ddc9f20f982946a Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 17:13:51 +0300 Subject: [PATCH 05/24] program_tools : draft --- module/core/program_tools/Cargo.toml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/module/core/program_tools/Cargo.toml b/module/core/program_tools/Cargo.toml index a0f0bbe3f4..0b836ed5ef 100644 --- a/module/core/program_tools/Cargo.toml +++ b/module/core/program_tools/Cargo.toml @@ -35,7 +35,7 @@ full = [ enabled = [ "mod_interface/enabled", - "former/enabled", + # "former/enabled", "proper_path_tools/enabled", "error_tools/enabled", "iter_tools/enabled", From dffdc2e53a46303e3e5d21afdde2c465767ce3ab Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 17:21:23 +0300 Subject: [PATCH 06/24] program_tools : evolve --- module/core/program_tools/Cargo.toml | 4 +- module/core/program_tools/src/program.rs | 182 ++++++++++++----------- 2 files changed, 94 insertions(+), 92 deletions(-) diff --git a/module/core/program_tools/Cargo.toml b/module/core/program_tools/Cargo.toml index 0b836ed5ef..30faf2edc3 100644 --- a/module/core/program_tools/Cargo.toml +++ b/module/core/program_tools/Cargo.toml @@ -35,7 +35,7 @@ full = [ enabled = [ "mod_interface/enabled", - # "former/enabled", + "former/enabled", "proper_path_tools/enabled", "error_tools/enabled", "iter_tools/enabled", @@ -43,7 +43,7 @@ enabled = [ [dependencies] mod_interface = { workspace = true } -# former = { workspace = true, features = [ "derive_former" ] } +former = { workspace = true, features = [ "derive_former" ] } proper_path_tools = { workspace = true } error_tools = { workspace = true, features = [ "error_for_app" ] } # qqq : xxx : rid off error_for_app iter_tools = { workspace = true } diff --git a/module/core/program_tools/src/program.rs b/module/core/program_tools/src/program.rs index ba15d5fa3c..8801bea38a 100644 --- a/module/core/program_tools/src/program.rs +++ b/module/core/program_tools/src/program.rs @@ -2,96 +2,98 @@ pub( crate ) mod private { -// use former::Former; -// use std:: -// { -// path::{ Path, PathBuf }, -// // process::Command, -// }; -// -// #[ derive( Debug, Default, Former ) ] -// pub struct SourceFile -// { -// file_path : PathBuf, -// data : GetData, -// } -// -// #[ derive( Debug, Default, Former ) ] -// pub struct Entry -// { -// source_file : SourceFile, -// typ : EntryType, -// } -// -// #[ derive( Debug, Default, Former ) ] -// pub struct CargoFile -// { -// file_path : PathBuf, -// data : GetData, -// } -// -// #[ derive( Debug, Default, Former ) ] -// // #[ debug ] -// pub struct Program -// { -// write_path : Option< PathBuf >, -// read_path : Option< PathBuf >, -// entries : Vec< Entry >, -// sources : Vec< SourceFile >, -// cargo_file : Option< CargoFile >, -// } -// -// #[ derive( Debug, Default, Former ) ] -// pub struct ProgramRun -// { -// // #[ embed ] -// program : Program, -// calls : Vec< ProgramCall >, -// } -// -// #[ derive( Debug ) ] -// pub enum GetData -// { -// FromStr( &'static str ), -// FromBin( &'static [ u8 ] ), -// FromFile( PathBuf ), -// FromString( String ), -// } -// -// impl Default for GetData -// { -// fn default() -> Self -// { -// GetData::FromStr( "" ) -// } -// } -// -// #[ derive( Debug, Default ) ] -// pub struct ProgramCall -// { -// action : ProgramAction, -// current_path : Option< PathBuf >, -// args : Vec< String >, -// index_of_entry : i32, -// } -// -// #[ derive( Debug, Default ) ] -// pub enum ProgramAction -// { -// #[ default ] -// Run, -// Build, -// Test, -// } -// -// #[ derive( Debug, Default ) ] -// pub enum EntryType -// { -// #[ default ] -// Bin, -// Lib, -// Test, -// } + use former::Former; + use std:: + { + path::{ Path, PathBuf }, + // process::Command, + }; + + #[ derive( Debug, Default, Former ) ] + pub struct SourceFile + { + file_path : PathBuf, + data : GetData, + } + + #[ derive( Debug, Default, Former ) ] + pub struct Entry + { + source_file : SourceFile, + typ : EntryType, + } + + #[ derive( Debug, Default, Former ) ] + pub struct CargoFile + { + file_path : PathBuf, + data : GetData, + } + + #[ derive( Debug, Default, Former ) ] + // #[ debug ] + pub struct Program + { + write_path : Option< PathBuf >, + read_path : Option< PathBuf >, + #[ subform( name = entry ) ] + entries : Vec< Entry >, + #[ subform( name = source ) ] + sources : Vec< SourceFile >, + cargo_file : Option< CargoFile >, + } + + #[ derive( Debug, Default, Former ) ] + pub struct ProgramPlan + { + // #[ embed ] + program : Program, + calls : Vec< ProgramCall >, + } + + #[ derive( Debug ) ] + pub enum GetData + { + FromStr( &'static str ), + FromBin( &'static [ u8 ] ), + FromFile( PathBuf ), + FromString( String ), + } + + impl Default for GetData + { + fn default() -> Self + { + GetData::FromStr( "" ) + } + } + + #[ derive( Debug, Default ) ] + pub struct ProgramCall + { + action : ProgramAction, + current_path : Option< PathBuf >, + args : Vec< String >, + index_of_entry : i32, + } + + #[ derive( Debug, Default ) ] + pub enum ProgramAction + { + #[ default ] + Run, + Build, + Test, + } + + #[ derive( Debug, Default ) ] + pub enum EntryType + { + #[ default ] + Bin, + Lib, + Test, + } } From 63f1299237cb7297853e060d6bdb3c35e9dcf663 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 17:22:22 +0300 Subject: [PATCH 07/24] program_tools : evolve --- module/core/program_tools/src/lib.rs | 2 ++ 1 file changed, 2 insertions(+) diff --git a/module/core/program_tools/src/lib.rs b/module/core/program_tools/src/lib.rs index fa8616e2be..ced6f3d8d8 100644 --- a/module/core/program_tools/src/lib.rs +++ b/module/core/program_tools/src/lib.rs @@ -4,6 +4,8 @@ #![ doc( html_root_url = "https://docs.rs/program_tools/latest/program_tools/" ) ] #![ doc = include_str!( concat!( env!( "CARGO_MANIFEST_DIR" ), "/", "Readme.md" ) ) ] +#![ allow( unused_imports, dead_code ) ] // xxx : rid off + #[ cfg( feature = "enabled" ) ] use mod_interface::mod_interface; From 1664214934d0059b6935ba11d7b20612c977d184 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 17:59:33 +0300 Subject: [PATCH 08/24] former : scalar subformer wip --- .../inc/former_tests/subformer_scalar.rs | 36 ++++++ .../former_tests/subformer_scalar_manual.rs | 117 ++++++++++++++++++ .../former_tests/subformer_subform_manual.rs | 3 +- module/core/former/tests/inc/mod.rs | 7 ++ 4 files changed, 161 insertions(+), 2 deletions(-) create mode 100644 module/core/former/tests/inc/former_tests/subformer_scalar.rs create mode 100644 module/core/former/tests/inc/former_tests/subformer_scalar_manual.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_scalar.rs b/module/core/former/tests/inc/former_tests/subformer_scalar.rs new file mode 100644 index 0000000000..c4c17ee75b --- /dev/null +++ b/module/core/former/tests/inc/former_tests/subformer_scalar.rs @@ -0,0 +1,36 @@ +#![ allow( dead_code ) ] + +use super::*; + +/// Child +#[ derive( Debug, Default, PartialEq, the_module::Former ) ] +pub struct Child +{ + name : String, + data : bool, +} + +/// Parent + +#[ derive( Debug, Default, PartialEq, the_module::Former ) ] +// #[ debug ] +// #[ derive( Debug, Default, PartialEq ) ] +pub struct Parent +{ + #[ scalar_subform ] + child : Child, +} + +impl< Definition > ParentFormer< Definition > +where + Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, +{ + +} + +// == begin of generated + +// == end of generated + +// include!( "./only_test/subformer_scalar.rs" ); +// xxx : uncomment \ No newline at end of file diff --git a/module/core/former/tests/inc/former_tests/subformer_scalar_manual.rs b/module/core/former/tests/inc/former_tests/subformer_scalar_manual.rs new file mode 100644 index 0000000000..55737b9803 --- /dev/null +++ b/module/core/former/tests/inc/former_tests/subformer_scalar_manual.rs @@ -0,0 +1,117 @@ +#![ allow( dead_code ) ] + +use super::*; + +/// Child +#[ derive( Debug, Default, PartialEq, the_module::Former ) ] +pub struct Child +{ + name : String, + data : bool, +} + +/// Parent + +#[ derive( Debug, Default, PartialEq, the_module::Former ) ] +// #[ debug ] +// #[ derive( Debug, Default, PartialEq ) ] +pub struct Parent +{ + // #[ scalar_subform ] + child : Child, +} + +impl< Definition > ParentFormer< Definition > +where + Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, +{ + + +} + +impl< Definition > ParentFormer< Definition > +where + Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, +{ + + #[ inline( always ) ] + pub fn _child_scalar_subformer< Former2, Definition2 >( self ) -> + Former2 + where + Definition2 : former::FormerDefinition + < + End = ParentFormerScalarSubformChildEnd< Definition >, + Storage = < Child as former::EntityToStorage >::Storage, + Formed = Self, + Context = Self, + >, + Definition2::Types : former::FormerDefinitionTypes + < + Storage = < Child as former::EntityToStorage >::Storage, + Formed = Self, + Context = Self, + >, + Former2 : former::FormerBegin< Definition2 >, + { + Former2::former_begin( None, Some( self ), ParentFormerScalarSubformChildEnd::default() ) + } + +} + +// = end + +/// Handles the completion of and element of subformer's container. +pub struct ParentFormerScalarSubformChildEnd< Definition > +{ + _phantom : core::marker::PhantomData< fn( Definition ) >, +} + +impl< Definition > Default +for ParentFormerScalarSubformChildEnd< Definition > +{ + #[ inline( always ) ] + fn default() -> Self + { + Self + { + _phantom : core::marker::PhantomData, + } + } +} + +impl< Types2, Definition > former::FormingEnd< Types2, > +for ParentFormerScalarSubformChildEnd< Definition > +where + Definition : former::FormerDefinition + < + Storage = < Parent as former::EntityToStorage >::Storage, + >, + Types2 : former::FormerDefinitionTypes + < + Storage = < Child as former::EntityToStorage >::Storage, + Formed = ParentFormer< Definition >, + Context = ParentFormer< Definition >, + >, +{ + #[ inline( always ) ] + fn call + ( + &self, + substorage : Types2::Storage, + super_former : core::option::Option< Types2::Context >, + ) + -> Types2::Formed + { + let mut super_former = super_former.unwrap(); + debug_assert!( super_former.storage.child.is_none() ); + super_former.storage.child = Some( ::core::convert::Into::into( former::StoragePreform::preform( substorage ) ) ); + super_former + } +} + +// == begin of generated + +// == end of generated + +// include!( "./only_test/subformer_scalar.rs" ); +// xxx : uncomment \ No newline at end of file diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_manual.rs b/module/core/former/tests/inc/former_tests/subformer_subform_manual.rs index dd75b254c0..e680200a0e 100644 --- a/module/core/former/tests/inc/former_tests/subformer_subform_manual.rs +++ b/module/core/former/tests/inc/former_tests/subformer_subform_manual.rs @@ -74,8 +74,6 @@ where Former2::former_begin( None, Some( self ), former::FormingEndClosure::new( on_end ) ) } - // < < #field_ty as former::Container >::Val as former::ValToEntry< #field_ty > > - // less generic, but more concise way to define custom subform setter #[ inline( always ) ] pub fn child( self, name : &str ) -> @@ -120,6 +118,7 @@ where // Definition::Types : former::FormerDefinitionTypes< Storage = < Parent as former::EntityToStorage >::Storage >, { + // xxx : rename #[ inline( always ) ] pub fn _children_add< Former2, Definition2 >( self ) -> Former2 diff --git a/module/core/former/tests/inc/mod.rs b/module/core/former/tests/inc/mod.rs index 069cbec9e2..9142bd56ab 100644 --- a/module/core/former/tests/inc/mod.rs +++ b/module/core/former/tests/inc/mod.rs @@ -66,6 +66,12 @@ mod former_tests #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] mod subformer_basic; + // xxx + // #[ cfg( any( not( feature = "no_std" ) ) ) ] + // mod subformer_scalar; + #[ cfg( any( not( feature = "no_std" ) ) ) ] + mod subformer_scalar_manual; + #[ cfg( any( not( feature = "no_std" ) ) ) ] mod subformer_container; #[ cfg( any( not( feature = "no_std" ) ) ) ] @@ -104,6 +110,7 @@ mod former_tests #[ cfg( any( not( feature = "no_std" ) ) ) ] mod subformer_subform_and_container_parametrized; + } #[ cfg( feature = "derive_components" ) ] From 36195cc0605370be72c14f78ceebbd0b6ea9511f Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 18:23:31 +0300 Subject: [PATCH 09/24] former : refactor tests --- ..._scalar_children.rs => scalar_children.rs} | 0 ...calar_children3.rs => scalar_children3.rs} | 0 .../only_test/subformer_scalar_subform.rs | 13 +++ ...{string_slice.rs => parametrized_slice.rs} | 0 ...manual.rs => parametrized_slice_manual.rs} | 0 ...rmer_container.rs => subform_container.rs} | 0 ...ntainers.rs => subform_container_basic.rs} | 0 ...l.rs => subform_container_basic_manual.rs} | 2 - ...r.rs => subform_container_basic_scalar.rs} | 0 ..._custom.rs => subform_container_custom.rs} | 0 ...licit.rs => subform_container_implicit.rs} | 0 ..._manual.rs => subform_container_manual.rs} | 0 ...er_named.rs => subform_container_named.rs} | 0 ...sic.rs => subform_container_playground.rs} | 1 + ...off.rs => subform_container_setter_off.rs} | 0 ...r_on.rs => subform_container_setter_on.rs} | 0 ...{subformer_subform.rs => subform_entry.rs} | 0 ...iner.rs => subform_entry_and_container.rs} | 2 +- ...bform_entry_and_container_parametrized.rs} | 0 ...=> subform_entry_and_container_private.rs} | 2 +- ...rm_hashmap.rs => subform_entry_hashmap.rs} | 0 ...tom.rs => subform_entry_hashmap_custom.rs} | 0 ...form_manual.rs => subform_entry_manual.rs} | 0 ...ubform_named.rs => subform_entry_named.rs} | 0 ...anual.rs => subform_entry_named_manual.rs} | 0 ...ter_off.rs => subform_entry_setter_off.rs} | 0 ...etter_on.rs => subform_entry_setter_on.rs} | 2 +- ...{subformer_scalar.rs => subform_scalar.rs} | 0 ...lar_manual.rs => subform_scalar_manual.rs} | 22 +++-- module/core/former/tests/inc/mod.rs | 89 +++++++++++-------- 30 files changed, 86 insertions(+), 47 deletions(-) rename module/core/former/tests/inc/former_tests/only_test/{subformer_scalar_children.rs => scalar_children.rs} (100%) rename module/core/former/tests/inc/former_tests/only_test/{subformer_scalar_children3.rs => scalar_children3.rs} (100%) create mode 100644 module/core/former/tests/inc/former_tests/only_test/subformer_scalar_subform.rs rename module/core/former/tests/inc/former_tests/{string_slice.rs => parametrized_slice.rs} (100%) rename module/core/former/tests/inc/former_tests/{string_slice_manual.rs => parametrized_slice_manual.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_container.rs => subform_container.rs} (100%) rename module/core/former/tests/inc/former_tests/{a_containers.rs => subform_container_basic.rs} (100%) rename module/core/former/tests/inc/former_tests/{a_containers_manual.rs => subform_container_basic_manual.rs} (99%) rename module/core/former/tests/inc/former_tests/{a_containers_scalar.rs => subform_container_basic_scalar.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_container_custom.rs => subform_container_custom.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_container_implicit.rs => subform_container_implicit.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_container_manual.rs => subform_container_manual.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_container_named.rs => subform_container_named.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_basic.rs => subform_container_playground.rs} (98%) rename module/core/former/tests/inc/former_tests/{subformer_container_setter_off.rs => subform_container_setter_off.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_container_setter_on.rs => subform_container_setter_on.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform.rs => subform_entry.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform_and_container.rs => subform_entry_and_container.rs} (95%) rename module/core/former/tests/inc/former_tests/{subformer_subform_and_container_parametrized.rs => subform_entry_and_container_parametrized.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform_and_container_private.rs => subform_entry_and_container_private.rs} (95%) rename module/core/former/tests/inc/former_tests/{subformer_subform_hashmap.rs => subform_entry_hashmap.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform_hashmap_custom.rs => subform_entry_hashmap_custom.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform_manual.rs => subform_entry_manual.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform_named.rs => subform_entry_named.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform_named_manual.rs => subform_entry_named_manual.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform_setter_off.rs => subform_entry_setter_off.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_subform_setter_on.rs => subform_entry_setter_on.rs} (94%) rename module/core/former/tests/inc/former_tests/{subformer_scalar.rs => subform_scalar.rs} (100%) rename module/core/former/tests/inc/former_tests/{subformer_scalar_manual.rs => subform_scalar_manual.rs} (78%) diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_scalar_children.rs b/module/core/former/tests/inc/former_tests/only_test/scalar_children.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/subformer_scalar_children.rs rename to module/core/former/tests/inc/former_tests/only_test/scalar_children.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_scalar_children3.rs b/module/core/former/tests/inc/former_tests/only_test/scalar_children3.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/subformer_scalar_children3.rs rename to module/core/former/tests/inc/former_tests/only_test/scalar_children3.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_scalar_subform.rs b/module/core/former/tests/inc/former_tests/only_test/subformer_scalar_subform.rs new file mode 100644 index 0000000000..7753f38dd5 --- /dev/null +++ b/module/core/former/tests/inc/former_tests/only_test/subformer_scalar_subform.rs @@ -0,0 +1,13 @@ + +#[ test ] +fn child() +{ + + let got = Parent::former() + .child().name( "a" ).data( true ).end() + .form(); + + let exp = Parent { child : Child { name : "a".to_string(), data : true } }; + a_id!( got, exp ); + +} diff --git a/module/core/former/tests/inc/former_tests/string_slice.rs b/module/core/former/tests/inc/former_tests/parametrized_slice.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/string_slice.rs rename to module/core/former/tests/inc/former_tests/parametrized_slice.rs diff --git a/module/core/former/tests/inc/former_tests/string_slice_manual.rs b/module/core/former/tests/inc/former_tests/parametrized_slice_manual.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/string_slice_manual.rs rename to module/core/former/tests/inc/former_tests/parametrized_slice_manual.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_container.rs b/module/core/former/tests/inc/former_tests/subform_container.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_container.rs rename to module/core/former/tests/inc/former_tests/subform_container.rs diff --git a/module/core/former/tests/inc/former_tests/a_containers.rs b/module/core/former/tests/inc/former_tests/subform_container_basic.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/a_containers.rs rename to module/core/former/tests/inc/former_tests/subform_container_basic.rs diff --git a/module/core/former/tests/inc/former_tests/a_containers_manual.rs b/module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs similarity index 99% rename from module/core/former/tests/inc/former_tests/a_containers_manual.rs rename to module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs index eed2cbfa9a..7a0b6292fe 100644 --- a/module/core/former/tests/inc/former_tests/a_containers_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs @@ -16,8 +16,6 @@ impl< > Struct1< > where { - - #[ inline( always ) ] pub fn former() -> Struct1Former< Struct1FormerDefinition<(), Struct1<>, former::ReturnPreformed> diff --git a/module/core/former/tests/inc/former_tests/a_containers_scalar.rs b/module/core/former/tests/inc/former_tests/subform_container_basic_scalar.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/a_containers_scalar.rs rename to module/core/former/tests/inc/former_tests/subform_container_basic_scalar.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_container_custom.rs b/module/core/former/tests/inc/former_tests/subform_container_custom.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_container_custom.rs rename to module/core/former/tests/inc/former_tests/subform_container_custom.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_container_implicit.rs b/module/core/former/tests/inc/former_tests/subform_container_implicit.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_container_implicit.rs rename to module/core/former/tests/inc/former_tests/subform_container_implicit.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_container_manual.rs b/module/core/former/tests/inc/former_tests/subform_container_manual.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_container_manual.rs rename to module/core/former/tests/inc/former_tests/subform_container_manual.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_container_named.rs b/module/core/former/tests/inc/former_tests/subform_container_named.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_container_named.rs rename to module/core/former/tests/inc/former_tests/subform_container_named.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_basic.rs b/module/core/former/tests/inc/former_tests/subform_container_playground.rs similarity index 98% rename from module/core/former/tests/inc/former_tests/subformer_basic.rs rename to module/core/former/tests/inc/former_tests/subform_container_playground.rs index 11f5a65779..e6fc082da0 100644 --- a/module/core/former/tests/inc/former_tests/subformer_basic.rs +++ b/module/core/former/tests/inc/former_tests/subform_container_playground.rs @@ -31,6 +31,7 @@ pub struct Property< Name > code : isize, } +// xxx : implement derive new /// generated by new impl< Name > Property< Name > { diff --git a/module/core/former/tests/inc/former_tests/subformer_container_setter_off.rs b/module/core/former/tests/inc/former_tests/subform_container_setter_off.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_container_setter_off.rs rename to module/core/former/tests/inc/former_tests/subform_container_setter_off.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_container_setter_on.rs b/module/core/former/tests/inc/former_tests/subform_container_setter_on.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_container_setter_on.rs rename to module/core/former/tests/inc/former_tests/subform_container_setter_on.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform.rs b/module/core/former/tests/inc/former_tests/subform_entry.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_subform.rs rename to module/core/former/tests/inc/former_tests/subform_entry.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_and_container.rs b/module/core/former/tests/inc/former_tests/subform_entry_and_container.rs similarity index 95% rename from module/core/former/tests/inc/former_tests/subformer_subform_and_container.rs rename to module/core/former/tests/inc/former_tests/subform_entry_and_container.rs index 6a3546113e..077c3f9ef8 100644 --- a/module/core/former/tests/inc/former_tests/subformer_subform_and_container.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_and_container.rs @@ -53,4 +53,4 @@ where include!( "./only_test/subformer_subform_child.rs" ); include!( "./only_test/subformer_container_children2.rs" ); -include!( "./only_test/subformer_scalar_children3.rs" ); +include!( "./only_test/scalar_children3.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_and_container_parametrized.rs b/module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_subform_and_container_parametrized.rs rename to module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_and_container_private.rs b/module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs similarity index 95% rename from module/core/former/tests/inc/former_tests/subformer_subform_and_container_private.rs rename to module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs index 1c915adce1..3a4b58c093 100644 --- a/module/core/former/tests/inc/former_tests/subformer_subform_and_container_private.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs @@ -53,4 +53,4 @@ where include!( "./only_test/subformer_subform_child.rs" ); include!( "./only_test/subformer_container_children2.rs" ); -include!( "./only_test/subformer_scalar_children3.rs" ); +include!( "./only_test/scalar_children3.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_hashmap.rs b/module/core/former/tests/inc/former_tests/subform_entry_hashmap.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_subform_hashmap.rs rename to module/core/former/tests/inc/former_tests/subform_entry_hashmap.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_hashmap_custom.rs b/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_subform_hashmap_custom.rs rename to module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_manual.rs b/module/core/former/tests/inc/former_tests/subform_entry_manual.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_subform_manual.rs rename to module/core/former/tests/inc/former_tests/subform_entry_manual.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_named.rs b/module/core/former/tests/inc/former_tests/subform_entry_named.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_subform_named.rs rename to module/core/former/tests/inc/former_tests/subform_entry_named.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_named_manual.rs b/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_subform_named_manual.rs rename to module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_setter_off.rs b/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_subform_setter_off.rs rename to module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_subform_setter_on.rs b/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs similarity index 94% rename from module/core/former/tests/inc/former_tests/subformer_subform_setter_on.rs rename to module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs index 29378ff208..eff8d04a23 100644 --- a/module/core/former/tests/inc/former_tests/subformer_subform_setter_on.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs @@ -40,5 +40,5 @@ where } -include!( "./only_test/subformer_scalar_children.rs" ); +include!( "./only_test/scalar_children.rs" ); include!( "./only_test/subformer_subform_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subformer_scalar.rs b/module/core/former/tests/inc/former_tests/subform_scalar.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/subformer_scalar.rs rename to module/core/former/tests/inc/former_tests/subform_scalar.rs diff --git a/module/core/former/tests/inc/former_tests/subformer_scalar_manual.rs b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs similarity index 78% rename from module/core/former/tests/inc/former_tests/subformer_scalar_manual.rs rename to module/core/former/tests/inc/former_tests/subform_scalar_manual.rs index 55737b9803..3ebce7aa91 100644 --- a/module/core/former/tests/inc/former_tests/subformer_scalar_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs @@ -17,6 +17,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { + #[ scalar( setter = false ) ] // #[ scalar_subform ] child : Child, } @@ -26,6 +27,13 @@ where Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, { + #[ inline( always ) ] + pub fn child( self ) -> + ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + { + self._child_scalar_subformer + ::< < Child as former::EntityToFormer< _ > >::Former, _, >() + } } @@ -40,7 +48,7 @@ where where Definition2 : former::FormerDefinition < - End = ParentFormerScalarSubformChildEnd< Definition >, + End = ParentFormerSubformScalarChildEnd< Definition >, Storage = < Child as former::EntityToStorage >::Storage, Formed = Self, Context = Self, @@ -53,7 +61,7 @@ where >, Former2 : former::FormerBegin< Definition2 >, { - Former2::former_begin( None, Some( self ), ParentFormerScalarSubformChildEnd::default() ) + Former2::former_begin( None, Some( self ), ParentFormerSubformScalarChildEnd::default() ) } } @@ -61,13 +69,13 @@ where // = end /// Handles the completion of and element of subformer's container. -pub struct ParentFormerScalarSubformChildEnd< Definition > +pub struct ParentFormerSubformScalarChildEnd< Definition > { _phantom : core::marker::PhantomData< fn( Definition ) >, } impl< Definition > Default -for ParentFormerScalarSubformChildEnd< Definition > +for ParentFormerSubformScalarChildEnd< Definition > { #[ inline( always ) ] fn default() -> Self @@ -80,7 +88,7 @@ for ParentFormerScalarSubformChildEnd< Definition > } impl< Types2, Definition > former::FormingEnd< Types2, > -for ParentFormerScalarSubformChildEnd< Definition > +for ParentFormerSubformScalarChildEnd< Definition > where Definition : former::FormerDefinition < @@ -113,5 +121,5 @@ where // == end of generated -// include!( "./only_test/subformer_scalar.rs" ); -// xxx : uncomment \ No newline at end of file +include!( "./only_test/subformer_scalar_subform.rs" ); +// xxx : uncomment diff --git a/module/core/former/tests/inc/mod.rs b/module/core/former/tests/inc/mod.rs index 9142bd56ab..5ec11b2c1f 100644 --- a/module/core/former/tests/inc/mod.rs +++ b/module/core/former/tests/inc/mod.rs @@ -9,6 +9,8 @@ mod former_tests #[ allow( unused_imports ) ] use super::*; + // = container former + #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] mod container_former_common; #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] @@ -18,16 +20,20 @@ mod former_tests #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] mod container_former_hashmap; + // = basic + mod a_basic_manual; mod a_basic; mod a_primitives_manual; mod a_primitives; - mod a_containers_scalar; + mod subform_container_basic_scalar; #[ cfg( not( feature = "no_std" ) ) ] - mod a_containers_manual; + mod subform_container_basic_manual; #[ cfg( not( feature = "no_std" ) ) ] - mod a_containers; + mod subform_container_basic; + + // = attribute mod attribute_default_container; mod attribute_default_primitive; @@ -39,13 +45,7 @@ mod former_tests mod attribute_alias; mod attribute_feature; - mod string_slice_manual; - mod string_slice; - mod unsigned_primitive_types; - mod default_user_type; - mod user_type_no_default; - mod user_type_no_debug; - mod visibility; + // = name collision mod name_collision_former_hashmap_without_parameter; mod name_collision_former_vector_without_parameter; @@ -54,6 +54,8 @@ mod former_tests mod name_collision_end; mod name_collision_on_end; + // = parametrization + #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] mod parametrized_struct_manual; #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] @@ -63,53 +65,70 @@ mod former_tests mod parametrized_field; mod parametrized_field_where; - #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod subformer_basic; + mod parametrized_slice_manual; + mod parametrized_slice; - // xxx - // #[ cfg( any( not( feature = "no_std" ) ) ) ] - // mod subformer_scalar; - #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_scalar_manual; + // = etc + mod unsigned_primitive_types; + mod default_user_type; + mod user_type_no_default; + mod user_type_no_debug; + mod visibility; + + // = subform container + + #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] + mod subform_container_playground; + #[ cfg( any( not( feature = "no_std" ) ) ) ] + mod subform_container; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_container; + mod subform_container_manual; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_container_manual; + mod subform_container_implicit; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_container_implicit; + mod subform_container_setter_off; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_container_setter_off; + mod subform_container_named; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_container_named; + mod subform_container_custom; + + // = subform scalar + + // xxx + // #[ cfg( any( not( feature = "no_std" ) ) ) ] + // mod subform_scalar; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_container_custom; + mod subform_scalar_manual; + + // = subform entry #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform; + mod subform_entry; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_manual; + mod subform_entry_manual; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_named; + mod subform_entry_named; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_named_manual; + mod subform_entry_named_manual; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_setter_off; + mod subform_entry_setter_off; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_setter_on; + mod subform_entry_setter_on; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_hashmap; + mod subform_entry_hashmap; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_hashmap_custom; + mod subform_entry_hashmap_custom; + + // = subform entry and container #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_and_container; + mod subform_entry_and_container; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_and_container_private; + mod subform_entry_and_container_private; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subformer_subform_and_container_parametrized; - + mod subform_entry_and_container_parametrized; } From 6bb0e0afe52f2956ad3436f5db997c06df098879 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 18:32:55 +0300 Subject: [PATCH 10/24] former : refactor --- module/core/former/Readme.md | 2 +- .../examples/former_custom_subform_setter.rs | 2 +- .../examples/former_custom_subform_setter2.rs | 4 +- .../tests/inc/former_tests/subform_entry.rs | 4 +- .../subform_entry_and_container.rs | 2 +- ...ubform_entry_and_container_parametrized.rs | 2 +- .../subform_entry_and_container_private.rs | 2 +- .../subform_entry_hashmap_custom.rs | 8 +- .../inc/former_tests/subform_entry_manual.rs | 24 +- .../inc/former_tests/subform_entry_named.rs | 4 +- .../subform_entry_named_manual.rs | 10 +- .../former_tests/subform_entry_setter_off.rs | 2 +- .../former_tests/subform_entry_setter_on.rs | 2 +- .../former_meta/src/derive_former/field.rs | 920 +++++++++--------- .../src/derive_former/field_attrs.rs | 2 +- 15 files changed, 495 insertions(+), 495 deletions(-) diff --git a/module/core/former/Readme.md b/module/core/former/Readme.md index 35aea33b92..84c824781f 100644 --- a/module/core/former/Readme.md +++ b/module/core/former/Readme.md @@ -1091,7 +1091,7 @@ The `child` function within `ParentFormer` is a custom subform setter that plays #[ inline( always ) ] pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._child_add::< ChildFormer< _ >, _, >() + self._child_subform_entry::< ChildFormer< _ >, _, >() .name( name ) } diff --git a/module/core/former/examples/former_custom_subform_setter.rs b/module/core/former/examples/former_custom_subform_setter.rs index bff35ac6ea..5e76abbcc9 100644 --- a/module/core/former/examples/former_custom_subform_setter.rs +++ b/module/core/former/examples/former_custom_subform_setter.rs @@ -61,7 +61,7 @@ fn main() #[ inline( always ) ] pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._child_add::< ChildFormer< _ >, _, >() + self._child_subform_entry::< ChildFormer< _ >, _, >() .name( name ) } diff --git a/module/core/former/examples/former_custom_subform_setter2.rs b/module/core/former/examples/former_custom_subform_setter2.rs index 7c781d6128..96c70e130f 100644 --- a/module/core/former/examples/former_custom_subform_setter2.rs +++ b/module/core/former/examples/former_custom_subform_setter2.rs @@ -1,7 +1,7 @@ // Example former_custom_subformer2.rs //! -//! This example extends the demonstration of nested builder patterns using the `Former` trait, highlighting a parent-child relationship similar to the `former_custom_subformer.rs`. However, this variant, `former_custom_subformer2.rs`, showcases a more flexible but complex approach to managing the `child` field in the `Parent` struct—a `HashMap` of `Child` entities. Instead of relying on a predefined subformer setter (`_child_add`), this example constructs the subformer logic directly using closures. This method provides greater control over how children are added and managed within the `Parent`. +//! This example extends the demonstration of nested builder patterns using the `Former` trait, highlighting a parent-child relationship similar to the `former_custom_subformer.rs`. However, this variant, `former_custom_subformer2.rs`, showcases a more flexible but complex approach to managing the `child` field in the `Parent` struct—a `HashMap` of `Child` entities. Instead of relying on a predefined subformer setter (`_child_subform_entry`), this example constructs the subformer logic directly using closures. This method provides greater control over how children are added and managed within the `Parent`. //! //! #### Custom Subform Setter //! @@ -85,7 +85,7 @@ fn main() } /// Dynamically adds named child entities to the `Parent` structure using a custom subformer. - /// Unlike traditional methods that might use predefined setters like `_child_add`, this function + /// Unlike traditional methods that might use predefined setters like `_child_subform_entry`, this function /// explicitly constructs a subformer setup through a closure to provide greater flexibility and control. /// #[ inline( always ) ] diff --git a/module/core/former/tests/inc/former_tests/subform_entry.rs b/module/core/former/tests/inc/former_tests/subform_entry.rs index e112d38ecd..f049627d96 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry.rs @@ -29,14 +29,14 @@ where #[ inline( always ) ] pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add::< ChildFormer< _ >, _, >() + self._children_subform_entry::< ChildFormer< _ >, _, >() .name( name ) } #[ inline( always ) ] pub fn _child( self ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add + self._children_subform_entry ::< < Child as former::EntityToFormer< _ > >::Former, _, >() } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_and_container.rs b/module/core/former/tests/inc/former_tests/subform_entry_and_container.rs index 077c3f9ef8..3e04d86cbd 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_and_container.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_and_container.rs @@ -31,7 +31,7 @@ where pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add + self._children_subform_entry ::< ChildFormer< _ >, _, >() .name( name ) } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs b/module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs index 43347fc9ce..c5d1a935f1 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs @@ -35,7 +35,7 @@ where pub fn child( self, name : &str ) -> ChildAsSubformer< 'child, str, Self, impl ChildAsSubformerEnd< 'child, str, Self > > { - self._children_add + self._children_subform_entry ::< ChildFormer< '_, _, _ >, _, >() .name( name ) } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs b/module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs index 3a4b58c093..eefbe42e21 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs @@ -31,7 +31,7 @@ where fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add + self._children_subform_entry ::< ChildFormer< _ >, _, >() .name( name ) } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs b/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs index 175197fab8..2fb2f5028b 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs @@ -31,7 +31,7 @@ where // more generic version #[ inline( always ) ] - pub fn _children_add_with_closure< Former2, Definition2, Types2 >( self ) -> + pub fn _children_subform_entry_with_closure< Former2, Definition2, Types2 >( self ) -> Former2 where Types2 : former::FormerDefinitionTypes @@ -75,15 +75,15 @@ where Former2::former_begin( None, Some( self ), former::FormingEndClosure::new( on_end ) ) } - // reuse _command_add + // reuse _command_subform_entry #[ inline( always ) ] pub fn command( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._command_add::< ChildFormer< _ >, _, >() + self._command_subform_entry::< ChildFormer< _ >, _, >() .name( name ) } - // that's how you should do custom subformer setters if you can't reuse _command_add + // that's how you should do custom subformer setters if you can't reuse _command_subform_entry #[ inline( always ) ] pub fn command2( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { diff --git a/module/core/former/tests/inc/former_tests/subform_entry_manual.rs b/module/core/former/tests/inc/former_tests/subform_entry_manual.rs index e680200a0e..f8c9bcac63 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_manual.rs @@ -30,7 +30,7 @@ where { #[ inline( always ) ] - pub fn _children_add_with_closure< Former2, Definition2, Types2 >( self ) -> + pub fn _children_subform_entry_with_closure< Former2, Definition2, Types2 >( self ) -> Former2 where Types2 : former::FormerDefinitionTypes @@ -79,7 +79,7 @@ where pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add + self._children_subform_entry ::< ChildFormer< _ >, _, >() .name( name ) } @@ -88,7 +88,7 @@ where // pub fn _child( self ) -> // ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > // { - // self._children_add + // self._children_subform_entry // ::< < Child as former::EntityToFormer< _ > >::Former, _, >() // } @@ -97,14 +97,14 @@ where pub fn _child( self ) -> < < Vec< Child > as former::Container >::Entry as former::EntityToFormer < - // ChildFormerDefinition< Self, Self, ParentFormerAddChildrenEnd< Definition > >, + // ChildFormerDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > >, < - < Vec< Child > as former::Container >::Entry as former::EntityToDefinition< Self, Self, ParentFormerAddChildrenEnd< Definition > > + < Vec< Child > as former::Container >::Entry as former::EntityToDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > > >::Definition, > >::Former { - self._children_add + self._children_subform_entry ::< < < Vec< Child > as former::Container >::Entry as former::EntityToFormer< _ > >::Former, _, >() } @@ -120,12 +120,12 @@ where // xxx : rename #[ inline( always ) ] - pub fn _children_add< Former2, Definition2 >( self ) -> + pub fn _children_subform_entry< Former2, Definition2 >( self ) -> Former2 where Definition2 : former::FormerDefinition < - End = ParentFormerAddChildrenEnd< Definition >, + End = ParentSubformEntryChildrenEnd< Definition >, Storage = < Child as former::EntityToStorage >::Storage, Formed = Self, Context = Self, @@ -138,19 +138,19 @@ where >, Former2 : former::FormerBegin< Definition2 >, { - Former2::former_begin( None, Some( self ), ParentFormerAddChildrenEnd::default() ) + Former2::former_begin( None, Some( self ), ParentSubformEntryChildrenEnd::default() ) } } /// Handles the completion of and element of subformer's container. -pub struct ParentFormerAddChildrenEnd< Definition > +pub struct ParentSubformEntryChildrenEnd< Definition > { _phantom : core::marker::PhantomData< fn( Definition ) >, } impl< Definition > Default -for ParentFormerAddChildrenEnd< Definition > +for ParentSubformEntryChildrenEnd< Definition > { #[ inline( always ) ] fn default() -> Self @@ -163,7 +163,7 @@ for ParentFormerAddChildrenEnd< Definition > } impl< Types2, Definition > former::FormingEnd< Types2, > -for ParentFormerAddChildrenEnd< Definition > +for ParentSubformEntryChildrenEnd< Definition > where Definition : former::FormerDefinition < diff --git a/module/core/former/tests/inc/former_tests/subform_entry_named.rs b/module/core/former/tests/inc/former_tests/subform_entry_named.rs index e834e8b30d..5cbe37bb68 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_named.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_named.rs @@ -40,7 +40,7 @@ where pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add + self._children_subform_entry ::< ChildFormer< _ >, _, >() .name( name ) } @@ -49,7 +49,7 @@ where // pub fn _child( self ) -> // ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > // { - // self._children_add + // self._children_subform_entry // ::< < Child as former::EntityToFormer< _ > >::Former, _, >() // } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs b/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs index c169a74d79..1d10b20025 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs @@ -33,7 +33,7 @@ where pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add + self._children_subform_entry ::< ChildFormer< _ >, _, >() .name( name ) } @@ -42,7 +42,7 @@ where // pub fn _child( self ) -> // ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > // { - // self._children_add + // self._children_subform_entry // ::< < Child as former::EntityToFormer< _ > >::Former, _, >() // } @@ -50,14 +50,14 @@ where pub fn _child( self ) -> < < Vec< Child > as former::Container >::Entry as former::EntityToFormer < - // ChildFormerDefinition< Self, Self, ParentFormerAddChildrenEnd< Definition > >, + // ChildFormerDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > >, < - < Vec< Child > as former::Container >::Entry as former::EntityToDefinition< Self, Self, ParentFormerAddChildrenEnd< Definition > > + < Vec< Child > as former::Container >::Entry as former::EntityToDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > > >::Definition, > >::Former { - self._children_add + self._children_subform_entry ::< < < Vec< Child > as former::Container >::Entry as former::EntityToFormer< _ > >::Former, _, >() } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs b/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs index e5a2f9eb61..d615890722 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs @@ -39,7 +39,7 @@ where pub fn children2( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add + self._children_subform_entry ::< ChildFormer< _ >, _, >() .name( name ) } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs b/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs index eff8d04a23..518e7d5d4a 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs @@ -33,7 +33,7 @@ where pub fn children2( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._children_add + self._children_subform_entry ::< ChildFormer< _ >, _, >() .name( name ) } diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index a38cdead95..b299d49b9e 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -33,8 +33,8 @@ storage_field_optional storage_field_preform storage_field_name former_field_setter -subform_setter -container_setter +subform_entry_setter +subform_container_setter scalar_setter scalar_setter_name @@ -352,7 +352,7 @@ scalar_setter_required // container setter let ( setters_code, namespace_code ) = if let Some( _ ) = &self.attrs.container { - let ( setters_code2, namespace_code2 ) = self.container_setter + let ( setters_code2, namespace_code2 ) = self.subform_container_setter ( stru, former, @@ -372,7 +372,7 @@ scalar_setter_required // subform setter let ( setters_code, namespace_code ) = if self.attrs.subform.is_some() { - let ( setters_code2, namespace_code2 ) = self.subform_setter + let ( setters_code2, namespace_code2 ) = self.subform_entry_setter ( stru, former, @@ -393,150 +393,263 @@ scalar_setter_required Ok( ( setters_code, namespace_code ) ) } - /// Generates setter functions for subforms within a container structure in a builder pattern. /// - /// This function is a key component of the `former` crate's capability to dynamically create setters for manipulating - /// data within a nested container structure like a `HashMap` or a `Vec`. The setters facilitate the addition or - /// modification of entries within the container, directly from the parent former's context. + /// Generate a single scalar setter for the 'field_ident' with the 'setter_name' name. /// - /// See `examples/subformer_subform_manual.rs` for example of generated code. + /// Used as a helper function for former_field_setter(), which generates alias setters + /// + /// # Example of generated code /// + /// ```ignore + /// #[ doc = "Setter for the 'int_1' field." ] + /// #[ inline ] + /// pub fn int_1< Src >( mut self, src : Src ) -> Self + /// where + /// Src : ::core::convert::Into< i32 >, + /// { + /// debug_assert!( self.int_1.is_none() ); + /// self.storage.int_1 = ::core::option::Option::Some( ::core::convert::Into::into( src ) ); + /// self + /// } + /// ``` #[ inline ] - pub fn subform_setter + pub fn scalar_setter ( &self, - stru : &syn::Ident, former : &syn::Ident, former_storage : &syn::Ident, - former_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, - struct_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, - struct_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, - struct_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, ) - -> Result< ( TokenStream, TokenStream ) > + -> TokenStream { - - // if self.attrs.subform.is_none() - // { - // return Ok( qt!{ } ); - // } - - use convert_case::{ Case, Casing }; let field_ident = self.ident; - let field_typ = self.non_optional_ty; - let attr = self.attrs.subform.as_ref().unwrap(); - // let params = typ::type_parameters( &self.non_optional_ty, .. ); + let typ = self.non_optional_ty; + let setter_name = self.scalar_setter_name(); + let attr = self.attrs.scalar.as_ref(); - // example : `child` - let setter_name = self.subform_setter_name(); + if attr.is_some() && attr.unwrap().hint + { + let hint = format! + ( + r#" - // example : `ParentFormerAddChildrenEnd`` - let former_add_end_name = format!( "{}FormerAdd{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); - let former_add_end = syn::Ident::new( &former_add_end_name, field_ident.span() ); +impl< Definition > {}< Definition > +where + Definition : former::FormerDefinition< Storage = {} >, +{{ + #[ inline ] + pub fn {}< Src >( mut self, src : Src ) -> Self + where + Src : ::core::convert::Into< {} >, + {{ + debug_assert!( self.storage.{}.is_none() ); + self.storage.{} = ::core::option::Option::Some( ::core::convert::Into::into( src ) ); + self + }} +}} - // example : `_children_former` - let field_add_name = format!( "_{}_add", field_ident ); - let field_add = syn::Ident::new( &field_add_name, field_ident.span() ); + "#, + former, + former_storage, + field_ident, + format!( "{}", qt!{ #typ } ), + field_ident, + field_ident, + ); + println!( "{hint}" ); + } + + if !self.scalar_setter_required() + { + return qt! {}; + } let doc = format! ( - r#" + "Scalar setter for the '{}' field.", + field_ident, + ); -Initiates the addition of {field_ident} to the `{stru}` entity using a dedicated subformer. + qt! + { + #[ doc = #doc ] + #[ inline ] + pub fn #setter_name< Src >( mut self, src : Src ) -> Self + where + Src : ::core::convert::Into< #typ >, + { + debug_assert!( self.storage.#field_ident.is_none() ); + self.storage.#field_ident = ::core::option::Option::Some( ::core::convert::Into::into( src ) ); + self + } + } + } -This method configures and returns a subformer specialized for the `{0}` entities' formation process, -which is part of the `{stru}` entity's construction. The subformer is set up with a specific end condition -handled by `{former_add_end}`, ensuring that the {field_ident} are properly integrated into the -parent's structure once formed. + /// + /// Generate a container setter for the 'field_ident' with the 'setter_name' name. + /// + /// See `examples/subformer_container_manual.rs` for example of generated code. -# Returns + #[ inline ] + pub fn subform_container_setter + ( + &self, + stru : &syn::Ident, + former : &syn::Ident, + former_storage : &syn::Ident, + former_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, + former_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, + former_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, + original_input : &proc_macro::TokenStream, + ) + -> Result< ( TokenStream, TokenStream ) > + { + let attr = self.attrs.container.as_ref().unwrap(); + let field_ident = &self.ident; + let field_typ = &self.non_optional_ty; + let params = typ::type_parameters( &field_typ, .. ); -Returns an instance of `Former2`, a subformer ready to begin the formation process for `{0}` entities, -allowing for dynamic and flexible construction of the `{stru}` entity's {field_ident}. + use convert_case::{ Case, Casing }; + let former_assign_end_name = format!( "{}FormerAssign{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); + let former_assign_end = syn::Ident::new( &former_assign_end_name, field_ident.span() ); + let field_assign_name = format!( "_{}_container_former", field_ident ); + let field_assign = syn::Ident::new( &field_assign_name, field_ident.span() ); - "#, - format!( "{}", qt!{ #field_typ } ), + // example : `former::VectorDefinition` + let subformer_definition = &attr.definition; + let subformer_definition = if subformer_definition.is_some() + { + qt! + { + #subformer_definition + < + #( #params, )* + Self, + Self, + #former_assign_end< Definition >, + > + } + // former::VectorDefinition< String, Self, Self, Struct1FormerAssignVec1End, > + } + else + { + qt! + { + < + #field_typ as former::EntityToDefinition< Self, Self, #former_assign_end< Definition > > + >::Definition + } + // < Vec< String > as former::EntityToDefinition< Self, Self, Struct1FormerAssignVec1End > >::Definition + }; + + let doc = format! + ( + "Container setter for the '{}' field. Method {} unlike method {} accept custom container subformer.", + field_ident, + field_assign_name, + field_ident, ); - let setters_code = qt! + let setter1 = + qt! { #[ doc = #doc ] #[ inline( always ) ] - pub fn #field_add< Former2, Definition2 >( self ) -> Former2 + pub fn #field_assign< Former2 >( self ) -> Former2 where - Definition2 : former::FormerDefinition + Former2 : former::FormerBegin < - End = #former_add_end< Definition >, - Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, - Formed = Self, - Context = Self, + #subformer_definition, >, - Definition2::Types : former::FormerDefinitionTypes + #subformer_definition : former::FormerDefinition < - Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, - Formed = Self, - Context = Self, + // Storage : former::ContainerAdd< Entry = < #field_typ as former::Container >::Entry >, + Storage = #field_typ, + Context = #former< #former_generics_ty >, + End = #former_assign_end< Definition >, >, - Former2 : former::FormerBegin< Definition2 >, { - Former2::former_begin( None, Some( self ), #former_add_end::default() ) + Former2::former_begin( None, Some( self ), #former_assign_end::< Definition >::default() ) } + // #[ inline( always ) ] + // pub fn _hashset_1_assign< Former2 >( self ) -> Former2 + // where + // Former2 : former::FormerBegin + // < + // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + // >, + // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > > : former::FormerDefinition + // < + // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, + // Context = Struct1Former< Definition >, + // End = Struct1FormerAssignHashset1End< Definition >, + // >, + // { + // Former2::former_begin( None, Some( self ), Struct1FormerAssignHashset1End::< Definition >::default() ) + // } + }; - let setters_code = if attr.setter() + let setter_name = self.container_setter_name(); + let setter2 = if let Some( setter_name ) = setter_name { - - let doc = format! - ( - r#" -Provides a user-friendly interface to add an instancce of {field_ident} to the {stru}. - -# Returns - -Returns an instance of `Former2`, a subformer ready to begin the formation process for `{0}` entities, -allowing for dynamic and flexible construction of the `{stru}` entity's {field_ident}. - - "#, - format!( "{}", qt!{ #field_typ } ), - ); - qt! { - #setters_code #[ doc = #doc ] #[ inline( always ) ] - pub fn #setter_name( self ) -> - < < #field_typ as former::Container >::Val as former::EntityToFormer + pub fn #setter_name( self ) -> former::ContainerFormer:: + < + // ( #( #params, )* ), + < #field_typ as former::Container >::Entry, + #subformer_definition, + > + where + #subformer_definition : former::FormerDefinition < - < - < #field_typ as former::Container >::Val as former::EntityToDefinition< Self, Self, #former_add_end < Definition > > - >::Definition, - > - >::Former - // #as_subformer< Self, impl #as_subformer_end< Self > > + // Storage : former::ContainerAdd< Entry = < #field_typ as former::Container >::Entry >, + Storage = #field_typ, + Context = #former< #former_generics_ty >, + End = #former_assign_end < Definition >, + >, { - self.#field_add - ::< < < #field_typ as former::Container >::Val as former::EntityToFormer< _ > >::Former, _, >() - // ::< #former< _ >, _, >() + self.#field_assign::< former::ContainerFormer:: + < + _, + _, + // ( #( #params, )* ), + // #subformer_definition, + > > () } - } - // #[ inline( always ) ] - // pub fn child( self ) -> - // ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > - // { - // self._children_add - // ::< < Child as former::EntityToFormer< _ > >::Former, _, >() - // } + // #[ inline( always ) ] + // pub fn hashset_1( self ) -> former::ContainerFormer:: + // < + // String, + // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + // > + // where + // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > > : former::FormerDefinition + // < + // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, + // Context = Struct1Former< Definition >, + // End = Struct1FormerAssignHashset1End< Definition >, + // >, + // { + // self._hashset_1_assign::< former::ContainerFormer:: + // < + // String, + // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + // > > () + // } + } } else { - setters_code + qt!{} }; if attr.hint @@ -545,79 +658,106 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i ( r#" -/// Initializes and configures a subformer for adding named child entities. This method leverages an internal function -/// to create and return a configured subformer instance. It allows for the dynamic addition of children with specific names, -/// integrating them into the formation process of the parent entity. +/// The containr setter provides a container setter that returns a ContainerFormer tailored for managing a collection of child entities. It employs a generic container definition to facilitate operations on the entire collection, such as adding or updating elements. -impl< Definition > {}< Definition > +impl< Definition, > {}< Definition, > where Definition : former::FormerDefinition< Storage = {} >, {{ #[ inline( always ) ] - pub fn {}( self ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + pub fn {}( self ) -> former::ContainerFormer:: + < + ( {} ), + former::HashMapDefinition< {} Self, Self, {}< Definition >, > + // Replace `HashMapDefinition` with definition for your container + > {{ - self.{}::< ChildFormer< _ >, _, >() + self.{}() }} - // Replace Child with name of type of element value. }} + "#, former, former_storage, field_ident, - field_add_name, + format!( "{}", qt!{ #( #params, )* } ), + format!( "{}", qt!{ #( #params, )* } ), + former_assign_end, + field_assign, ); - println!( "{hint}" ); + let about = format! + ( +r#"derive : Former +structure : {stru} +field : {field_ident}"#, + ); + diag::report_print( about, original_input, hint ); } - let doc = format! - ( - r#" - -Implements the `FormingEnd` trait for `{former_add_end}` to handle the final -stage of the forming process for a `{stru}` container that contains `{0}` elements. - -This implementation is tailored to manage the transition of {field_ident} elements from a substorage -temporary state into their final state within the `{stru}`'s storage. The function ensures -that the `{stru}`'s {field_ident} storage is initialized if not already set, and then adds the -preformed elements to this storage. - -# Type Parameters - -- `Types2`: Represents the specific types associated with the `Former` trait being applied, - which include storage, formed type, and context. -- `Definition`: Defines the `FormerDefinition` that outlines the storage structure and - the end conditions for the formation process. - -# Parameters - -- `substorage`: The storage from which {field_ident} elements are preformed and retrieved. -- `super_former`: An optional context which, upon invocation, contains the `{former}` - instance being formed. + let setters_code = qt! + { + #setter1 + #setter2 + }; -# Returns + // example : `former::VectorDefinition`` + let subformer_definition = &self.attrs.container.as_ref().unwrap().definition; -Returns the updated `{former}` instance with newly added {field_ident}, completing the -formation process of the `{stru}`. + let former_assign_end_doc = format! + ( + r#" +A callback structure to manage the final stage of forming a `{0}` for the `{stru}` container. +This callback is used to integrate the contents of a temporary `{0}` back into the original `{stru}` former +after the subforming process is completed. It replaces the existing content of the `{field_ident}` field in `{stru}` +with the new content generated during the subforming process. "#, format!( "{}", qt!{ #field_typ } ), ); + let subformer_definition_types = if let Some( ref _subformer_definition ) = subformer_definition + { + let subformer_definition_types_string = format!( "{}Types", qt!{ #subformer_definition } ); + let subformer_definition_types : syn::Type = syn::parse_str( &subformer_definition_types_string )?; + qt! + { + #subformer_definition_types + < + #( #params, )* + #former< #former_generics_ty >, + #former< #former_generics_ty >, + > + } + } + else + { + qt! + { + < + #field_typ as former::EntityToDefinitionTypes + < + #former< #former_generics_ty >, + #former< #former_generics_ty >, + > + >::Types + } + }; - let namespace_code = qt! + let r = qt! { - #[ doc = #doc ] - pub struct #former_add_end< Definition > + #[ doc = #former_assign_end_doc ] + pub struct #former_assign_end< Definition > { - _phantom : core::marker::PhantomData< fn( Definition ) >, + _phantom : core::marker::PhantomData< ( Definition, ) >, } impl< Definition > Default - for #former_add_end< Definition > + for #former_assign_end< Definition > { + #[ inline( always ) ] fn default() -> Self { @@ -626,45 +766,36 @@ formation process of the `{stru}`. _phantom : core::marker::PhantomData, } } + } - impl< #struct_generics_impl Types2, Definition > former::FormingEnd< Types2, > - for #former_add_end< Definition > + #[ automatically_derived ] + impl< #former_generics_impl > former::FormingEnd + < + // VectorDefinitionTypes + #subformer_definition_types, + > + for #former_assign_end< Definition > where - Definition : former::FormerDefinition - < - Storage = < #stru < #struct_generics_ty > as former::EntityToStorage >::Storage, - >, - Types2 : former::FormerDefinitionTypes - < - Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, - Formed = #former< #former_generics_ty >, - Context = #former< #former_generics_ty >, - >, - #struct_generics_where + #former_generics_where { #[ inline( always ) ] fn call ( &self, - substorage : Types2::Storage, - super_former : core::option::Option< Types2::Context >, + storage : #field_typ, + super_former : Option< #former< #former_generics_ty > >, ) - -> Types2::Formed + -> #former< #former_generics_ty > { let mut super_former = super_former.unwrap(); - if super_former.storage.#field_ident.is_none() + if let Some( ref mut field ) = super_former.storage.#field_ident { - super_former.storage.#field_ident = Some( Default::default() ); + former::ContainerAssign::assign( field, storage ); } - if let Some( ref mut field ) = super_former.storage.#field_ident + else { - former::ContainerAdd::add - ( - field, - < < #field_typ as former::Container >::Val as former::ValToEntry< #field_typ > > - ::val_to_entry( former::StoragePreform::preform( substorage ) ), - ); + super_former.storage.#field_ident = Some( storage ); } super_former } @@ -672,175 +803,156 @@ formation process of the `{stru}`. }; - // tree_print!( setters_code.as_ref().unwrap() ); + // tree_print!( r.as_ref().unwrap() ); + let namespace_code = r; + Ok( ( setters_code, namespace_code ) ) } + /// Generates setter functions for subforms within a container structure in a builder pattern. /// - /// Generate a container setter for the 'field_ident' with the 'setter_name' name. + /// This function is a key component of the `former` crate's capability to dynamically create setters for manipulating + /// data within a nested container structure like a `HashMap` or a `Vec`. The setters facilitate the addition or + /// modification of entries within the container, directly from the parent former's context. + /// + /// See `examples/subformer_subform_manual.rs` for example of generated code. /// - /// See `examples/subformer_container_manual.rs` for example of generated code. #[ inline ] - pub fn container_setter + pub fn subform_entry_setter ( &self, stru : &syn::Ident, former : &syn::Ident, former_storage : &syn::Ident, - former_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, former_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, - former_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, - original_input : &proc_macro::TokenStream, + struct_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, + struct_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, + struct_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, ) -> Result< ( TokenStream, TokenStream ) > { - let attr = self.attrs.container.as_ref().unwrap(); - let field_ident = &self.ident; - let field_typ = &self.non_optional_ty; - let params = typ::type_parameters( &field_typ, .. ); + + // if self.attrs.subform.is_none() + // { + // return Ok( qt!{ } ); + // } use convert_case::{ Case, Casing }; - let former_assign_end_name = format!( "{}FormerAssign{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); - let former_assign_end = syn::Ident::new( &former_assign_end_name, field_ident.span() ); - let field_assign_name = format!( "_{}_container_former", field_ident ); - let field_assign = syn::Ident::new( &field_assign_name, field_ident.span() ); + let field_ident = self.ident; + let field_typ = self.non_optional_ty; + let attr = self.attrs.subform.as_ref().unwrap(); + // let params = typ::type_parameters( &self.non_optional_ty, .. ); - // example : `former::VectorDefinition` - let subformer_definition = &attr.definition; - let subformer_definition = if subformer_definition.is_some() - { - qt! - { - #subformer_definition - < - #( #params, )* - Self, - Self, - #former_assign_end< Definition >, - > - } - // former::VectorDefinition< String, Self, Self, Struct1FormerAssignVec1End, > - } - else - { - qt! - { - < - #field_typ as former::EntityToDefinition< Self, Self, #former_assign_end< Definition > > - >::Definition - } - // < Vec< String > as former::EntityToDefinition< Self, Self, Struct1FormerAssignVec1End > >::Definition - }; + // example : `child` + let setter_name = self.subform_setter_name(); + + // example : `ParentSubformEntryChildrenEnd`` + let subform_entry_end_name = format!( "{}SubformEntry{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); + let subform_entry_end = syn::Ident::new( &subform_entry_end_name, field_ident.span() ); + + // example : `_children_former` + let subform_entry_name = format!( "_{}_subform_entry", field_ident ); + let subform_entry = syn::Ident::new( &subform_entry_name, field_ident.span() ); let doc = format! ( - "Container setter for the '{}' field. Method {} unlike method {} accept custom container subformer.", - field_ident, - field_assign_name, - field_ident, + r#" + +Initiates the addition of {field_ident} to the `{stru}` entity using a dedicated subformer. + +This method configures and returns a subformer specialized for the `{0}` entities' formation process, +which is part of the `{stru}` entity's construction. The subformer is set up with a specific end condition +handled by `{subform_entry_end}`, ensuring that the {field_ident} are properly integrated into the +parent's structure once formed. + +# Returns + +Returns an instance of `Former2`, a subformer ready to begin the formation process for `{0}` entities, +allowing for dynamic and flexible construction of the `{stru}` entity's {field_ident}. + + "#, + format!( "{}", qt!{ #field_typ } ), ); - let setter1 = - qt! + let setters_code = qt! { #[ doc = #doc ] #[ inline( always ) ] - pub fn #field_assign< Former2 >( self ) -> Former2 + pub fn #subform_entry< Former2, Definition2 >( self ) -> Former2 where - Former2 : former::FormerBegin + Definition2 : former::FormerDefinition < - #subformer_definition, + End = #subform_entry_end< Definition >, + Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, + Formed = Self, + Context = Self, >, - #subformer_definition : former::FormerDefinition + Definition2::Types : former::FormerDefinitionTypes < - // Storage : former::ContainerAdd< Entry = < #field_typ as former::Container >::Entry >, - Storage = #field_typ, - Context = #former< #former_generics_ty >, - End = #former_assign_end< Definition >, + Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, + Formed = Self, + Context = Self, >, + Former2 : former::FormerBegin< Definition2 >, { - Former2::former_begin( None, Some( self ), #former_assign_end::< Definition >::default() ) + Former2::former_begin( None, Some( self ), #subform_entry_end::default() ) } - // #[ inline( always ) ] - // pub fn _hashset_1_assign< Former2 >( self ) -> Former2 - // where - // Former2 : former::FormerBegin - // < - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, - // >, - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > > : former::FormerDefinition - // < - // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, - // Context = Struct1Former< Definition >, - // End = Struct1FormerAssignHashset1End< Definition >, - // >, - // { - // Former2::former_begin( None, Some( self ), Struct1FormerAssignHashset1End::< Definition >::default() ) - // } - }; - let setter_name = self.container_setter_name(); - let setter2 = if let Some( setter_name ) = setter_name + let setters_code = if attr.setter() { + + let doc = format! + ( + r#" +Provides a user-friendly interface to add an instancce of {field_ident} to the {stru}. + +# Returns + +Returns an instance of `Former2`, a subformer ready to begin the formation process for `{0}` entities, +allowing for dynamic and flexible construction of the `{stru}` entity's {field_ident}. + + "#, + format!( "{}", qt!{ #field_typ } ), + ); + qt! { + #setters_code #[ doc = #doc ] #[ inline( always ) ] - pub fn #setter_name( self ) -> former::ContainerFormer:: - < - // ( #( #params, )* ), - < #field_typ as former::Container >::Entry, - #subformer_definition, - > - where - #subformer_definition : former::FormerDefinition - < - // Storage : former::ContainerAdd< Entry = < #field_typ as former::Container >::Entry >, - Storage = #field_typ, - Context = #former< #former_generics_ty >, - End = #former_assign_end < Definition >, - >, - { - self.#field_assign::< former::ContainerFormer:: + pub fn #setter_name( self ) -> + < < #field_typ as former::Container >::Val as former::EntityToFormer < - _, - _, - // ( #( #params, )* ), - // #subformer_definition, - > > () - } - - // #[ inline( always ) ] - // pub fn hashset_1( self ) -> former::ContainerFormer:: - // < - // String, - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, - // > - // where - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > > : former::FormerDefinition - // < - // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, - // Context = Struct1Former< Definition >, - // End = Struct1FormerAssignHashset1End< Definition >, - // >, - // { - // self._hashset_1_assign::< former::ContainerFormer:: - // < - // String, - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, - // > > () - // } - + < + < #field_typ as former::Container >::Val as former::EntityToDefinition< Self, Self, #subform_entry_end < Definition > > + >::Definition, + > + >::Former + // #as_subformer< Self, impl #as_subformer_end< Self > > + { + self.#subform_entry + ::< < < #field_typ as former::Container >::Val as former::EntityToFormer< _ > >::Former, _, >() + // ::< #former< _ >, _, >() + } } + + // #[ inline( always ) ] + // pub fn child( self ) -> + // ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + // { + // self._children_subform_entry + // ::< < Child as former::EntityToFormer< _ > >::Former, _, >() + // } + } else { - qt!{} + setters_code }; if attr.hint @@ -849,106 +961,79 @@ formation process of the `{stru}`. ( r#" -/// The containr setter provides a container setter that returns a ContainerFormer tailored for managing a collection of child entities. It employs a generic container definition to facilitate operations on the entire collection, such as adding or updating elements. +/// Initializes and configures a subformer for adding named child entities. This method leverages an internal function +/// to create and return a configured subformer instance. It allows for the dynamic addition of children with specific names, +/// integrating them into the formation process of the parent entity. -impl< Definition, > {}< Definition, > +impl< Definition > {}< Definition > where Definition : former::FormerDefinition< Storage = {} >, {{ #[ inline( always ) ] - pub fn {}( self ) -> former::ContainerFormer:: - < - ( {} ), - former::HashMapDefinition< {} Self, Self, {}< Definition >, > - // Replace `HashMapDefinition` with definition for your container - > + pub fn {}( self ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > {{ - self.{}() + self.{}::< ChildFormer< _ >, _, >() }} + // Replace Child with name of type of element value. }} - "#, former, former_storage, field_ident, - format!( "{}", qt!{ #( #params, )* } ), - format!( "{}", qt!{ #( #params, )* } ), - former_assign_end, - field_assign, - ); - let about = format! - ( -r#"derive : Former -structure : {stru} -field : {field_ident}"#, + subform_entry_name, ); - diag::report_print( about, original_input, hint ); + println!( "{hint}" ); } - let setters_code = qt! - { - #setter1 - #setter2 - }; - - // example : `former::VectorDefinition`` - let subformer_definition = &self.attrs.container.as_ref().unwrap().definition; - - let former_assign_end_doc = format! + let doc = format! ( r#" -A callback structure to manage the final stage of forming a `{0}` for the `{stru}` container. -This callback is used to integrate the contents of a temporary `{0}` back into the original `{stru}` former -after the subforming process is completed. It replaces the existing content of the `{field_ident}` field in `{stru}` -with the new content generated during the subforming process. +Implements the `FormingEnd` trait for `{subform_entry_end}` to handle the final +stage of the forming process for a `{stru}` container that contains `{0}` elements. + +This implementation is tailored to manage the transition of {field_ident} elements from a substorage +temporary state into their final state within the `{stru}`'s storage. The function ensures +that the `{stru}`'s {field_ident} storage is initialized if not already set, and then adds the +preformed elements to this storage. + +# Type Parameters + +- `Types2`: Represents the specific types associated with the `Former` trait being applied, + which include storage, formed type, and context. +- `Definition`: Defines the `FormerDefinition` that outlines the storage structure and + the end conditions for the formation process. + +# Parameters + +- `substorage`: The storage from which {field_ident} elements are preformed and retrieved. +- `super_former`: An optional context which, upon invocation, contains the `{former}` + instance being formed. + +# Returns + +Returns the updated `{former}` instance with newly added {field_ident}, completing the +formation process of the `{stru}`. + "#, format!( "{}", qt!{ #field_typ } ), ); - let subformer_definition_types = if let Some( ref _subformer_definition ) = subformer_definition - { - let subformer_definition_types_string = format!( "{}Types", qt!{ #subformer_definition } ); - let subformer_definition_types : syn::Type = syn::parse_str( &subformer_definition_types_string )?; - qt! - { - #subformer_definition_types - < - #( #params, )* - #former< #former_generics_ty >, - #former< #former_generics_ty >, - > - } - } - else - { - qt! - { - < - #field_typ as former::EntityToDefinitionTypes - < - #former< #former_generics_ty >, - #former< #former_generics_ty >, - > - >::Types - } - }; - let r = qt! + let namespace_code = qt! { - #[ doc = #former_assign_end_doc ] - pub struct #former_assign_end< Definition > + #[ doc = #doc ] + pub struct #subform_entry_end< Definition > { - _phantom : core::marker::PhantomData< ( Definition, ) >, + _phantom : core::marker::PhantomData< fn( Definition ) >, } impl< Definition > Default - for #former_assign_end< Definition > + for #subform_entry_end< Definition > { - #[ inline( always ) ] fn default() -> Self { @@ -957,36 +1042,45 @@ with the new content generated during the subforming process. _phantom : core::marker::PhantomData, } } - } - #[ automatically_derived ] - impl< #former_generics_impl > former::FormingEnd - < - // VectorDefinitionTypes - #subformer_definition_types, - > - for #former_assign_end< Definition > + impl< #struct_generics_impl Types2, Definition > former::FormingEnd< Types2, > + for #subform_entry_end< Definition > where - #former_generics_where + Definition : former::FormerDefinition + < + Storage = < #stru < #struct_generics_ty > as former::EntityToStorage >::Storage, + >, + Types2 : former::FormerDefinitionTypes + < + Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, + Formed = #former< #former_generics_ty >, + Context = #former< #former_generics_ty >, + >, + #struct_generics_where { #[ inline( always ) ] fn call ( &self, - storage : #field_typ, - super_former : Option< #former< #former_generics_ty > >, + substorage : Types2::Storage, + super_former : core::option::Option< Types2::Context >, ) - -> #former< #former_generics_ty > + -> Types2::Formed { let mut super_former = super_former.unwrap(); - if let Some( ref mut field ) = super_former.storage.#field_ident + if super_former.storage.#field_ident.is_none() { - former::ContainerAssign::assign( field, storage ); + super_former.storage.#field_ident = Some( Default::default() ); } - else + if let Some( ref mut field ) = super_former.storage.#field_ident { - super_former.storage.#field_ident = Some( storage ); + former::ContainerAdd::add + ( + field, + < < #field_typ as former::Container >::Val as former::ValToEntry< #field_typ > > + ::val_to_entry( former::StoragePreform::preform( substorage ) ), + ); } super_former } @@ -994,104 +1088,10 @@ with the new content generated during the subforming process. }; - // tree_print!( r.as_ref().unwrap() ); - let namespace_code = r; - + // tree_print!( setters_code.as_ref().unwrap() ); Ok( ( setters_code, namespace_code ) ) } - /// - /// Generate a single scalar setter for the 'field_ident' with the 'setter_name' name. - /// - /// Used as a helper function for former_field_setter(), which generates alias setters - /// - /// # Example of generated code - /// - /// ```ignore - /// #[ doc = "Setter for the 'int_1' field." ] - /// #[ inline ] - /// pub fn int_1< Src >( mut self, src : Src ) -> Self - /// where - /// Src : ::core::convert::Into< i32 >, - /// { - /// debug_assert!( self.int_1.is_none() ); - /// self.storage.int_1 = ::core::option::Option::Some( ::core::convert::Into::into( src ) ); - /// self - /// } - /// ``` - - #[ inline ] - pub fn scalar_setter - ( - &self, - former : &syn::Ident, - former_storage : &syn::Ident, - ) - -> TokenStream - { - let field_ident = self.ident; - let typ = self.non_optional_ty; - let setter_name = self.scalar_setter_name(); - let attr = self.attrs.scalar.as_ref(); - - if attr.is_some() && attr.unwrap().hint - { - let hint = format! - ( - r#" - -impl< Definition > {}< Definition > -where - Definition : former::FormerDefinition< Storage = {} >, -{{ - #[ inline ] - pub fn {}< Src >( mut self, src : Src ) -> Self - where - Src : ::core::convert::Into< {} >, - {{ - debug_assert!( self.storage.{}.is_none() ); - self.storage.{} = ::core::option::Option::Some( ::core::convert::Into::into( src ) ); - self - }} -}} - - "#, - former, - former_storage, - field_ident, - format!( "{}", qt!{ #typ } ), - field_ident, - field_ident, - ); - println!( "{hint}" ); - } - - if !self.scalar_setter_required() - { - return qt! {}; - } - - let doc = format! - ( - "Scalar setter for the '{}' field.", - field_ident, - ); - - qt! - { - #[ doc = #doc ] - #[ inline ] - pub fn #setter_name< Src >( mut self, src : Src ) -> Self - where - Src : ::core::convert::Into< #typ >, - { - debug_assert!( self.storage.#field_ident.is_none() ); - self.storage.#field_ident = ::core::option::Option::Some( ::core::convert::Into::into( src ) ); - self - } - } - } - /// Get name of scalar setter. pub fn scalar_setter_name( &self ) -> &syn::Ident { diff --git a/module/core/former_meta/src/derive_former/field_attrs.rs b/module/core/former_meta/src/derive_former/field_attrs.rs index 5aea94b80d..0b26c138ec 100644 --- a/module/core/former_meta/src/derive_former/field_attrs.rs +++ b/module/core/former_meta/src/derive_former/field_attrs.rs @@ -371,7 +371,7 @@ pub struct AttributeSubformSetter /// like `name = my_field`. pub name : Option< syn::Ident >, /// Disable generation of setter. - /// It still generate `_field_add` method, so it could be used to make a setter with custom arguments. + /// It still generate `_field_subform_entry` method, so it could be used to make a setter with custom arguments. pub setter : Option< bool >, /// Specifies whether to provide a sketch of the subform setter as a hint. /// Defaults to `false`, which means no hint is provided unless explicitly requested. From edc1128108548ef8dc62cf0836a3f4c7329ce423 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 18:39:07 +0300 Subject: [PATCH 11/24] former : refactor --- .../former_custom_container_setter.rs | 4 +- .../only_test/containers_with_subformer.rs | 6 +- .../subform_container_basic_manual.rs | 78 +++++++++---------- .../former_tests/subform_container_manual.rs | 16 ++-- .../subform_container_setter_off.rs | 4 +- .../subform_container_setter_on.rs | 4 +- module/core/former/tests/inc/mod.rs | 22 +++--- .../former_meta/src/derive_former/field.rs | 60 +++++++------- 8 files changed, 97 insertions(+), 97 deletions(-) diff --git a/module/core/former/examples/former_custom_container_setter.rs b/module/core/former/examples/former_custom_container_setter.rs index d5565a0908..d882835b24 100644 --- a/module/core/former/examples/former_custom_container_setter.rs +++ b/module/core/former/examples/former_custom_container_setter.rs @@ -58,10 +58,10 @@ fn main() pub fn children( self ) -> former::ContainerFormer:: < ( String, Child ), - former::HashMapDefinition< String, Child, Self, Self, ParentFormerAssignChildrenEnd< Definition >, > + former::HashMapDefinition< String, Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > > { - self._children_container_former() + self._children_subform_container() } } diff --git a/module/core/former/tests/inc/former_tests/only_test/containers_with_subformer.rs b/module/core/former/tests/inc/former_tests/only_test/containers_with_subformer.rs index 042d36e538..42309cf1a6 100644 --- a/module/core/former/tests/inc/former_tests/only_test/containers_with_subformer.rs +++ b/module/core/former/tests/inc/former_tests/only_test/containers_with_subformer.rs @@ -122,9 +122,9 @@ tests_impls! { // Container subformers are defined - let _got = Struct1FormerAssignVec1End::< Struct1FormerDefinition >::default(); - let _got = Struct1FormerAssignHashmap1End::< Struct1FormerDefinition >::default(); - let _got = Struct1FormerAssignHashset1End::< Struct1FormerDefinition >::default(); + let _got = Struct1SubformContainerVec1End::< Struct1FormerDefinition >::default(); + let _got = Struct1SubformContainerHashmap1End::< Struct1FormerDefinition >::default(); + let _got = Struct1SubformContainerHashset1End::< Struct1FormerDefinition >::default(); // AsSubformerEnd is defined fn _f1< End : Struct1AsSubformerEnd< Struct1Former > > diff --git a/module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs b/module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs index 7a0b6292fe..be0a0f5bc7 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs @@ -341,38 +341,38 @@ where where Former2 : former::FormerBegin < - former::VectorDefinition< String, Self, Self, Struct1FormerAssignVec1End< Definition > >, + former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > >, >, - former::VectorDefinition< String, Self, Self, Struct1FormerAssignVec1End< Definition > > : former::FormerDefinition + former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > > : former::FormerDefinition < // Storage : former::ContainerAdd< Entry = < collection_tools::Vec< String > as former::Container >::Entry >, Storage = Vec< String >, Context = Struct1Former< Definition >, - End = Struct1FormerAssignVec1End< Definition >, + End = Struct1SubformContainerVec1End< Definition >, >, - Struct1FormerAssignVec1End< Definition > : former::FormingEnd + Struct1SubformContainerVec1End< Definition > : former::FormingEnd < < collection_tools::Vec< String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - Former2::former_begin( None, Some( self ), Struct1FormerAssignVec1End::< Definition >::default() ) + Former2::former_begin( None, Some( self ), Struct1SubformContainerVec1End::< Definition >::default() ) } #[ inline( always ) ] pub fn vec_1( self ) -> former::ContainerFormer:: < String, - former::VectorDefinition< String, Self, Self, Struct1FormerAssignVec1End< Definition > >, + former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > >, > where - former::VectorDefinition< String, Self, Self, Struct1FormerAssignVec1End< Definition > > : former::FormerDefinition + former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > > : former::FormerDefinition < // Storage : former::ContainerAdd< Entry = < collection_tools::Vec< String > as former::Container >::Entry >, Storage = Vec< String >, Context = Struct1Former< Definition >, - End = Struct1FormerAssignVec1End< Definition >, + End = Struct1SubformContainerVec1End< Definition >, >, - Struct1FormerAssignVec1End< Definition > : former::FormingEnd + Struct1SubformContainerVec1End< Definition > : former::FormingEnd < < collection_tools::Vec< String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, @@ -380,7 +380,7 @@ where self._vec_1_assign::< former::ContainerFormer:: < String, - former::VectorDefinition< String, Self, Self, Struct1FormerAssignVec1End< Definition > >, + former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > >, > > () } @@ -389,38 +389,38 @@ where where Former2 : former::FormerBegin < - former::HashMapDefinition< String, String, Self, Self, Struct1FormerAssignHashmap1End< Definition > >, + former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > >, >, - former::HashMapDefinition< String, String, Self, Self, Struct1FormerAssignHashmap1End< Definition > > : former::FormerDefinition + former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > > : former::FormerDefinition < // Storage : former::ContainerAdd< Entry = < collection_tools::HashMap< String, String > as former::Container >::Entry >, Storage = collection_tools::HashMap< String, String >, Context = Struct1Former< Definition >, - End = Struct1FormerAssignHashmap1End< Definition >, + End = Struct1SubformContainerHashmap1End< Definition >, >, - Struct1FormerAssignHashmap1End< Definition > : former::FormingEnd + Struct1SubformContainerHashmap1End< Definition > : former::FormingEnd < < collection_tools::HashMap< String, String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - Former2::former_begin( None, Some( self ), Struct1FormerAssignHashmap1End::< Definition >::default() ) + Former2::former_begin( None, Some( self ), Struct1SubformContainerHashmap1End::< Definition >::default() ) } #[ inline( always ) ] pub fn hashmap_1( self ) -> former::ContainerFormer:: < ( String, String ), - former::HashMapDefinition< String, String, Self, Self, Struct1FormerAssignHashmap1End< Definition > >, + former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > >, > where - former::HashMapDefinition< String, String, Self, Self, Struct1FormerAssignHashmap1End< Definition > > : former::FormerDefinition + former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > > : former::FormerDefinition < // Storage : former::ContainerAdd< Entry = < collection_tools::HashMap< String, String > as former::Container >::Entry >, Storage = collection_tools::HashMap< String, String >, Context = Struct1Former< Definition >, - End = Struct1FormerAssignHashmap1End< Definition >, + End = Struct1SubformContainerHashmap1End< Definition >, >, - Struct1FormerAssignHashmap1End< Definition > : former::FormingEnd + Struct1SubformContainerHashmap1End< Definition > : former::FormingEnd < < collection_tools::HashMap< String, String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, @@ -428,7 +428,7 @@ where self._hashmap_1_assign::< former::ContainerFormer:: < ( String, String ), - former::HashMapDefinition< String, String, Self, Self, Struct1FormerAssignHashmap1End< Definition > >, + former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > >, > > () } @@ -437,38 +437,38 @@ where where Former2 : former::FormerBegin < - former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, >, - former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > > : former::FormerDefinition + former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > > : former::FormerDefinition < // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, Storage = collection_tools::HashSet< String >, Context = Struct1Former< Definition >, - End = Struct1FormerAssignHashset1End< Definition >, + End = Struct1SubformContainerHashset1End< Definition >, >, - Struct1FormerAssignHashset1End< Definition > : former::FormingEnd + Struct1SubformContainerHashset1End< Definition > : former::FormingEnd < < collection_tools::HashSet< String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - Former2::former_begin( None, Some( self ), Struct1FormerAssignHashset1End::< Definition >::default() ) + Former2::former_begin( None, Some( self ), Struct1SubformContainerHashset1End::< Definition >::default() ) } #[ inline( always ) ] pub fn hashset_1( self ) -> former::ContainerFormer:: < String, - former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, > where - former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > > : former::FormerDefinition + former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > > : former::FormerDefinition < // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, Storage = collection_tools::HashSet< String >, Context = Struct1Former< Definition >, - End = Struct1FormerAssignHashset1End< Definition >, + End = Struct1SubformContainerHashset1End< Definition >, >, - Struct1FormerAssignHashset1End< Definition > : former::FormingEnd + Struct1SubformContainerHashset1End< Definition > : former::FormingEnd < < collection_tools::HashSet< String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, @@ -476,7 +476,7 @@ where self._hashset_1_assign::< former::ContainerFormer:: < String, - former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, > > () } @@ -538,12 +538,12 @@ where // = former assign end -pub struct Struct1FormerAssignVec1End< Definition > +pub struct Struct1SubformContainerVec1End< Definition > { _phantom : core::marker::PhantomData< ( Definition, ) >, } -impl Default for Struct1FormerAssignVec1End< Definition > +impl Default for Struct1SubformContainerVec1End< Definition > { #[ inline( always ) ] fn default() -> Self @@ -561,7 +561,7 @@ impl< Definition > former::FormingEnd < former::VectorDefinitionTypes< String, Struct1Former< Definition >, Struct1Former< Definition > > > -for Struct1FormerAssignVec1End< Definition > +for Struct1SubformContainerVec1End< Definition > where Definition : former::FormerDefinition< Storage = Struct1FormerStorage >, Definition::Types : former::FormerDefinitionTypes< Storage = Struct1FormerStorage >, @@ -583,12 +583,12 @@ where } } -pub struct Struct1FormerAssignHashmap1End +pub struct Struct1SubformContainerHashmap1End { _phantom : core::marker::PhantomData<(Definition,)>, } -impl Default for Struct1FormerAssignHashmap1End +impl Default for Struct1SubformContainerHashmap1End { #[ inline( always ) ] fn default() -> Self @@ -602,7 +602,7 @@ impl Default for Struct1FormerAssignHashmap1End impl< Definition, > former::FormingEnd < former::HashMapDefinitionTypes< String, String, Struct1Former< Definition >, Struct1Former< Definition > > > -for Struct1FormerAssignHashmap1End< Definition > +for Struct1SubformContainerHashmap1End< Definition > where Definition : former::FormerDefinition< Storage = Struct1FormerStorage >, Definition::Types : former::FormerDefinitionTypes< Storage = Struct1FormerStorage >, @@ -624,12 +624,12 @@ where } } -pub struct Struct1FormerAssignHashset1End +pub struct Struct1SubformContainerHashset1End { _phantom : core::marker::PhantomData<(Definition,)>, } -impl Default for Struct1FormerAssignHashset1End +impl Default for Struct1SubformContainerHashset1End { #[ inline( always ) ] fn default() -> Self @@ -643,7 +643,7 @@ impl Default for Struct1FormerAssignHashset1End impl< Definition, > former::FormingEnd < former::HashSetDefinitionTypes< String, Struct1Former< Definition >, Struct1Former< Definition > > > -for Struct1FormerAssignHashset1End< Definition > +for Struct1SubformContainerHashset1End< Definition > where Definition : former::FormerDefinition< Storage = Struct1FormerStorage >, Definition::Types : former::FormerDefinitionTypes< Storage = Struct1FormerStorage >, diff --git a/module/core/former/tests/inc/former_tests/subform_container_manual.rs b/module/core/former/tests/inc/former_tests/subform_container_manual.rs index 82811c38eb..26a753abe6 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_container_manual.rs @@ -30,21 +30,21 @@ where { #[ inline( always ) ] - pub fn _children_container_former< Former2 >( self ) -> Former2 + pub fn _children_subform_container< Former2 >( self ) -> Former2 where - Former2 : former::FormerBegin< former::VectorDefinition< Child, Self, Self, ParentFormerAssignChildrenEnd< Definition >, > >, + Former2 : former::FormerBegin< former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > >, { - Former2::former_begin( None, Some( self ), ParentFormerAssignChildrenEnd::< Definition >::default() ) + Former2::former_begin( None, Some( self ), ParentSubformContainerChildrenEnd::< Definition >::default() ) } #[ inline( always ) ] pub fn children( self ) -> former::ContainerFormer:: < Child, - former::VectorDefinition< Child, Self, Self, ParentFormerAssignChildrenEnd< Definition >, > + former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > > { - self._children_container_former::< former::ContainerFormer::< Child, former::VectorDefinition< Child, Self, Self, ParentFormerAssignChildrenEnd< Definition >, > > >() + self._children_subform_container::< former::ContainerFormer::< Child, former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > > >() } } @@ -52,12 +52,12 @@ where // #[ doc = r"Callback to return original former after forming of container for `vec_1` is done. Callback replace content of container assigning new content from subformer's storage." ] -pub struct ParentFormerAssignChildrenEnd< Definition > +pub struct ParentSubformContainerChildrenEnd< Definition > { _phantom : core::marker::PhantomData< ( Definition, ) >, } -impl< Definition > Default for ParentFormerAssignChildrenEnd< Definition > +impl< Definition > Default for ParentSubformContainerChildrenEnd< Definition > { #[ inline( always ) ] @@ -78,7 +78,7 @@ impl< Definition, > former::FormingEnd Vec< Child > as former::EntityToDefinitionTypes< ParentFormer< Definition, >, ParentFormer< Definition, > > >::Types > -for ParentFormerAssignChildrenEnd< Definition > +for ParentSubformContainerChildrenEnd< Definition > where Definition : former::FormerDefinition< Storage = ParentFormerStorage< > >, { diff --git a/module/core/former/tests/inc/former_tests/subform_container_setter_off.rs b/module/core/former/tests/inc/former_tests/subform_container_setter_off.rs index 5f3ca56708..e0e394c192 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_setter_off.rs +++ b/module/core/former/tests/inc/former_tests/subform_container_setter_off.rs @@ -40,10 +40,10 @@ where pub fn children2( self ) -> former::ContainerFormer:: < Child, - former::VectorDefinition< Child, Self, Self, ParentFormerAssignChildrenEnd< Definition >, > + former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > > { - self._children_container_former::< _ >() + self._children_subform_container::< _ >() } } diff --git a/module/core/former/tests/inc/former_tests/subform_container_setter_on.rs b/module/core/former/tests/inc/former_tests/subform_container_setter_on.rs index 83233366cf..afe39b4a84 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_setter_on.rs +++ b/module/core/former/tests/inc/former_tests/subform_container_setter_on.rs @@ -33,10 +33,10 @@ where pub fn children2( self ) -> former::ContainerFormer:: < Child, - former::VectorDefinition< Child, Self, Self, ParentFormerAssignChildrenEnd< Definition >, > + former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > > { - self._children_container_former::< _ >() + self._children_subform_container::< _ >() } } diff --git a/module/core/former/tests/inc/mod.rs b/module/core/former/tests/inc/mod.rs index 5ec11b2c1f..0a089aa865 100644 --- a/module/core/former/tests/inc/mod.rs +++ b/module/core/former/tests/inc/mod.rs @@ -9,17 +9,6 @@ mod former_tests #[ allow( unused_imports ) ] use super::*; - // = container former - - #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod container_former_common; - #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod container_former_vec; - #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod container_former_hashset; - #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod container_former_hashmap; - // = basic mod a_basic_manual; @@ -76,6 +65,17 @@ mod former_tests mod user_type_no_debug; mod visibility; + // = container former + + #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] + mod container_former_common; + #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] + mod container_former_vec; + #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] + mod container_former_hashset; + #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] + mod container_former_hashmap; + // = subform container #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index b299d49b9e..e098c10797 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -33,9 +33,9 @@ storage_field_optional storage_field_preform storage_field_name former_field_setter +scalar_setter subform_entry_setter subform_container_setter -scalar_setter scalar_setter_name container_setter_name @@ -510,10 +510,10 @@ where let params = typ::type_parameters( &field_typ, .. ); use convert_case::{ Case, Casing }; - let former_assign_end_name = format!( "{}FormerAssign{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); - let former_assign_end = syn::Ident::new( &former_assign_end_name, field_ident.span() ); - let field_assign_name = format!( "_{}_container_former", field_ident ); - let field_assign = syn::Ident::new( &field_assign_name, field_ident.span() ); + let subform_container_end_name = format!( "{}SubformContainer{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); + let subform_container_end = syn::Ident::new( &subform_container_end_name, field_ident.span() ); + let subform_container_name = format!( "_{}_subform_container", field_ident ); + let subform_container = syn::Ident::new( &subform_container_name, field_ident.span() ); // example : `former::VectorDefinition` let subformer_definition = &attr.definition; @@ -526,27 +526,27 @@ where #( #params, )* Self, Self, - #former_assign_end< Definition >, + #subform_container_end< Definition >, > } - // former::VectorDefinition< String, Self, Self, Struct1FormerAssignVec1End, > + // former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End, > } else { qt! { < - #field_typ as former::EntityToDefinition< Self, Self, #former_assign_end< Definition > > + #field_typ as former::EntityToDefinition< Self, Self, #subform_container_end< Definition > > >::Definition } - // < Vec< String > as former::EntityToDefinition< Self, Self, Struct1FormerAssignVec1End > >::Definition + // < Vec< String > as former::EntityToDefinition< Self, Self, Struct1SubformContainerVec1End > >::Definition }; let doc = format! ( "Container setter for the '{}' field. Method {} unlike method {} accept custom container subformer.", field_ident, - field_assign_name, + subform_container_name, field_ident, ); @@ -556,7 +556,7 @@ where #[ doc = #doc ] #[ inline( always ) ] - pub fn #field_assign< Former2 >( self ) -> Former2 + pub fn #subform_container< Former2 >( self ) -> Former2 where Former2 : former::FormerBegin < @@ -567,10 +567,10 @@ where // Storage : former::ContainerAdd< Entry = < #field_typ as former::Container >::Entry >, Storage = #field_typ, Context = #former< #former_generics_ty >, - End = #former_assign_end< Definition >, + End = #subform_container_end< Definition >, >, { - Former2::former_begin( None, Some( self ), #former_assign_end::< Definition >::default() ) + Former2::former_begin( None, Some( self ), #subform_container_end::< Definition >::default() ) } // #[ inline( always ) ] @@ -578,16 +578,16 @@ where // where // Former2 : former::FormerBegin // < - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, // >, - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > > : former::FormerDefinition + // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > > : former::FormerDefinition // < // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, // Context = Struct1Former< Definition >, - // End = Struct1FormerAssignHashset1End< Definition >, + // End = Struct1SubformContainerHashset1End< Definition >, // >, // { - // Former2::former_begin( None, Some( self ), Struct1FormerAssignHashset1End::< Definition >::default() ) + // Former2::former_begin( None, Some( self ), Struct1SubformContainerHashset1End::< Definition >::default() ) // } }; @@ -612,10 +612,10 @@ where // Storage : former::ContainerAdd< Entry = < #field_typ as former::Container >::Entry >, Storage = #field_typ, Context = #former< #former_generics_ty >, - End = #former_assign_end < Definition >, + End = #subform_container_end < Definition >, >, { - self.#field_assign::< former::ContainerFormer:: + self.#subform_container::< former::ContainerFormer:: < _, _, @@ -628,20 +628,20 @@ where // pub fn hashset_1( self ) -> former::ContainerFormer:: // < // String, - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, // > // where - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > > : former::FormerDefinition + // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > > : former::FormerDefinition // < // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, // Context = Struct1Former< Definition >, - // End = Struct1FormerAssignHashset1End< Definition >, + // End = Struct1SubformContainerHashset1End< Definition >, // >, // { // self._hashset_1_assign::< former::ContainerFormer:: // < // String, - // former::HashSetDefinition< String, Self, Self, Struct1FormerAssignHashset1End< Definition > >, + // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, // > > () // } @@ -684,8 +684,8 @@ where field_ident, format!( "{}", qt!{ #( #params, )* } ), format!( "{}", qt!{ #( #params, )* } ), - former_assign_end, - field_assign, + subform_container_end, + subform_container, ); let about = format! ( @@ -705,7 +705,7 @@ field : {field_ident}"#, // example : `former::VectorDefinition`` let subformer_definition = &self.attrs.container.as_ref().unwrap().definition; - let former_assign_end_doc = format! + let subform_container_end_doc = format! ( r#" A callback structure to manage the final stage of forming a `{0}` for the `{stru}` container. @@ -748,14 +748,14 @@ with the new content generated during the subforming process. let r = qt! { - #[ doc = #former_assign_end_doc ] - pub struct #former_assign_end< Definition > + #[ doc = #subform_container_end_doc ] + pub struct #subform_container_end< Definition > { _phantom : core::marker::PhantomData< ( Definition, ) >, } impl< Definition > Default - for #former_assign_end< Definition > + for #subform_container_end< Definition > { #[ inline( always ) ] @@ -775,7 +775,7 @@ with the new content generated during the subforming process. // VectorDefinitionTypes #subformer_definition_types, > - for #former_assign_end< Definition > + for #subform_container_end< Definition > where #former_generics_where { From 6342c93a40670bec246d773a36bdfe12891a1067 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 18:57:34 +0300 Subject: [PATCH 12/24] former : refactor --- module/core/former/Readme.md | 90 ++++---- ...ashmap.rs => former_collection_hashmap.rs} | 4 +- ...ashset.rs => former_collection_hashset.rs} | 2 +- ..._vector.rs => former_collection_vector.rs} | 4 +- .../examples/former_custom_container.rs | 44 ++-- .../former_custom_container_setter.rs | 24 +-- .../examples/former_custom_definition.rs | 8 +- .../examples/former_custom_scalar_setter.rs | 10 +- .../examples/former_custom_subform_setter.rs | 12 +- .../examples/former_custom_subform_setter2.rs | 18 +- .../src/{container.rs => collection.rs} | 192 +++++++++--------- .../src/{container => collection}/hash_map.rs | 20 +- .../src/{container => collection}/hash_set.rs | 28 +-- .../src/{container => collection}/vector.rs | 22 +- module/core/former/src/forming.rs | 10 +- module/core/former/src/lib.rs | 6 +- ...ner.rs => attribute_default_collection.rs} | 0 ..._common.rs => collection_former_common.rs} | 20 +- ...ashmap.rs => collection_former_hashmap.rs} | 4 +- ...ashset.rs => collection_former_hashset.rs} | 4 +- ...former_vec.rs => collection_former_vec.rs} | 6 +- .../tests/inc/former_tests/name_collisions.rs | 2 +- ...ormer.rs => collections_with_subformer.rs} | 8 +- ...er.rs => collections_without_subformer.rs} | 0 ...r_container.rs => subformer_collection.rs} | 0 ...2.rs => subformer_collection_children2.rs} | 2 +- .../former_tests/parametrized_struct_imm.rs | 2 +- .../parametrized_struct_manual.rs | 8 +- .../former_tests/parametrized_struct_where.rs | 2 +- ..._entry_and_container.rs => subform_all.rs} | 6 +- ...etrized.rs => subform_all_parametrized.rs} | 8 +- ...iner_private.rs => subform_all_private.rs} | 6 +- ...orm_container.rs => subform_collection.rs} | 4 +- ...r_basic.rs => subform_collection_basic.rs} | 8 +- ....rs => subform_collection_basic_manual.rs} | 110 +++++----- ....rs => subform_collection_basic_scalar.rs} | 2 +- ...custom.rs => subform_collection_custom.rs} | 18 +- ...icit.rs => subform_collection_implicit.rs} | 6 +- ...manual.rs => subform_collection_manual.rs} | 30 +-- ...r_named.rs => subform_collection_named.rs} | 6 +- ...nd.rs => subform_collection_playground.rs} | 6 +- ...ff.rs => subform_collection_setter_off.rs} | 12 +- ..._on.rs => subform_collection_setter_on.rs} | 12 +- .../tests/inc/former_tests/subform_entry.rs | 2 +- .../inc/former_tests/subform_entry_hashmap.rs | 2 +- .../subform_entry_hashmap_custom.rs | 10 +- .../inc/former_tests/subform_entry_manual.rs | 20 +- .../inc/former_tests/subform_entry_named.rs | 2 +- .../subform_entry_named_manual.rs | 8 +- .../former_tests/subform_entry_setter_off.rs | 2 +- .../former_tests/subform_entry_setter_on.rs | 2 +- .../inc/former_tests/subform_scalar_manual.rs | 2 +- module/core/former/tests/inc/mod.rs | 42 ++-- module/core/former_meta/src/derive_former.rs | 2 +- .../former_meta/src/derive_former/field.rs | 150 +++++++------- .../src/derive_former/field_attrs.rs | 34 ++-- module/core/former_meta/src/lib.rs | 4 +- module/core/program_tools/src/program.rs | 4 +- module/move/wca/src/ca/grammar/command.rs | 2 +- module/move/willbe/src/tool/template.rs | 4 +- 60 files changed, 539 insertions(+), 539 deletions(-) rename module/core/former/examples/{former_container_hashmap.rs => former_collection_hashmap.rs} (88%) rename module/core/former/examples/{former_container_hashset.rs => former_collection_hashset.rs} (96%) rename module/core/former/examples/{former_container_vector.rs => former_collection_vector.rs} (86%) rename module/core/former/src/{container.rs => collection.rs} (65%) rename module/core/former/src/{container => collection}/hash_map.rs (91%) rename module/core/former/src/{container => collection}/hash_set.rs (85%) rename module/core/former/src/{container => collection}/vector.rs (89%) rename module/core/former/tests/inc/former_tests/{attribute_default_container.rs => attribute_default_collection.rs} (100%) rename module/core/former/tests/inc/former_tests/{container_former_common.rs => collection_former_common.rs} (85%) rename module/core/former/tests/inc/former_tests/{container_former_hashmap.rs => collection_former_hashmap.rs} (98%) rename module/core/former/tests/inc/former_tests/{container_former_hashset.rs => collection_former_hashset.rs} (97%) rename module/core/former/tests/inc/former_tests/{container_former_vec.rs => collection_former_vec.rs} (96%) rename module/core/former/tests/inc/former_tests/only_test/{containers_with_subformer.rs => collections_with_subformer.rs} (96%) rename module/core/former/tests/inc/former_tests/only_test/{containers_without_subformer.rs => collections_without_subformer.rs} (100%) rename module/core/former/tests/inc/former_tests/only_test/{subformer_container.rs => subformer_collection.rs} (100%) rename module/core/former/tests/inc/former_tests/only_test/{subformer_container_children2.rs => subformer_collection_children2.rs} (95%) rename module/core/former/tests/inc/former_tests/{subform_entry_and_container.rs => subform_all.rs} (89%) rename module/core/former/tests/inc/former_tests/{subform_entry_and_container_parametrized.rs => subform_all_parametrized.rs} (94%) rename module/core/former/tests/inc/former_tests/{subform_entry_and_container_private.rs => subform_all_private.rs} (89%) rename module/core/former/tests/inc/former_tests/{subform_container.rs => subform_collection.rs} (80%) rename module/core/former/tests/inc/former_tests/{subform_container_basic.rs => subform_collection_basic.rs} (66%) rename module/core/former/tests/inc/former_tests/{subform_container_basic_manual.rs => subform_collection_basic_manual.rs} (80%) rename module/core/former/tests/inc/former_tests/{subform_container_basic_scalar.rs => subform_collection_basic_scalar.rs} (88%) rename module/core/former/tests/inc/former_tests/{subform_container_custom.rs => subform_collection_custom.rs} (92%) rename module/core/former/tests/inc/former_tests/{subform_container_implicit.rs => subform_collection_implicit.rs} (78%) rename module/core/former/tests/inc/former_tests/{subform_container_manual.rs => subform_collection_manual.rs} (59%) rename module/core/former/tests/inc/former_tests/{subform_container_named.rs => subform_collection_named.rs} (86%) rename module/core/former/tests/inc/former_tests/{subform_container_playground.rs => subform_collection_playground.rs} (91%) rename module/core/former/tests/inc/former_tests/{subform_container_setter_off.rs => subform_collection_setter_off.rs} (75%) rename module/core/former/tests/inc/former_tests/{subform_container_setter_on.rs => subform_collection_setter_on.rs} (69%) diff --git a/module/core/former/Readme.md b/module/core/former/Readme.md index 84c824781f..0d5e327f77 100644 --- a/module/core/former/Readme.md +++ b/module/core/former/Readme.md @@ -638,7 +638,7 @@ Purpose of Storage: - **Intermediate State Holding**: Storage serves as a temporary repository for all the partially set properties and data of the object being formed. This functionality is essential in situations where the object's completion depends on multiple, potentially complex stages of configuration. - **Decoupling Configuration from Instantiation**: Storage separates the accumulation of configuration states from the actual creation of the final object. This separation fosters cleaner, more maintainable code, allowing developers to apply configurations in any order and manage interim states more efficiently, without compromising the integrity of the final object. -Storage is not just a passive container; it is an active part of a larger ecosystem that includes the former itself, a context, and a callback (often referred to as `FormingEnd`): +Storage is not just a passive collection; it is an active part of a larger ecosystem that includes the former itself, a context, and a callback (often referred to as `FormingEnd`): - **Former as an Active Manager**: The former is responsible for managing the storage, utilizing it to keep track of the object's evolving configuration. It orchestrates the formation process by handling intermediate states and preparing the object for its final form. - **Contextual Flexibility**: The context associated with the former adds an additional layer of flexibility, allowing the former to adjust its behavior based on the broader circumstances of the object's formation. This is particularly useful when the forming process involves conditions or states external to the object itself. @@ -677,9 +677,9 @@ These traits collectively facilitate a robust and flexible builder pattern that ## Example : Custom Definition -Define a custom former definition and custom forming logic, and apply them to a container. +Define a custom former definition and custom forming logic, and apply them to a collection. -The example showcases how to accumulate elements into a container and then transform them into a single result using a custom `FormingEnd` implementation. This pattern is useful for scenarios where the formation process involves aggregation or transformation of input elements into a different type or form. +The example showcases how to accumulate elements into a collection and then transform them into a single result using a custom `FormingEnd` implementation. This pattern is useful for scenarios where the formation process involves aggregation or transformation of input elements into a different type or form. ```rust # #[ cfg( any( not( feature = "derive_former" ), not( feature = "enabled" ) ) ) ] @@ -696,7 +696,7 @@ The example showcases how to accumulate elements into a container and then trans // This trait defines the types used during the forming process. impl former::FormerDefinitionTypes for Sum { - type Storage = Vec; // Container for the integers. + type Storage = Vec; // Collection for the integers. type Formed = i32; // The final type after forming, which is a single integer. type Context = (); // No additional context is used in this example. } @@ -736,7 +736,7 @@ The example showcases how to accumulate elements into a container and then trans } // Use the custom `Former` to sum a list of integers. - let got = former::ContainerFormer::::new(Sum) + let got = former::CollectionFormer::::new(Sum) .add( 1 ) // Add an integer to the storage. .add( 2 ) // Add another integer. .add( 10 ) // Add another integer. @@ -756,19 +756,19 @@ Subformers are specialized builders used within the former to construct nested o ## Types of Setters / Subformers -It's crucial to understand the differences among subform setters, container setters, and scalar setters: +It's crucial to understand the differences among subform setters, collection setters, and scalar setters: -- **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or container setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +- **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. -- **Container Setter**: Returns a former of the container itself, offering an interface to manage the container as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +- **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. -- **Subform Setter**: Returns a former of an element within a container, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +- **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. -## Example : Container Setter for a Vector +## Example : Collection Setter for a Vector -This example demonstrates how to employ the `Former` trait to configure a `Vec` using a container setter in a structured manner. +This example demonstrates how to employ the `Former` trait to configure a `Vec` using a collection setter in a structured manner. ```rust # #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] @@ -781,7 +781,7 @@ This example demonstrates how to employ the `Former` trait to configure a `Vec` #[ derive( Debug, PartialEq, former::Former ) ] pub struct StructWithVec { - #[ container ] + #[ subform_collection ] vec : Vec< &'static str >, } @@ -798,13 +798,13 @@ This example demonstrates how to employ the `Former` trait to configure a `Vec` # } ``` -Try out `cargo run --example former_container_vector`. +Try out `cargo run --example former_collection_vector`.
-[See code](./examples/former_container_vector.rs). +[See code](./examples/former_collection_vector.rs). -## Example : Container Setter for a Hashmap +## Example : Collection Setter for a Hashmap -This example demonstrates how to effectively employ the `Former` trait to configure a `HashMap` using a container setter. +This example demonstrates how to effectively employ the `Former` trait to configure a `HashMap` using a collection setter. ```rust # #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] @@ -818,7 +818,7 @@ This example demonstrates how to effectively employ the `Former` trait to config #[ derive( Debug, PartialEq, former::Former ) ] pub struct StructWithMap { - #[ container ] + #[ subform_collection ] map : HashMap< &'static str, &'static str >, } @@ -835,11 +835,11 @@ This example demonstrates how to effectively employ the `Former` trait to config # } ``` -Try out `cargo run --example former_container_hashmap`. +Try out `cargo run --example former_collection_hashmap`.
-[See code](./examples/former_container_hashmap.rs). +[See code](./examples/former_collection_hashmap.rs). -## Example : Container Setter for a Hashset +## Example : Collection Setter for a Hashset This example demonstrates the use of the `Former` trait to build a `collection_tools::HashSet` through subforming. @@ -855,7 +855,7 @@ This example demonstrates the use of the `Former` trait to build a `collection_t #[ derive( Debug, PartialEq, former::Former ) ] pub struct StructWithSet { - #[ container ] + #[ subform_collection ] set : HashSet< &'static str >, } @@ -872,15 +872,15 @@ This example demonstrates the use of the `Former` trait to build a `collection_t # } ``` -Try out `cargo run --example former_container_hashset`. +Try out `cargo run --example former_collection_hashset`.
-[See code](./examples/former_container_hashset.rs). +[See code](./examples/former_collection_hashset.rs). ## Example : Custom Scalar Setter -This example demonstrates the implementation of a scalar setter using the `Former` trait. Unlike the more complex subform and container setters shown in previous examples, this example focuses on a straightforward approach to directly set a scalar value within a parent entity. The `Parent` struct manages a `HashMap` of `Child` entities, and the scalar setter is used to set the entire `HashMap` directly. +This example demonstrates the implementation of a scalar setter using the `Former` trait. Unlike the more complex subform and collection setters shown in previous examples, this example focuses on a straightforward approach to directly set a scalar value within a parent entity. The `Parent` struct manages a `HashMap` of `Child` entities, and the scalar setter is used to set the entire `HashMap` directly. -The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a container—each child entity in this case. +The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. ```rust # #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] @@ -952,7 +952,7 @@ The `child` function within `ParentFormer` is a custom subform setter that plays # } ``` -In this example, the `Parent` struct functions as a container for multiple `Child` structs, each identified by a unique child name. The `ParentFormer` implements a custom method `child`, which serves as a subformer for adding `Child` instances into the `Parent`. +In this example, the `Parent` struct functions as a collection for multiple `Child` structs, each identified by a unique child name. The `ParentFormer` implements a custom method `child`, which serves as a subformer for adding `Child` instances into the `Parent`. - **Child Definition**: Each `Child` consists of a `name` and a `description`, and we derive `Former` to enable easy setting of these properties using a builder pattern. - **Parent Definition**: It holds a collection of `Child` objects in a `HashMap`. The `#[setter(false)]` attribute is used to disable the default setter, and a custom method `child` is defined to facilitate the addition of children with specific attributes. @@ -962,11 +962,11 @@ Try out `cargo run --example former_custom_scalar_setter`.
[See code](./examples/former_custom_scalar_setter.rs). -## Example : Custom Container Setter +## Example : Custom Collection Setter -This example demonstrates the use of container setters to manage complex nested data structures with the `Former` trait, focusing on a parent-child relationship structured around a container `HashMap`. Unlike typical builder patterns that add individual elements using subform setters, this example uses a container setter to manage the entire collection of children. +This example demonstrates the use of collection setters to manage complex nested data structures with the `Former` trait, focusing on a parent-child relationship structured around a collection `HashMap`. Unlike typical builder patterns that add individual elements using subform setters, this example uses a collection setter to manage the entire collection of children. -The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a container—each child entity in this case. +The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. ```rust # #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] @@ -1039,15 +1039,15 @@ The `child` function within `ParentFormer` is a custom subform setter that plays # } ``` -Try out `cargo run --example former_custom_container_setter`. +Try out `cargo run --example former_custom_collection_setter`.
-[See code](./examples/former_custom_container_setter.rs). +[See code](./examples/former_custom_collection_setter.rs). ## Example : Custom Subform Setter This example illustrates the implementation of nested builder patterns using the `Former` trait, emphasizing a parent-child relationship. Here, the `Parent` struct utilizes `ChildFormer` as a custom subformer to dynamically manage its `child` field—a `HashMap`. Each child in the `HashMap` is uniquely identified and configured via the `ChildFormer`. -The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a container—each child entity in this case. +The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. ```rust # #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] @@ -1075,7 +1075,7 @@ The `child` function within `ParentFormer` is a custom subform setter that plays pub struct Parent { // Use `hint = true` to gennerate sketch of setter. - #[ subform( setter = false, hint = false ) ] + #[ subform_entry( setter = false, hint = false ) ] child : HashMap< String, Child >, } @@ -1137,23 +1137,23 @@ Try out `cargo run --example former_custom_subform_setter`.
[See code](./examples/former_custom_subform_setter.rs). -## General Container Interface +## General Collection Interface -There are suite of traits designed to abstract and enhance the functionality of container data structures within the forming process. These traits are integral to managing the complexity of container operations, such as adding, modifying, and converting between different representations within containers like vectors, hash maps, etc. They are especially useful when used in conjunction with the `container` attribute in the `former` macro, which automates the implementation of these traits to create robust and flexible builder patterns for complex data structures. +There are suite of traits designed to abstract and enhance the functionality of collection data structures within the forming process. These traits are integral to managing the complexity of collection operations, such as adding, modifying, and converting between different representations within collections like vectors, hash maps, etc. They are especially useful when used in conjunction with the `collection` attribute in the `former` macro, which automates the implementation of these traits to create robust and flexible builder patterns for complex data structures. -- [`Container`] - Defines basic functionalities for containers, managing entries and values, establishing the fundamental operations required for any custom container implementation in forming processes. -- [`EntryToVal`] - Facilitates the conversion of container entries to their value representations, crucial for operations that treat container elements more abstractly as values. -- [`ValToEntry`] - Provides the reverse functionality of `EntryToVal`, converting values back into entries, which is essential for operations that require adding or modifying entries in the container based on value data. -- [`ContainerAdd`] - Adds functionality for inserting entries into a container, considering container-specific rules such as duplication handling and order preservation, enhancing the usability of containers in forming scenarios. -- [`ContainerAssign`] - Extends the container functionality to replace all existing entries with new ones, enabling bulk updates or complete resets of container contents, which is particularly useful in dynamic data environments. +- [`Collection`] - Defines basic functionalities for collections, managing entries and values, establishing the fundamental operations required for any custom collection implementation in forming processes. +- [`EntryToVal`] - Facilitates the conversion of collection entries to their value representations, crucial for operations that treat collection elements more abstractly as values. +- [`ValToEntry`] - Provides the reverse functionality of `EntryToVal`, converting values back into entries, which is essential for operations that require adding or modifying entries in the collection based on value data. +- [`CollectionAdd`] - Adds functionality for inserting entries into a collection, considering collection-specific rules such as duplication handling and order preservation, enhancing the usability of collections in forming scenarios. +- [`CollectionAssign`] - Extends the collection functionality to replace all existing entries with new ones, enabling bulk updates or complete resets of collection contents, which is particularly useful in dynamic data environments. -## Custom Container Former +## Custom Collection Former -Container interface is defined in the crate and implemented for containers like vectors, hash maps, etc, but if you want to use non-standard container you can implement container interface for the container. This example demonstrate how to do that. +Collection interface is defined in the crate and implemented for collections like vectors, hash maps, etc, but if you want to use non-standard collection you can implement collection interface for the collection. This example demonstrate how to do that. -Try out `cargo run --example former_custom_container`. +Try out `cargo run --example former_custom_collection`.
-[See code](./examples/former_custom_container.rs). +[See code](./examples/former_custom_collection.rs). ## Concept of Mutator @@ -1262,7 +1262,7 @@ Try out `cargo run --example former_custom_mutator`. - [Custom Defaults](./examples/former_custom_defaults.rs) - Former allows the specification of custom default values for fields through the `former( default )` attribute. -- [Custom Definition](./examples/former_custom_definition.rs) - Define a custom former definition and custom forming logic, and apply them to a container. +- [Custom Definition](./examples/former_custom_definition.rs) - Define a custom former definition and custom forming logic, and apply them to a collection. diff --git a/module/core/former/examples/former_container_hashmap.rs b/module/core/former/examples/former_collection_hashmap.rs similarity index 88% rename from module/core/former/examples/former_container_hashmap.rs rename to module/core/former/examples/former_collection_hashmap.rs index 8908adc7ab..4699ec192e 100644 --- a/module/core/former/examples/former_container_hashmap.rs +++ b/module/core/former/examples/former_collection_hashmap.rs @@ -1,5 +1,5 @@ //! -//! This example demonstrates how to effectively employ the `Former` trait to configure a `HashMap` using a container setter. +//! This example demonstrates how to effectively employ the `Former` trait to configure a `HashMap` using a collection setter. //! #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] @@ -12,7 +12,7 @@ fn main() #[ derive( Debug, PartialEq, former::Former ) ] pub struct StructWithMap { - #[ container ] + #[ subform_collection ] map : HashMap< &'static str, &'static str >, } diff --git a/module/core/former/examples/former_container_hashset.rs b/module/core/former/examples/former_collection_hashset.rs similarity index 96% rename from module/core/former/examples/former_container_hashset.rs rename to module/core/former/examples/former_collection_hashset.rs index 2c76d24a0a..7b2822c944 100644 --- a/module/core/former/examples/former_container_hashset.rs +++ b/module/core/former/examples/former_collection_hashset.rs @@ -12,7 +12,7 @@ fn main() #[ derive( Debug, PartialEq, former::Former ) ] pub struct StructWithSet { - #[ container ] + #[ subform_collection ] set : HashSet< &'static str >, } diff --git a/module/core/former/examples/former_container_vector.rs b/module/core/former/examples/former_collection_vector.rs similarity index 86% rename from module/core/former/examples/former_container_vector.rs rename to module/core/former/examples/former_collection_vector.rs index 92f67dbd47..ed813604f8 100644 --- a/module/core/former/examples/former_container_vector.rs +++ b/module/core/former/examples/former_collection_vector.rs @@ -1,5 +1,5 @@ //! -//! This example demonstrates how to employ the `Former` trait to configure a `Vec` using a container setter in a structured manner. +//! This example demonstrates how to employ the `Former` trait to configure a `Vec` using a collection setter in a structured manner. //! #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] @@ -11,7 +11,7 @@ fn main() #[ derive( Debug, PartialEq, former::Former ) ] pub struct StructWithVec { - #[ container ] + #[ subform_collection ] vec : Vec< &'static str >, } diff --git a/module/core/former/examples/former_custom_container.rs b/module/core/former/examples/former_custom_container.rs index c3e9ff0f8b..d30d3a01cb 100644 --- a/module/core/former/examples/former_custom_container.rs +++ b/module/core/former/examples/former_custom_container.rs @@ -1,8 +1,8 @@ -//! Example former_custom_container.rs +//! Example former_custom_collection.rs //! -//! This example demonstrates how to define and use a custom container with former. -//! The custom container implemented here is a `LoggingSet`, which extends the basic `HashSet` behavior -//! by logging each addition. This example illustrates how to integrate such custom containers with the +//! This example demonstrates how to define and use a custom collection with former. +//! The custom collection implemented here is a `LoggingSet`, which extends the basic `HashSet` behavior +//! by logging each addition. This example illustrates how to integrate such custom collections with the //! Former trait system for use in structured data types. #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] @@ -12,7 +12,7 @@ fn main() { use collection_tools::HashSet; - // Custom container that logs additions. + // Custom collection that logs additions. #[ derive( Debug, PartialEq ) ] pub struct LoggingSet< K > where @@ -21,7 +21,7 @@ fn main() set : HashSet< K >, // Internal HashSet to store the elements. } - // Implement default for the custom container. + // Implement default for the custom collection. impl< K > Default for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, @@ -36,7 +36,7 @@ fn main() } } - // Allow the custom container to be converted into an iterator, to iterate over the elements. + // Allow the custom collection to be converted into an iterator, to iterate over the elements. impl< K > IntoIterator for LoggingSet< K > where K : std::cmp::Eq + std::hash::Hash, @@ -64,8 +64,8 @@ fn main() } } - // Implement the Container trait to integrate with the former system. - impl< K > former::Container for LoggingSet< K > + // Implement the Collection trait to integrate with the former system. + impl< K > former::Collection for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -79,8 +79,8 @@ fn main() } } - // Implement ContainerAdd to handle adding elements to the custom container. - impl< K > former::ContainerAdd for LoggingSet< K > + // Implement CollectionAdd to handle adding elements to the custom collection. + impl< K > former::CollectionAdd for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -91,8 +91,8 @@ fn main() } } - // Implement ContainerAssign to handle bulk assignment of elements. - impl< K > former::ContainerAssign for LoggingSet< K > + // Implement CollectionAssign to handle bulk assignment of elements. + impl< K > former::CollectionAssign for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -106,8 +106,8 @@ fn main() } } - // Implement ContainerValToEntry to convert values back to entries. - impl< K > former::ContainerValToEntry< K > for LoggingSet< K > + // Implement CollectionValToEntry to convert values back to entries. + impl< K > former::CollectionValToEntry< K > for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -121,7 +121,7 @@ fn main() // = storage - // Define storage behavior for the custom container. + // Define storage behavior for the custom collection. impl< K > former::Storage for LoggingSet< K > where @@ -138,13 +138,13 @@ fn main() { fn preform( self ) -> Self::Preformed { - self // Return the container as is. + self // Return the collection as is. } } // = definition types - // Definitions related to the type settings for the LoggingSet, which detail how the container should behave with former. + // Definitions related to the type settings for the LoggingSet, which detail how the collection should behave with former. /// Holds generic parameter types for forming operations related to `LoggingSet`. #[ derive( Debug, Default ) ] @@ -249,17 +249,17 @@ fn main() // = subformer - // Subformer type alias simplifies the usage of `ContainerFormer` with `LoggingSet`. + // Subformer type alias simplifies the usage of `CollectionFormer` with `LoggingSet`. pub type LoggingSetAsSubformer< K, Context, Formed, End > = - former::ContainerFormer::< K, LoggingSetDefinition< K, Context, Formed, End > >; + former::CollectionFormer::< K, LoggingSetDefinition< K, Context, Formed, End > >; - // == use custom container + // == use custom collection /// Parent required for the template. #[ derive( Debug, Default, PartialEq, former::Former ) ] pub struct Parent { - #[ container ] + #[ subform_collection ] children : LoggingSet< i32 >, } diff --git a/module/core/former/examples/former_custom_container_setter.rs b/module/core/former/examples/former_custom_container_setter.rs index d882835b24..756d74b330 100644 --- a/module/core/former/examples/former_custom_container_setter.rs +++ b/module/core/former/examples/former_custom_container_setter.rs @@ -1,19 +1,19 @@ -// Example former_custom_container_setter.rs +// Example former_custom_collection_setter.rs //! -//! This example demonstrates the use of container setters to manage complex nested data structures with the `Former` trait, focusing on a parent-child relationship structured around a container `HashMap`. Unlike typical builder patterns that add individual elements using subform setters, this example uses a container setter to manage the entire collection of children. +//! This example demonstrates the use of collection setters to manage complex nested data structures with the `Former` trait, focusing on a parent-child relationship structured around a collection `HashMap`. Unlike typical builder patterns that add individual elements using subform setters, this example uses a collection setter to manage the entire collection of children. //! -//! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a container—each child entity in this case. +//! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. //! //! #### Types of Setters //! -//! It's crucial to understand the differences among subform setters, container setters, and scalar setters: +//! It's crucial to understand the differences among subform setters, collection setters, and scalar setters: //! -//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or container setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. //! -//! - **Container Setter**: Returns a former of the container itself, offering an interface to manage the container as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +//! - **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. //! -//! - **Subform Setter**: Returns a former of an element within a container, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +//! - **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. //! //! Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. //! @@ -44,24 +44,24 @@ fn main() pub struct Parent { // Use `hint = true` to gennerate sketch of setter. - #[ container( setter = false, hint = false ) ] + #[ subform_collection( setter = false, hint = false ) ] children : HashMap< String, Child >, } - /// The containr setter provides a container setter that returns a ContainerFormer tailored for managing a collection of child entities. It employs a generic container definition to facilitate operations on the entire collection, such as adding or updating elements. + /// The containr setter provides a collection setter that returns a CollectionFormer tailored for managing a collection of child entities. It employs a generic collection definition to facilitate operations on the entire collection, such as adding or updating elements. impl< Definition, > ParentFormer< Definition, > where Definition : former::FormerDefinition< Storage = ParentFormerStorage >, { #[ inline( always ) ] - pub fn children( self ) -> former::ContainerFormer:: + pub fn children( self ) -> former::CollectionFormer:: < ( String, Child ), - former::HashMapDefinition< String, Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > + former::HashMapDefinition< String, Child, Self, Self, ParentSubformCollectionChildrenEnd< Definition >, > > { - self._children_subform_container() + self._children_subform_collection() } } diff --git a/module/core/former/examples/former_custom_definition.rs b/module/core/former/examples/former_custom_definition.rs index 40957cf3ce..6b3ef3e978 100644 --- a/module/core/former/examples/former_custom_definition.rs +++ b/module/core/former/examples/former_custom_definition.rs @@ -1,8 +1,8 @@ //! ## Example : Custom Definition //! -//! Define a custom former definition and custom forming logic, and apply them to a container. +//! Define a custom former definition and custom forming logic, and apply them to a collection. //! -//! The example showcases how to accumulate elements into a container and then transform them into a single result +//! The example showcases how to accumulate elements into a collection and then transform them into a single result //! using a custom `FormingEnd` implementation. This pattern is useful for scenarios where the formation process //! involves aggregation or transformation of input elements into a different type or form. @@ -19,7 +19,7 @@ fn main() // This trait defines the types used during the forming process. impl former::FormerDefinitionTypes for Sum { - type Storage = Vec; // Container for the integers. + type Storage = Vec; // Collection for the integers. type Formed = i32; // The final type after forming, which is a single integer. type Context = (); // No additional context is used in this example. } @@ -59,7 +59,7 @@ fn main() } // Use the custom `Former` to sum a list of integers. - let got = former::ContainerFormer::::new(Sum) + let got = former::CollectionFormer::::new(Sum) .add( 1 ) // Add an integer to the storage. .add( 2 ) // Add another integer. .add( 10 ) // Add another integer. diff --git a/module/core/former/examples/former_custom_scalar_setter.rs b/module/core/former/examples/former_custom_scalar_setter.rs index e5acb1847b..8cd2a5dcd0 100644 --- a/module/core/former/examples/former_custom_scalar_setter.rs +++ b/module/core/former/examples/former_custom_scalar_setter.rs @@ -4,17 +4,17 @@ //! //! Use of a scalar setter within a `Former` trait implementation to directly assign a `HashMap` of `Child` entities to a `Parent` structure using a custom setter function. //! -//! Unlike the more complex subform and container setters shown in previous examples, this example focuses on a straightforward approach to directly set a scalar value within a parent entity. The `Parent` struct manages a `HashMap` of `Child` entities, and the scalar setter is used to set the entire `HashMap` directly. The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a container—each child entity in this case. +//! Unlike the more complex subform and collection setters shown in previous examples, this example focuses on a straightforward approach to directly set a scalar value within a parent entity. The `Parent` struct manages a `HashMap` of `Child` entities, and the scalar setter is used to set the entire `HashMap` directly. The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. //! //! #### Types of Setters //! -//! It's crucial to understand the differences among subform setters, container setters, and scalar setters: +//! It's crucial to understand the differences among subform setters, collection setters, and scalar setters: //! -//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or container setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. //! -//! - **Container Setter**: Returns a former of the container itself, offering an interface to manage the container as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +//! - **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. //! -//! - **Subform Setter**: Returns a former of an element within a container, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +//! - **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. //! //! Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. //! diff --git a/module/core/former/examples/former_custom_subform_setter.rs b/module/core/former/examples/former_custom_subform_setter.rs index 5e76abbcc9..965a9bda9a 100644 --- a/module/core/former/examples/former_custom_subform_setter.rs +++ b/module/core/former/examples/former_custom_subform_setter.rs @@ -3,17 +3,17 @@ //! //! This example illustrates the implementation of nested builder patterns using the `Former` trait, emphasizing a parent-child relationship. Here, the `Parent` struct utilizes `ChildFormer` as a custom subformer to dynamically manage its `child` field—a `HashMap`. Each child in the `HashMap` is uniquely identified and configured via the `ChildFormer`. //! -//! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a container—each child entity in this case. +//! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. //! //! #### Types of Setters //! -//! It's crucial to understand the differences among subform setters, container setters, and scalar setters: +//! It's crucial to understand the differences among subform setters, collection setters, and scalar setters: //! -//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or container setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. //! -//! - **Container Setter**: Returns a former of the container itself, offering an interface to manage the container as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +//! - **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. //! -//! - **Subform Setter**: Returns a former of an element within a container, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +//! - **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. //! //! Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. //! @@ -45,7 +45,7 @@ fn main() pub struct Parent { // Use `hint = true` to gennerate sketch of setter. - #[ subform( setter = false, hint = false ) ] + #[ subform_entry( setter = false, hint = false ) ] child : HashMap< String, Child >, } diff --git a/module/core/former/examples/former_custom_subform_setter2.rs b/module/core/former/examples/former_custom_subform_setter2.rs index 96c70e130f..ab1fbfca9d 100644 --- a/module/core/former/examples/former_custom_subform_setter2.rs +++ b/module/core/former/examples/former_custom_subform_setter2.rs @@ -5,17 +5,17 @@ //! //! #### Custom Subform Setter //! -//! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a container—each child entity in this case. +//! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. //! //! #### Types of Setters //! -//! It's crucial to understand the differences among subform setters, container setters, and scalar setters: +//! It's crucial to understand the differences among subform setters, collection setters, and scalar setters: //! -//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or container setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. //! -//! - **Container Setter**: Returns a former of the container itself, offering an interface to manage the container as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +//! - **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. //! -//! - **Subform Setter**: Returns a former of an element within a container, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +//! - **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. //! //! Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. //! @@ -46,7 +46,7 @@ fn main() pub struct Parent { // Use `hint = true` to gennerate sketch of setter. - #[ subform( setter = false, hint = false ) ] + #[ subform_entry( setter = false, hint = false ) ] child : HashMap< String, Child >, } @@ -73,7 +73,7 @@ fn main() super_former.storage.child = Some( Default::default() ); } - // add instance to the container + // add instance to the collection super_former.storage.child.as_mut().unwrap() .entry( preformed.name.clone() ) .or_insert( preformed.clone() ); @@ -101,12 +101,12 @@ fn main() super_former.storage.child = Some( Default::default() ); } - // add instance to the container + // add instance to the collection super_former.storage.child.as_mut().unwrap() .entry( preformed.name.clone() ) .or_insert( preformed.clone() ); - // custom logic to add two instances to the container + // custom logic to add two instances to the collection super_former.storage.child.as_mut().unwrap() .entry( format!( "{}_2", preformed.name ) ) .or_insert( preformed.clone() ); diff --git a/module/core/former/src/container.rs b/module/core/former/src/collection.rs similarity index 65% rename from module/core/former/src/container.rs rename to module/core/former/src/collection.rs index 2e0897da73..36ba0b7278 100644 --- a/module/core/former/src/container.rs +++ b/module/core/former/src/collection.rs @@ -1,8 +1,8 @@ //! //! This module defines traits and structures that facilitate the management and manipulation -//! of container data structures within a builder pattern context. It provides a comprehensive -//! interface for adding, managing, and converting elements within various types of containers, -//! such as vectors, hash maps, and custom container implementations. +//! of collection data structures within a builder pattern context. It provides a comprehensive +//! interface for adding, managing, and converting elements within various types of collections, +//! such as vectors, hash maps, and custom collection implementations. //! /// Internal namespace. @@ -11,18 +11,18 @@ pub( crate ) mod private use crate::*; - /// Facilitates the conversion of container entries to their corresponding value representations. + /// Facilitates the conversion of collection entries to their corresponding value representations. /// - /// This trait is utilized to transform an entry of a container into a value, abstracting the operation of containers - /// like vectors or hash maps. It ensures that even in complex container structures, entries can be seamlessly managed + /// This trait is utilized to transform an entry of a collection into a value, abstracting the operation of collections + /// like vectors or hash maps. It ensures that even in complex collection structures, entries can be seamlessly managed /// and manipulated as values. - pub trait EntryToVal< Container > + pub trait EntryToVal< Collection > { - /// The type of values stored in the container. This might be distinct from `Entry` in complex containers. + /// The type of values stored in the collection. This might be distinct from `Entry` in complex collections. /// For example, in a `HashMap`, while `Entry` might be a ( key, value ) tuple, `Val` might only be the value part. type Val; - /// Converts an entry into a value representation specific to the type of container. This conversion is crucial + /// Converts an entry into a value representation specific to the type of collection. This conversion is crucial /// for handling operations on entries, especially when they need to be treated or accessed as individual values, /// such as retrieving the value part from a key-value pair in a hash map. fn entry_to_val( self ) -> Self::Val; @@ -30,7 +30,7 @@ pub( crate ) mod private impl< C, E > EntryToVal< C > for E where - C : Container< Entry = E >, + C : Collection< Entry = E >, { type Val = C::Val; @@ -40,23 +40,23 @@ pub( crate ) mod private } } - /// Provides a mechanism for transforming a value back into a container-specific entry format. + /// Provides a mechanism for transforming a value back into a collection-specific entry format. /// - /// This trait is particularly valuable in scenarios where the operations on a container require + /// This trait is particularly valuable in scenarios where the operations on a collection require /// not just the manipulation of values but also the re-integration of these values as entries. /// It is especially crucial in complex data structures, such as `HashMap`s, where entries /// often involve a key-value pair, and simple values need to be restructured to fit this model /// for operations like insertion or update. - pub trait ContainerValToEntry< Val > + pub trait CollectionValToEntry< Val > { - /// The specific type of entry that corresponds to the value within the container. + /// The specific type of entry that corresponds to the value within the collection. /// For example, in a `HashMap`, this might be a tuple of a key and a value. type Entry; - /// Converts a value into a container-specific entry, facilitating operations that modify - /// the container. This method is key for ensuring that values can be correctly integrated - /// back into the container, particularly when the entry type is more complex than the value. + /// Converts a value into a collection-specific entry, facilitating operations that modify + /// the collection. This method is key for ensuring that values can be correctly integrated + /// back into the collection, particularly when the entry type is more complex than the value. /// /// # Parameters /// * `val` - The value to be converted into an entry. @@ -66,11 +66,11 @@ pub( crate ) mod private /// /// # Example /// ``` - /// use former::ContainerValToEntry; + /// use former::CollectionValToEntry; /// /// struct PairMap; /// - /// impl ContainerValToEntry< ( i32, i32 ) > for PairMap + /// impl CollectionValToEntry< ( i32, i32 ) > for PairMap /// { /// type Entry = ( String, i32 ); /// @@ -83,24 +83,24 @@ pub( crate ) mod private fn val_to_entry( val : Val ) -> Self::Entry; } - /// Facilitates the conversion of values back into entries for specific container types. + /// Facilitates the conversion of values back into entries for specific collection types. /// - /// This trait wraps the functionality of `ContainerValToEntry`, providing a more ergonomic + /// This trait wraps the functionality of `CollectionValToEntry`, providing a more ergonomic /// interface for converting values directly within the type they pertain to. It is useful - /// in maintaining the integrity of container operations, especially when dealing with + /// in maintaining the integrity of collection operations, especially when dealing with /// sophisticated structures that separate the concept of values and entries, such as `HashMap`s - /// and other associative containers. - pub trait ValToEntry< Container > + /// and other associative collections. + pub trait ValToEntry< Collection > { - /// Represents the type of entry that corresponds to the value within the container. + /// Represents the type of entry that corresponds to the value within the collection. type Entry; - /// Transforms the instance (value) into an entry compatible with the specified container. - /// This conversion is essential for operations like insertion or modification within the container, + /// Transforms the instance (value) into an entry compatible with the specified collection. + /// This conversion is essential for operations like insertion or modification within the collection, /// where the value needs to be formatted as an entry. /// /// # Returns - /// Returns the entry constructed from the instance of the value, ready for integration into the container. + /// Returns the entry constructed from the instance of the value, ready for integration into the collection. /// /// # Example /// ``` @@ -123,60 +123,60 @@ pub( crate ) mod private impl< C, Val > ValToEntry< C > for Val where - C : ContainerValToEntry< Val >, + C : CollectionValToEntry< Val >, { type Entry = C::Entry; - /// Invokes the `val_to_entry` function of the `ContainerValToEntry` trait to convert the value to an entry. + /// Invokes the `val_to_entry` function of the `CollectionValToEntry` trait to convert the value to an entry. fn val_to_entry( self ) -> C::Entry { C::val_to_entry( self ) } } - /// Represents a container by defining the types of entries and values it handles. + /// Represents a collection by defining the types of entries and values it handles. /// - /// This trait abstracts the nature of containers in data structures, facilitating the handling of contained - /// entries and values, especially in scenarios where the structure of the container allows for complex relationships, - /// such as `HashMap`s. It not only identifies what constitutes an entry and a value in the context of the container + /// This trait abstracts the nature of collections in data structures, facilitating the handling of contained + /// entries and values, especially in scenarios where the structure of the collection allows for complex relationships, + /// such as `HashMap`s. It not only identifies what constitutes an entry and a value in the context of the collection /// but also provides utility for converting between these two, which is critical in operations involving entry manipulation /// and value retrieval. - pub trait Container + pub trait Collection { - /// The type of entries that can be added to the container. This type can differ from `Val` in containers like `HashMap`, + /// The type of entries that can be added to the collection. This type can differ from `Val` in collections like `HashMap`, /// where an entry might represent a key-value pair, and `Val` could represent just the value or the key. type Entry; - /// The type of values stored in the container. This might be distinct from `Entry` in complex containers. + /// The type of values stored in the collection. This might be distinct from `Entry` in complex collections. /// For example, in a `HashMap`, while `Entry` might be a ( key, value ) tuple, `Val` might only be the value part. type Val; - /// Converts an entry to its corresponding value within the container. This function is essential for abstracting - /// the container's internal representation from the values it manipulates. + /// Converts an entry to its corresponding value within the collection. This function is essential for abstracting + /// the collection's internal representation from the values it manipulates. fn entry_to_val( e : Self::Entry ) -> Self::Val; } - /// Provides functionality to add individual entries to a container. + /// Provides functionality to add individual entries to a collection. /// - /// This trait extends the basic `Container` trait by introducing a method to add entries to a container. - /// It is designed to handle the container's specific requirements and rules for adding entries, such as + /// This trait extends the basic `Collection` trait by introducing a method to add entries to a collection. + /// It is designed to handle the collection's specific requirements and rules for adding entries, such as /// managing duplicates, maintaining order, or handling capacity constraints. - pub trait ContainerAdd : Container + pub trait CollectionAdd : Collection { - /// Adds an entry to the container and returns a boolean indicating the success of the operation. + /// Adds an entry to the collection and returns a boolean indicating the success of the operation. /// - /// Implementations should ensure that the entry is added according to the rules of the container, + /// Implementations should ensure that the entry is added according to the rules of the collection, /// which might involve checking for duplicates, ordering, or capacity limits. /// /// # Parameters /// - /// * `e`: The entry to be added to the container, where the type `Entry` is defined by the `Container` trait. + /// * `e`: The entry to be added to the collection, where the type `Entry` is defined by the `Collection` trait. /// /// # Returns /// /// Returns `true` if the entry was successfully added, or `false` if not added due to reasons such as - /// the entry already existing in the container or the container reaching its capacity. + /// the entry already existing in the collection or the collection reaching its capacity. /// /// # Examples /// @@ -184,14 +184,14 @@ pub( crate ) mod private /// /// ```rust /// - /// use former::{ Container, ContainerAdd }; + /// use former::{ Collection, CollectionAdd }; /// - /// struct MyContainer + /// struct MyCollection /// { /// entries : Vec< i32 >, /// } /// - /// impl Container for MyContainer + /// impl Collection for MyCollection /// { /// type Entry = i32; /// type Val = i32; @@ -204,7 +204,7 @@ pub( crate ) mod private /// /// } /// - /// impl ContainerAdd for MyContainer + /// impl CollectionAdd for MyCollection /// { /// fn add( &mut self, e : Self::Entry ) -> bool /// { @@ -220,49 +220,49 @@ pub( crate ) mod private /// } /// } /// - /// let mut container = MyContainer { entries : vec![] }; - /// assert!( container.add( 10 ) ); // Returns true, entry added - /// assert!( !container.add( 10 ) ); // Returns false, entry already exists + /// let mut collection = MyCollection { entries : vec![] }; + /// assert!( collection.add( 10 ) ); // Returns true, entry added + /// assert!( !collection.add( 10 ) ); // Returns false, entry already exists /// ``` fn add( &mut self, e : Self::Entry ) -> bool; } - /// Defines the capability to replace all entries in a container with a new set of entries. + /// Defines the capability to replace all entries in a collection with a new set of entries. /// - /// This trait extends the `Container` trait by providing a method to replace the existing entries in - /// the container with a new set. This can be useful for resetting the container's contents or bulk-updating + /// This trait extends the `Collection` trait by providing a method to replace the existing entries in + /// the collection with a new set. This can be useful for resetting the collection's contents or bulk-updating /// them based on external criteria or operations. - pub trait ContainerAssign : Container + pub trait CollectionAssign : Collection where Self : IntoIterator< Item = Self::Entry >, { - /// Replaces all entries in the container with the provided entries and returns the count of new entries added. + /// Replaces all entries in the collection with the provided entries and returns the count of new entries added. /// - /// This method clears the existing entries and populates the container with new ones provided by an iterator. - /// It is ideal for scenarios where the container needs to be refreshed or updated with a new batch of entries. + /// This method clears the existing entries and populates the collection with new ones provided by an iterator. + /// It is ideal for scenarios where the collection needs to be refreshed or updated with a new batch of entries. /// /// # Parameters /// - /// * `entries` : An iterator over the entries to be added to the container. The entries must conform to - /// the `Entry` type defined by the `Container` trait. + /// * `entries` : An iterator over the entries to be added to the collection. The entries must conform to + /// the `Entry` type defined by the `Collection` trait. /// /// # Returns /// - /// Returns the number of entries successfully added to the container. This count may differ from the total - /// number of entries in the iterator if the container imposes restrictions such as capacity limits or duplicate + /// Returns the number of entries successfully added to the collection. This count may differ from the total + /// number of entries in the iterator if the collection imposes restrictions such as capacity limits or duplicate /// handling. /// /// # Examples /// /// ```rust - /// use former::{ Container, ContainerAssign }; + /// use former::{ Collection, CollectionAssign }; /// - /// struct MyContainer + /// struct MyCollection /// { /// entries : Vec< i32 >, /// } /// - /// impl Container for MyContainer + /// impl Collection for MyCollection /// { /// type Entry = i32; /// type Val = i32; @@ -275,7 +275,7 @@ pub( crate ) mod private /// /// } /// - /// impl IntoIterator for MyContainer + /// impl IntoIterator for MyCollection /// { /// type Item = i32; /// type IntoIter = std::vec::IntoIter< i32 >; @@ -288,7 +288,7 @@ pub( crate ) mod private /// } /// } /// - /// impl ContainerAssign for MyContainer + /// impl CollectionAssign for MyCollection /// { /// fn assign< Entries >( &mut self, entries : Entries ) -> usize /// where @@ -300,9 +300,9 @@ pub( crate ) mod private /// } /// } /// - /// let mut container = MyContainer { entries : vec![ 1, 2, 3 ] }; + /// let mut collection = MyCollection { entries : vec![ 1, 2, 3 ] }; /// let new_elements = vec![ 4, 5, 6 ]; - /// assert_eq!( container.assign( new_elements ), 3 ); // Container now contains [ 4, 5, 6 ] + /// assert_eq!( collection.assign( new_elements ), 3 ); // Collection now contains [ 4, 5, 6 ] /// ``` fn assign< Entries >( &mut self, entries : Entries ) -> usize where @@ -311,12 +311,12 @@ pub( crate ) mod private // = - /// A builder structure for constructing containers with a fluent and flexible interface. + /// A builder structure for constructing collections with a fluent and flexible interface. #[ derive( Default ) ] - pub struct ContainerFormer< E, Definition > + pub struct CollectionFormer< E, Definition > where Definition : FormerDefinition, - Definition::Storage : ContainerAdd< Entry = E >, + Definition::Storage : CollectionAdd< Entry = E >, { storage : Definition::Storage, context : core::option::Option< Definition::Context >, @@ -324,15 +324,15 @@ pub( crate ) mod private } use core::fmt; - impl< E, Definition > fmt::Debug for ContainerFormer< E, Definition > + impl< E, Definition > fmt::Debug for CollectionFormer< E, Definition > where Definition : FormerDefinition, - Definition::Storage : ContainerAdd< Entry = E >, + Definition::Storage : CollectionAdd< Entry = E >, { fn fmt( &self, f : &mut fmt::Formatter< '_ > ) -> fmt::Result { f - .debug_struct( "ContainerFormer" ) + .debug_struct( "CollectionFormer" ) .field( "storage", &"Storage Present" ) .field( "context", &self.context.as_ref().map( |_| "Context Present" ) ) .field( "on_end", &self.on_end.as_ref().map( |_| "End Present" ) ) @@ -340,13 +340,13 @@ pub( crate ) mod private } } - impl< E, Definition > ContainerFormer< E, Definition > + impl< E, Definition > CollectionFormer< E, Definition > where Definition : FormerDefinition, - Definition::Storage : ContainerAdd< Entry = E >, + Definition::Storage : CollectionAdd< Entry = E >, { - /// Begins the construction process of a container with optional initial storage and context, - /// setting up an `on_end` completion handler to finalize the container's construction. + /// Begins the construction process of a collection with optional initial storage and context, + /// setting up an `on_end` completion handler to finalize the collection's construction. #[ inline( always ) ] pub fn begin ( @@ -419,14 +419,14 @@ pub( crate ) mod private } } - impl< E, Storage, Formed, Definition > ContainerFormer< E, Definition > + impl< E, Storage, Formed, Definition > CollectionFormer< E, Definition > where Definition : FormerDefinition< Context = (), Storage = Storage, Formed = Formed >, - Definition::Storage : ContainerAdd< Entry = E >, + Definition::Storage : CollectionAdd< Entry = E >, { - /// Constructs a new `ContainerFormer` instance, starting with an empty storage. + /// Constructs a new `CollectionFormer` instance, starting with an empty storage. /// This method serves as the entry point for the builder pattern, facilitating the - /// creation of a new container. + /// creation of a new collection. #[ inline( always ) ] pub fn new( end : Definition::End ) -> Self { @@ -454,10 +454,10 @@ pub( crate ) mod private } } - impl< E, Definition > ContainerFormer< E, Definition > + impl< E, Definition > CollectionFormer< E, Definition > where Definition : FormerDefinition, - Definition::Storage : ContainerAdd< Entry = E >, + Definition::Storage : CollectionAdd< Entry = E >, { /// Appends an entry to the end of the storage, expanding the internal collection. @@ -465,7 +465,7 @@ pub( crate ) mod private pub fn add< IntoElement >( mut self, entry : IntoElement ) -> Self where IntoElement : core::convert::Into< E >, { - ContainerAdd::add( &mut self.storage, entry.into() ); + CollectionAdd::add( &mut self.storage, entry.into() ); self } @@ -474,10 +474,10 @@ pub( crate ) mod private // impl< E, Definition > FormerBegin< Definition > - for ContainerFormer< E, Definition > + for CollectionFormer< E, Definition > where Definition : FormerDefinition, - Definition::Storage : ContainerAdd< Entry = E >, + Definition::Storage : CollectionAdd< Entry = E >, { #[ inline( always ) ] @@ -537,13 +537,13 @@ pub mod exposed { EntryToVal, - ContainerValToEntry, + CollectionValToEntry, ValToEntry, - Container, - ContainerAdd, - ContainerAssign, - ContainerFormer, + Collection, + CollectionAdd, + CollectionAssign, + CollectionFormer, }; diff --git a/module/core/former/src/container/hash_map.rs b/module/core/former/src/collection/hash_map.rs similarity index 91% rename from module/core/former/src/container/hash_map.rs rename to module/core/former/src/collection/hash_map.rs index 6054850903..ebef51a479 100644 --- a/module/core/former/src/container/hash_map.rs +++ b/module/core/former/src/collection/hash_map.rs @@ -1,6 +1,6 @@ -//! This module provides a comprehensive approach to applying the builder pattern to `HashMap` containers. +//! This module provides a comprehensive approach to applying the builder pattern to `HashMap` collections. //! -//! By leveraging traits such as `Container`, `ContainerAdd`, `ContainerAssign`, and `ContainerValToEntry`, +//! By leveraging traits such as `Collection`, `CollectionAdd`, `CollectionAssign`, and `CollectionValToEntry`, //! this module abstracts the operations on hashmap-like data structures, making them more flexible and easier to integrate as //! as subformer, enabling fluid and intuitive manipulation of hashmaps via builder patterns. //! @@ -8,7 +8,7 @@ use crate::*; use collection_tools::HashMap; -impl< K, V > Container for collection_tools::HashMap< K, V > +impl< K, V > Collection for collection_tools::HashMap< K, V > where K : core::cmp::Eq + core::hash::Hash, { @@ -23,7 +23,7 @@ where } -impl< K, V > ContainerAdd for collection_tools::HashMap< K, V > +impl< K, V > CollectionAdd for collection_tools::HashMap< K, V > where K : core::cmp::Eq + core::hash::Hash, { @@ -36,7 +36,7 @@ where } -impl< K, V > ContainerAssign for collection_tools::HashMap< K, V > +impl< K, V > CollectionAssign for collection_tools::HashMap< K, V > where K : core::cmp::Eq + core::hash::Hash, { @@ -74,9 +74,9 @@ where // = definition -/// Represents the formation definition for a hash map-like container within the former framework. +/// Represents the formation definition for a hash map-like collection within the former framework. /// -/// This structure defines the essential elements required to form a hash map-like container, detailing +/// This structure defines the essential elements required to form a hash map-like collection, detailing /// the key and value types, the contextual environment during formation, the final formed type, and the /// behavior at the end of the formation process. It facilitates customization and extension of hash map /// formation within any system that implements complex data management operations. @@ -202,9 +202,9 @@ where // = subformer -/// Provides a streamlined builder interface for constructing hash map-like containers. +/// Provides a streamlined builder interface for constructing hash map-like collections. /// -/// `HashMapFormer` is a type alias that configures the `ContainerFormer` specifically for hash maps, +/// `HashMapFormer` is a type alias that configures the `CollectionFormer` specifically for hash maps, /// facilitating a more intuitive and flexible way to build and manipulate hash maps within custom data structures. /// This type alias simplifies the usage of hash maps in builder patterns by encapsulating complex generic parameters /// and leveraging the `HashMapDefinition` to handle the construction logic. It supports fluent chaining of key-value @@ -214,7 +214,7 @@ where /// a builder pattern both efficient and expressive. pub type HashMapFormer< K, E, Context, Formed, End > = -ContainerFormer::< ( K, E ), HashMapDefinition< K, E, Context, Formed, End > >; +CollectionFormer::< ( K, E ), HashMapDefinition< K, E, Context, Formed, End > >; // = extension diff --git a/module/core/former/src/container/hash_set.rs b/module/core/former/src/collection/hash_set.rs similarity index 85% rename from module/core/former/src/container/hash_set.rs rename to module/core/former/src/collection/hash_set.rs index 6e96684ee1..ab77440ec8 100644 --- a/module/core/former/src/container/hash_set.rs +++ b/module/core/former/src/collection/hash_set.rs @@ -1,9 +1,9 @@ -//! This module provides a builder pattern implementation (`HashSetFormer`) for `HashSet`-like containers. It is designed to extend the builder pattern, allowing for fluent and dynamic construction of sets within custom data structures. +//! This module provides a builder pattern implementation (`HashSetFormer`) for `HashSet`-like collections. It is designed to extend the builder pattern, allowing for fluent and dynamic construction of sets within custom data structures. use crate::*; use collection_tools::HashSet; -impl< K > Container for collection_tools::HashSet< K > +impl< K > Collection for collection_tools::HashSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -18,7 +18,7 @@ where } -impl< K > ContainerAdd for collection_tools::HashSet< K > +impl< K > CollectionAdd for collection_tools::HashSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -33,7 +33,7 @@ where } -impl< K > ContainerAssign for collection_tools::HashSet< K > +impl< K > CollectionAssign for collection_tools::HashSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -49,7 +49,7 @@ where } } -impl< K > ContainerValToEntry< K > for HashSet< K > +impl< K > CollectionValToEntry< K > for HashSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -61,7 +61,7 @@ where } } -// /// A trait for containers behaving like a `HashSet`, allowing insertion operations. +// /// A trait for collections behaving like a `HashSet`, allowing insertion operations. // /// // /// Implementing this trait enables the associated formed to be used with `HashSetFormer`, // /// facilitating a builder pattern that is both intuitive and concise. @@ -114,12 +114,12 @@ where // = definition -/// Represents the formation definition for a hash set-like container within the former framework. +/// Represents the formation definition for a hash set-like collection within the former framework. /// -/// This structure defines the essential elements required to form a hash set-like container, detailing +/// This structure defines the essential elements required to form a hash set-like collection, detailing /// the type of elements, the contextual environment during formation, the final formed type, and the /// behavior at the end of the formation process. It is designed to support the construction and configuration -/// of hash set containers with dynamic characteristics and behaviors. +/// of hash set collections with dynamic characteristics and behaviors. /// /// # Type Parameters /// - `K`: The type of elements in the hash set. @@ -233,15 +233,15 @@ where // = subformer -/// Provides a concise alias for `ContainerFormer` configured specifically for `HashSet`-like containers. +/// Provides a concise alias for `CollectionFormer` configured specifically for `HashSet`-like collections. /// -/// `HashSetFormer` simplifies the creation of `HashSet` containers within builder patterns by leveraging -/// the `ContainerFormer` with predefined settings. This approach minimizes boilerplate code and enhances -/// readability, making it ideal for fluent and expressive construction of set containers within custom data structures. +/// `HashSetFormer` simplifies the creation of `HashSet` collections within builder patterns by leveraging +/// the `CollectionFormer` with predefined settings. This approach minimizes boilerplate code and enhances +/// readability, making it ideal for fluent and expressive construction of set collections within custom data structures. /// pub type HashSetFormer< K, Context, Formed, End > = -ContainerFormer::< K, HashSetDefinition< K, Context, Formed, End > >; +CollectionFormer::< K, HashSetDefinition< K, Context, Formed, End > >; // = extension diff --git a/module/core/former/src/container/vector.rs b/module/core/former/src/collection/vector.rs similarity index 89% rename from module/core/former/src/container/vector.rs rename to module/core/former/src/collection/vector.rs index 33c344d1ab..d3b707c03b 100644 --- a/module/core/former/src/container/vector.rs +++ b/module/core/former/src/collection/vector.rs @@ -1,6 +1,6 @@ -//! This module provides a comprehensive approach to applying the builder pattern to `Vec` containers. +//! This module provides a comprehensive approach to applying the builder pattern to `Vec` collections. //! -//! By leveraging traits such as `Container`, `ContainerAdd`, `ContainerAssign`, and `ContainerValToEntry`, +//! By leveraging traits such as `Collection`, `CollectionAdd`, `CollectionAssign`, and `CollectionValToEntry`, //! this module abstracts the operations on vector-like data structures, making them more flexible and easier to integrate as //! as subformer, enabling fluid and intuitive manipulation of vectors via builder patterns. //! @@ -9,7 +9,7 @@ use crate::*; #[ allow( unused ) ] use collection_tools::Vec; -impl< E > Container for collection_tools::Vec< E > +impl< E > Collection for collection_tools::Vec< E > { type Entry = E; type Val = E; @@ -22,7 +22,7 @@ impl< E > Container for collection_tools::Vec< E > } -impl< E > ContainerAdd for collection_tools::Vec< E > +impl< E > CollectionAdd for collection_tools::Vec< E > { #[ inline( always ) ] @@ -34,7 +34,7 @@ impl< E > ContainerAdd for collection_tools::Vec< E > } -impl< E > ContainerAssign for collection_tools::Vec< E > +impl< E > CollectionAssign for collection_tools::Vec< E > { #[ inline( always ) ] fn assign< Elements >( &mut self, elements : Elements ) -> usize @@ -48,7 +48,7 @@ impl< E > ContainerAssign for collection_tools::Vec< E > } -impl< E > ContainerValToEntry< E > for collection_tools::Vec< E > +impl< E > CollectionValToEntry< E > for collection_tools::Vec< E > where { type Entry = E; @@ -78,9 +78,9 @@ for Vec< E > // = definition -/// Represents the formation definition for a vector-like container within the former framework. +/// Represents the formation definition for a vector-like collection within the former framework. /// -/// This structure defines the necessary parameters and relationships needed to form a vector-like container, +/// This structure defines the necessary parameters and relationships needed to form a vector-like collection, /// including its storage, context, the result of the formation process, and the behavior at the end of the formation. /// /// # Type Parameters @@ -189,9 +189,9 @@ for Vec< E > // = subformer -/// Provides a streamlined builder interface for constructing vector-like containers. +/// Provides a streamlined builder interface for constructing vector-like collections. /// -/// `VectorFormer` is a type alias that configures the `ContainerFormer` for use specifically with vectors. +/// `VectorFormer` is a type alias that configures the `CollectionFormer` for use specifically with vectors. /// It integrates the `VectorDefinition` to facilitate the fluent and dynamic construction of vectors, leveraging /// predefined settings to reduce boilerplate code. This approach enhances readability and simplifies the use of /// vectors in custom data structures where builder patterns are desired. @@ -202,7 +202,7 @@ for Vec< E > /// pub type VectorFormer< E, Context, Formed, End > = -ContainerFormer::< E, VectorDefinition< E, Context, Formed, End > >; +CollectionFormer::< E, VectorDefinition< E, Context, Formed, End > >; // = extension diff --git a/module/core/former/src/forming.rs b/module/core/former/src/forming.rs index 892f4ad526..d95bea8666 100644 --- a/module/core/former/src/forming.rs +++ b/module/core/former/src/forming.rs @@ -57,7 +57,7 @@ where /// Implementors can define how to transform or pass through the context during the forming process's completion. /// /// # Parameters -/// - `Storage`: The type of the container being processed. +/// - `Storage`: The type of the collection being processed. /// - `Context`: The type of the context that might be altered or returned upon completion. pub trait FormingEnd< Definition : crate::FormerDefinitionTypes > @@ -65,7 +65,7 @@ pub trait FormingEnd< Definition : crate::FormerDefinitionTypes > /// Called at the end of the subforming process to return the modified or original context. /// /// # Parameters - /// - `container`: The container being processed. + /// - `collection`: The collection being processed. /// - `context`: Optional context to be transformed or returned. /// /// # Returns @@ -85,9 +85,9 @@ where } } -/// A `FormingEnd` implementation that directly returns the formed container as the final product of the forming process. +/// A `FormingEnd` implementation that directly returns the formed collection as the final product of the forming process. /// -/// This struct is particularly useful when the end result of the forming process is simply the formed container itself, +/// This struct is particularly useful when the end result of the forming process is simply the formed collection itself, /// without needing to integrate or process additional contextual information. It's ideal for scenarios where the final /// entity is directly derived from the storage state without further transformations or context-dependent adjustments. #[ derive( Debug, Default ) ] @@ -193,7 +193,7 @@ impl< Definition : crate::FormerDefinitionTypes > FormingEndClosure< Definition /// /// # Parameters /// - /// * `closure` - A closure that matches the expected signature for transforming a container + /// * `closure` - A closure that matches the expected signature for transforming a collection /// and context into a new context. This closure is stored and called by the /// `call` method of the `FormingEnd` trait implementation. /// diff --git a/module/core/former/src/lib.rs b/module/core/former/src/lib.rs index 9653b8152e..85b73f8e13 100644 --- a/module/core/former/src/lib.rs +++ b/module/core/former/src/lib.rs @@ -21,11 +21,11 @@ mod forming; #[ cfg( feature = "derive_former" ) ] mod storage; -/// Interface for containers. +/// Interface for collections. #[ cfg( feature = "enabled" ) ] #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] #[ cfg( feature = "derive_former" ) ] -mod container; +mod collection; /// Component-based forming. #[ cfg( feature = "enabled" ) ] @@ -95,7 +95,7 @@ pub mod exposed #[ cfg( feature = "enabled" ) ] #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] #[ cfg( feature = "derive_former" ) ] - pub use super::container::*; + pub use super::collection::*; } diff --git a/module/core/former/tests/inc/former_tests/attribute_default_container.rs b/module/core/former/tests/inc/former_tests/attribute_default_collection.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/attribute_default_container.rs rename to module/core/former/tests/inc/former_tests/attribute_default_collection.rs diff --git a/module/core/former/tests/inc/former_tests/container_former_common.rs b/module/core/former/tests/inc/former_tests/collection_former_common.rs similarity index 85% rename from module/core/former/tests/inc/former_tests/container_former_common.rs rename to module/core/former/tests/inc/former_tests/collection_former_common.rs index 3bc9c84dfc..80ed29689e 100644 --- a/module/core/former/tests/inc/former_tests/container_former_common.rs +++ b/module/core/former/tests/inc/former_tests/collection_former_common.rs @@ -132,14 +132,14 @@ fn custom_definition() // - let got = former::ContainerFormer::< String, Return13 >::begin( None, None, Return13 ) + let got = former::CollectionFormer::< String, Return13 >::begin( None, None, Return13 ) .add( "a" ) .add( "b" ) .form(); let exp = 13; a_id!( got, exp ); - let got = former::ContainerFormer::< String, Return13 >::new( Return13 ) + let got = former::CollectionFormer::< String, Return13 >::new( Return13 ) .add( "a" ) .add( "b" ) .form(); @@ -205,14 +205,14 @@ fn custom_definition_parametrized() // - let got = the_module::ContainerFormer::< String, Return13< String > >::begin_coercing( None, None, Return13::new() ) + let got = the_module::CollectionFormer::< String, Return13< String > >::begin_coercing( None, None, Return13::new() ) .add( "a" ) .add( "b" ) .form(); let exp = 13; a_id!( got, exp ); - let got = the_module::ContainerFormer::< String, Return13< String > >::new_coercing( Return13::new() ) + let got = the_module::CollectionFormer::< String, Return13< String > >::new_coercing( Return13::new() ) .add( "a" ) .add( "b" ) .form(); @@ -221,16 +221,16 @@ fn custom_definition_parametrized() // - type MyContainer< E > = the_module::ContainerFormer::< E, Return13< E > >; + type MyCollection< E > = the_module::CollectionFormer::< E, Return13< E > >; - let got = MyContainer::< String >::begin_coercing( None, None, Return13::new() ) + let got = MyCollection::< String >::begin_coercing( None, None, Return13::new() ) .add( "a" ) .add( "b" ) .form(); let exp = 13; a_id!( got, exp ); - let got = MyContainer::< String >::new_coercing( Return13::new() ) + let got = MyCollection::< String >::new_coercing( Return13::new() ) .add( "a" ) .add( "b" ) .form(); @@ -273,21 +273,21 @@ fn custom_definition_custom_end() } let end_wrapper : the_module::FormingEndClosure< Return13 > = the_module::FormingEndClosure::new( return_13 ); - let got = the_module::ContainerFormer::< String, Return13 >::new( end_wrapper ) + let got = the_module::CollectionFormer::< String, Return13 >::new( end_wrapper ) .add( "a" ) .add( "b" ) .form(); let exp = 13; a_id!( got, exp ); - let got = the_module::ContainerFormer::< String, Return13 >::new( return_13.into() ) + let got = the_module::CollectionFormer::< String, Return13 >::new( return_13.into() ) .add( "a" ) .add( "b" ) .form(); let exp = 13; a_id!( got, exp ); - let got = the_module::ContainerFormer::< String, Return13 >::new_coercing( return_13 ) + let got = the_module::CollectionFormer::< String, Return13 >::new_coercing( return_13 ) .add( "a" ) .add( "b" ) .form(); diff --git a/module/core/former/tests/inc/former_tests/container_former_hashmap.rs b/module/core/former/tests/inc/former_tests/collection_former_hashmap.rs similarity index 98% rename from module/core/former/tests/inc/former_tests/container_former_hashmap.rs rename to module/core/former/tests/inc/former_tests/collection_former_hashmap.rs index 1b34ebbb3b..ac0a6abedf 100644 --- a/module/core/former/tests/inc/former_tests/container_former_hashmap.rs +++ b/module/core/former/tests/inc/former_tests/collection_former_hashmap.rs @@ -11,10 +11,10 @@ use collection_tools::HashMap; fn add() { - // expliccit with ContainerFormer + // expliccit with CollectionFormer let got : HashMap< String, String > = the_module - ::ContainerFormer + ::CollectionFormer ::< ( String, String ), former::HashMapDefinition< String, String, (), HashMap< String, String >, the_module::ReturnStorage > > ::new( former::ReturnStorage ) .add( ( "a".into(), "x".into() ) ) diff --git a/module/core/former/tests/inc/former_tests/container_former_hashset.rs b/module/core/former/tests/inc/former_tests/collection_former_hashset.rs similarity index 97% rename from module/core/former/tests/inc/former_tests/container_former_hashset.rs rename to module/core/former/tests/inc/former_tests/collection_former_hashset.rs index 83b8e7a994..c3fa89935a 100644 --- a/module/core/former/tests/inc/former_tests/container_former_hashset.rs +++ b/module/core/former/tests/inc/former_tests/collection_former_hashset.rs @@ -11,10 +11,10 @@ use collection_tools::HashSet; fn add() { - // expliccit with ContainerFormer + // expliccit with CollectionFormer let got : HashSet< String > = the_module - ::ContainerFormer + ::CollectionFormer ::< String, former::HashSetDefinition< String, (), HashSet< String >, the_module::ReturnStorage > > ::new( former::ReturnStorage ) .add( "a" ) diff --git a/module/core/former/tests/inc/former_tests/container_former_vec.rs b/module/core/former/tests/inc/former_tests/collection_former_vec.rs similarity index 96% rename from module/core/former/tests/inc/former_tests/container_former_vec.rs rename to module/core/former/tests/inc/former_tests/collection_former_vec.rs index ec76210448..b9eb91c6f8 100644 --- a/module/core/former/tests/inc/former_tests/container_former_vec.rs +++ b/module/core/former/tests/inc/former_tests/collection_former_vec.rs @@ -10,10 +10,10 @@ use collection_tools::Vec; fn add() { - // expliccit with ContainerFormer + // expliccit with CollectionFormer let got : Vec< String > = the_module - ::ContainerFormer + ::CollectionFormer ::< String, former::VectorDefinition< String, (), Vec< String >, the_module::ReturnStorage > > ::new( former::ReturnStorage ) .add( "a" ) @@ -105,7 +105,7 @@ fn replace() // -// qqq : make similar test for all containers +// qqq : make similar test for all collections #[ test ] fn entity_to() { diff --git a/module/core/former/tests/inc/former_tests/name_collisions.rs b/module/core/former/tests/inc/former_tests/name_collisions.rs index 843af61803..9d935c81b8 100644 --- a/module/core/former/tests/inc/former_tests/name_collisions.rs +++ b/module/core/former/tests/inc/former_tests/name_collisions.rs @@ -34,4 +34,4 @@ pub struct Struct1 // -include!( "./only_test/containers_without_subformer.rs" ); +include!( "./only_test/collections_without_subformer.rs" ); diff --git a/module/core/former/tests/inc/former_tests/only_test/containers_with_subformer.rs b/module/core/former/tests/inc/former_tests/only_test/collections_with_subformer.rs similarity index 96% rename from module/core/former/tests/inc/former_tests/only_test/containers_with_subformer.rs rename to module/core/former/tests/inc/former_tests/only_test/collections_with_subformer.rs index 42309cf1a6..0c57911f19 100644 --- a/module/core/former/tests/inc/former_tests/only_test/containers_with_subformer.rs +++ b/module/core/former/tests/inc/former_tests/only_test/collections_with_subformer.rs @@ -121,10 +121,10 @@ tests_impls! fn field_forming_end() { - // Container subformers are defined - let _got = Struct1SubformContainerVec1End::< Struct1FormerDefinition >::default(); - let _got = Struct1SubformContainerHashmap1End::< Struct1FormerDefinition >::default(); - let _got = Struct1SubformContainerHashset1End::< Struct1FormerDefinition >::default(); + // Collection subformers are defined + let _got = Struct1SubformCollectionVec1End::< Struct1FormerDefinition >::default(); + let _got = Struct1SubformCollectionHashmap1End::< Struct1FormerDefinition >::default(); + let _got = Struct1SubformCollectionHashset1End::< Struct1FormerDefinition >::default(); // AsSubformerEnd is defined fn _f1< End : Struct1AsSubformerEnd< Struct1Former > > diff --git a/module/core/former/tests/inc/former_tests/only_test/containers_without_subformer.rs b/module/core/former/tests/inc/former_tests/only_test/collections_without_subformer.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/containers_without_subformer.rs rename to module/core/former/tests/inc/former_tests/only_test/collections_without_subformer.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_container.rs b/module/core/former/tests/inc/former_tests/only_test/subformer_collection.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/subformer_container.rs rename to module/core/former/tests/inc/former_tests/only_test/subformer_collection.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_container_children2.rs b/module/core/former/tests/inc/former_tests/only_test/subformer_collection_children2.rs similarity index 95% rename from module/core/former/tests/inc/former_tests/only_test/subformer_container_children2.rs rename to module/core/former/tests/inc/former_tests/only_test/subformer_collection_children2.rs index 46fae25331..4821ab23e8 100644 --- a/module/core/former/tests/inc/former_tests/only_test/subformer_container_children2.rs +++ b/module/core/former/tests/inc/former_tests/only_test/subformer_collection_children2.rs @@ -1,6 +1,6 @@ #[ test ] -fn container() +fn collection() { let got = Parent::former() diff --git a/module/core/former/tests/inc/former_tests/parametrized_struct_imm.rs b/module/core/former/tests/inc/former_tests/parametrized_struct_imm.rs index d216575504..8ffd7ad762 100644 --- a/module/core/former/tests/inc/former_tests/parametrized_struct_imm.rs +++ b/module/core/former/tests/inc/former_tests/parametrized_struct_imm.rs @@ -28,7 +28,7 @@ impl< Name > Property< Name > pub struct Child< K : core::hash::Hash + std::cmp::Eq > { pub name : String, - #[ container( definition = former::HashMapDefinition ) ] + #[ subform_collection( definition = former::HashMapDefinition ) ] pub properties : collection_tools::HashMap< K, Property< K > >, } diff --git a/module/core/former/tests/inc/former_tests/parametrized_struct_manual.rs b/module/core/former/tests/inc/former_tests/parametrized_struct_manual.rs index 95e081b39e..efab5306c5 100644 --- a/module/core/former/tests/inc/former_tests/parametrized_struct_manual.rs +++ b/module/core/former/tests/inc/former_tests/parametrized_struct_manual.rs @@ -30,7 +30,7 @@ where K : core::hash::Hash + std::cmp::Eq, { pub name : String, - // #[ container( definition = former::HashMapDefinition ) ] + // #[ subform_collection( definition = former::HashMapDefinition ) ] pub properties : collection_tools::HashMap< K, Property< K > >, } @@ -318,9 +318,9 @@ where } #[ inline( always ) ] - pub fn properties( self ) -> former::ContainerFormer::< ( K, Property< K >, ), former::HashMapDefinition< K, Property< K >, Self, Self, ChildFormerPropertiesEnd > > + pub fn properties( self ) -> former::CollectionFormer::< ( K, Property< K >, ), former::HashMapDefinition< K, Property< K >, Self, Self, ChildFormerPropertiesEnd > > { - self.properties_set::< former::ContainerFormer::< ( K, Property< K >, ), former::HashMapDefinition< K, Property< K >, Self, Self, ChildFormerPropertiesEnd > >>() + self.properties_set::< former::CollectionFormer::< ( K, Property< K >, ), former::HashMapDefinition< K, Property< K >, Self, Self, ChildFormerPropertiesEnd > >>() } } @@ -356,7 +356,7 @@ where let mut super_former = super_former.unwrap(); if let Some( ref mut field ) = super_former.storage.properties { - former::ContainerAssign::assign( field, storage ); + former::CollectionAssign::assign( field, storage ); } else { diff --git a/module/core/former/tests/inc/former_tests/parametrized_struct_where.rs b/module/core/former/tests/inc/former_tests/parametrized_struct_where.rs index 063e58be1c..b45429c63c 100644 --- a/module/core/former/tests/inc/former_tests/parametrized_struct_where.rs +++ b/module/core/former/tests/inc/former_tests/parametrized_struct_where.rs @@ -30,7 +30,7 @@ where K : core::hash::Hash + std::cmp::Eq, { pub name : String, - #[ container( definition = former::HashMapDefinition ) ] + #[ subform_collection( definition = former::HashMapDefinition ) ] pub properties : collection_tools::HashMap< K, Property< K > >, } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_and_container.rs b/module/core/former/tests/inc/former_tests/subform_all.rs similarity index 89% rename from module/core/former/tests/inc/former_tests/subform_entry_and_container.rs rename to module/core/former/tests/inc/former_tests/subform_all.rs index 3e04d86cbd..b201f63c02 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_and_container.rs +++ b/module/core/former/tests/inc/former_tests/subform_all.rs @@ -16,8 +16,8 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ subform( name = _child ) ] - #[ container( name = children2 ) ] + #[ subform_entry( name = _child ) ] + #[ subform_collection( name = children2 ) ] #[ scalar( name = children3 ) ] children : Vec< Child >, } @@ -52,5 +52,5 @@ where // == end of generated include!( "./only_test/subformer_subform_child.rs" ); -include!( "./only_test/subformer_container_children2.rs" ); +include!( "./only_test/subformer_collection_children2.rs" ); include!( "./only_test/scalar_children3.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs b/module/core/former/tests/inc/former_tests/subform_all_parametrized.rs similarity index 94% rename from module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs rename to module/core/former/tests/inc/former_tests/subform_all_parametrized.rs index c5d1a935f1..9d45778855 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_and_container_parametrized.rs +++ b/module/core/former/tests/inc/former_tests/subform_all_parametrized.rs @@ -20,8 +20,8 @@ where // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent< 'child > { - #[ subform( name = _child ) ] - #[ container( name = children2 ) ] + #[ subform_entry( name = _child ) ] + #[ subform_collection( name = children2 ) ] #[ scalar( name = children3 ) ] children : Vec< Child< 'child, str > >, } @@ -85,7 +85,7 @@ fn subform_child_generated() } #[ test ] -fn container() +fn collection() { let got = Parent::former() @@ -130,5 +130,5 @@ fn scalar() } // include!( "./only_test/subformer_subform_child.rs" ); -// include!( "./only_test/subformer_container_children2.rs" ); +// include!( "./only_test/subformer_collection_children2.rs" ); // include!( "./only_test/subformer_scalar_children3.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs b/module/core/former/tests/inc/former_tests/subform_all_private.rs similarity index 89% rename from module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs rename to module/core/former/tests/inc/former_tests/subform_all_private.rs index eefbe42e21..dda702f5d0 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_and_container_private.rs +++ b/module/core/former/tests/inc/former_tests/subform_all_private.rs @@ -16,8 +16,8 @@ struct Child // #[ derive( Debug, Default, PartialEq ) ] struct Parent { - #[ subform( name = _child ) ] - #[ container( name = children2 ) ] + #[ subform_entry( name = _child ) ] + #[ subform_collection( name = children2 ) ] #[ scalar( name = children3 ) ] children : Vec< Child >, } @@ -52,5 +52,5 @@ where // == end of generated include!( "./only_test/subformer_subform_child.rs" ); -include!( "./only_test/subformer_container_children2.rs" ); +include!( "./only_test/subformer_collection_children2.rs" ); include!( "./only_test/scalar_children3.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container.rs b/module/core/former/tests/inc/former_tests/subform_collection.rs similarity index 80% rename from module/core/former/tests/inc/former_tests/subform_container.rs rename to module/core/former/tests/inc/former_tests/subform_collection.rs index c168f83e8b..d9941e680b 100644 --- a/module/core/former/tests/inc/former_tests/subform_container.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection.rs @@ -16,7 +16,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ container( definition = former::VectorDefinition ) ] + #[ subform_collection( definition = former::VectorDefinition ) ] children : Vec< Child >, } @@ -24,4 +24,4 @@ pub struct Parent // == end of generated -include!( "./only_test/subformer_container.rs" ); +include!( "./only_test/subformer_collection.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container_basic.rs b/module/core/former/tests/inc/former_tests/subform_collection_basic.rs similarity index 66% rename from module/core/former/tests/inc/former_tests/subform_container_basic.rs rename to module/core/former/tests/inc/former_tests/subform_collection_basic.rs index c2466841bf..1fcf5792cd 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_basic.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_basic.rs @@ -11,11 +11,11 @@ use super::*; // #[ derive( Default, Debug, PartialEq ) ] pub struct Struct1 { - #[ container( definition = former::VectorDefinition ) ] + #[ subform_collection( definition = former::VectorDefinition ) ] vec_1 : Vec< String >, - #[ container( definition = former::HashMapDefinition ) ] + #[ subform_collection( definition = former::HashMapDefinition ) ] hashmap_1 : std::collections::HashMap< String, String >, - #[ container( definition = former::HashSetDefinition ) ] + #[ subform_collection( definition = former::HashSetDefinition ) ] hashset_1 : std::collections::HashSet< String >, } @@ -23,4 +23,4 @@ pub struct Struct1 // == generated end -include!( "./only_test/containers_with_subformer.rs" ); +include!( "./only_test/collections_with_subformer.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs b/module/core/former/tests/inc/former_tests/subform_collection_basic_manual.rs similarity index 80% rename from module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs rename to module/core/former/tests/inc/former_tests/subform_collection_basic_manual.rs index be0a0f5bc7..314bace671 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_basic_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_basic_manual.rs @@ -341,46 +341,46 @@ where where Former2 : former::FormerBegin < - former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > >, + former::VectorDefinition< String, Self, Self, Struct1SubformCollectionVec1End< Definition > >, >, - former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > > : former::FormerDefinition + former::VectorDefinition< String, Self, Self, Struct1SubformCollectionVec1End< Definition > > : former::FormerDefinition < - // Storage : former::ContainerAdd< Entry = < collection_tools::Vec< String > as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < collection_tools::Vec< String > as former::Collection >::Entry >, Storage = Vec< String >, Context = Struct1Former< Definition >, - End = Struct1SubformContainerVec1End< Definition >, + End = Struct1SubformCollectionVec1End< Definition >, >, - Struct1SubformContainerVec1End< Definition > : former::FormingEnd + Struct1SubformCollectionVec1End< Definition > : former::FormingEnd < < collection_tools::Vec< String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - Former2::former_begin( None, Some( self ), Struct1SubformContainerVec1End::< Definition >::default() ) + Former2::former_begin( None, Some( self ), Struct1SubformCollectionVec1End::< Definition >::default() ) } #[ inline( always ) ] - pub fn vec_1( self ) -> former::ContainerFormer:: + pub fn vec_1( self ) -> former::CollectionFormer:: < String, - former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > >, + former::VectorDefinition< String, Self, Self, Struct1SubformCollectionVec1End< Definition > >, > where - former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > > : former::FormerDefinition + former::VectorDefinition< String, Self, Self, Struct1SubformCollectionVec1End< Definition > > : former::FormerDefinition < - // Storage : former::ContainerAdd< Entry = < collection_tools::Vec< String > as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < collection_tools::Vec< String > as former::Collection >::Entry >, Storage = Vec< String >, Context = Struct1Former< Definition >, - End = Struct1SubformContainerVec1End< Definition >, + End = Struct1SubformCollectionVec1End< Definition >, >, - Struct1SubformContainerVec1End< Definition > : former::FormingEnd + Struct1SubformCollectionVec1End< Definition > : former::FormingEnd < < collection_tools::Vec< String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - self._vec_1_assign::< former::ContainerFormer:: + self._vec_1_assign::< former::CollectionFormer:: < String, - former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End< Definition > >, + former::VectorDefinition< String, Self, Self, Struct1SubformCollectionVec1End< Definition > >, > > () } @@ -389,46 +389,46 @@ where where Former2 : former::FormerBegin < - former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > >, + former::HashMapDefinition< String, String, Self, Self, Struct1SubformCollectionHashmap1End< Definition > >, >, - former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > > : former::FormerDefinition + former::HashMapDefinition< String, String, Self, Self, Struct1SubformCollectionHashmap1End< Definition > > : former::FormerDefinition < - // Storage : former::ContainerAdd< Entry = < collection_tools::HashMap< String, String > as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < collection_tools::HashMap< String, String > as former::Collection >::Entry >, Storage = collection_tools::HashMap< String, String >, Context = Struct1Former< Definition >, - End = Struct1SubformContainerHashmap1End< Definition >, + End = Struct1SubformCollectionHashmap1End< Definition >, >, - Struct1SubformContainerHashmap1End< Definition > : former::FormingEnd + Struct1SubformCollectionHashmap1End< Definition > : former::FormingEnd < < collection_tools::HashMap< String, String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - Former2::former_begin( None, Some( self ), Struct1SubformContainerHashmap1End::< Definition >::default() ) + Former2::former_begin( None, Some( self ), Struct1SubformCollectionHashmap1End::< Definition >::default() ) } #[ inline( always ) ] - pub fn hashmap_1( self ) -> former::ContainerFormer:: + pub fn hashmap_1( self ) -> former::CollectionFormer:: < ( String, String ), - former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > >, + former::HashMapDefinition< String, String, Self, Self, Struct1SubformCollectionHashmap1End< Definition > >, > where - former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > > : former::FormerDefinition + former::HashMapDefinition< String, String, Self, Self, Struct1SubformCollectionHashmap1End< Definition > > : former::FormerDefinition < - // Storage : former::ContainerAdd< Entry = < collection_tools::HashMap< String, String > as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < collection_tools::HashMap< String, String > as former::Collection >::Entry >, Storage = collection_tools::HashMap< String, String >, Context = Struct1Former< Definition >, - End = Struct1SubformContainerHashmap1End< Definition >, + End = Struct1SubformCollectionHashmap1End< Definition >, >, - Struct1SubformContainerHashmap1End< Definition > : former::FormingEnd + Struct1SubformCollectionHashmap1End< Definition > : former::FormingEnd < < collection_tools::HashMap< String, String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - self._hashmap_1_assign::< former::ContainerFormer:: + self._hashmap_1_assign::< former::CollectionFormer:: < ( String, String ), - former::HashMapDefinition< String, String, Self, Self, Struct1SubformContainerHashmap1End< Definition > >, + former::HashMapDefinition< String, String, Self, Self, Struct1SubformCollectionHashmap1End< Definition > >, > > () } @@ -437,46 +437,46 @@ where where Former2 : former::FormerBegin < - former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, + former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > >, >, - former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > > : former::FormerDefinition + former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > > : former::FormerDefinition < - // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < collection_tools::HashSet< String > as former::Collection >::Entry >, Storage = collection_tools::HashSet< String >, Context = Struct1Former< Definition >, - End = Struct1SubformContainerHashset1End< Definition >, + End = Struct1SubformCollectionHashset1End< Definition >, >, - Struct1SubformContainerHashset1End< Definition > : former::FormingEnd + Struct1SubformCollectionHashset1End< Definition > : former::FormingEnd < < collection_tools::HashSet< String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - Former2::former_begin( None, Some( self ), Struct1SubformContainerHashset1End::< Definition >::default() ) + Former2::former_begin( None, Some( self ), Struct1SubformCollectionHashset1End::< Definition >::default() ) } #[ inline( always ) ] - pub fn hashset_1( self ) -> former::ContainerFormer:: + pub fn hashset_1( self ) -> former::CollectionFormer:: < String, - former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, + former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > >, > where - former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > > : former::FormerDefinition + former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > > : former::FormerDefinition < - // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < collection_tools::HashSet< String > as former::Collection >::Entry >, Storage = collection_tools::HashSet< String >, Context = Struct1Former< Definition >, - End = Struct1SubformContainerHashset1End< Definition >, + End = Struct1SubformCollectionHashset1End< Definition >, >, - Struct1SubformContainerHashset1End< Definition > : former::FormingEnd + Struct1SubformCollectionHashset1End< Definition > : former::FormingEnd < < collection_tools::HashSet< String > as former::EntityToDefinitionTypes< Self, Self > >::Types >, { - self._hashset_1_assign::< former::ContainerFormer:: + self._hashset_1_assign::< former::CollectionFormer:: < String, - former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, + former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > >, > > () } @@ -538,12 +538,12 @@ where // = former assign end -pub struct Struct1SubformContainerVec1End< Definition > +pub struct Struct1SubformCollectionVec1End< Definition > { _phantom : core::marker::PhantomData< ( Definition, ) >, } -impl Default for Struct1SubformContainerVec1End< Definition > +impl Default for Struct1SubformCollectionVec1End< Definition > { #[ inline( always ) ] fn default() -> Self @@ -561,7 +561,7 @@ impl< Definition > former::FormingEnd < former::VectorDefinitionTypes< String, Struct1Former< Definition >, Struct1Former< Definition > > > -for Struct1SubformContainerVec1End< Definition > +for Struct1SubformCollectionVec1End< Definition > where Definition : former::FormerDefinition< Storage = Struct1FormerStorage >, Definition::Types : former::FormerDefinitionTypes< Storage = Struct1FormerStorage >, @@ -573,7 +573,7 @@ where let mut super_former = super_former.unwrap(); if let Some( ref mut field ) = super_former.storage.vec_1 { - former::ContainerAssign::assign( field, storage ); + former::CollectionAssign::assign( field, storage ); } else { @@ -583,12 +583,12 @@ where } } -pub struct Struct1SubformContainerHashmap1End +pub struct Struct1SubformCollectionHashmap1End { _phantom : core::marker::PhantomData<(Definition,)>, } -impl Default for Struct1SubformContainerHashmap1End +impl Default for Struct1SubformCollectionHashmap1End { #[ inline( always ) ] fn default() -> Self @@ -602,7 +602,7 @@ impl Default for Struct1SubformContainerHashmap1End impl< Definition, > former::FormingEnd < former::HashMapDefinitionTypes< String, String, Struct1Former< Definition >, Struct1Former< Definition > > > -for Struct1SubformContainerHashmap1End< Definition > +for Struct1SubformCollectionHashmap1End< Definition > where Definition : former::FormerDefinition< Storage = Struct1FormerStorage >, Definition::Types : former::FormerDefinitionTypes< Storage = Struct1FormerStorage >, @@ -614,7 +614,7 @@ where let mut super_former = super_former.unwrap(); if let Some( ref mut field ) = super_former.storage.hashmap_1 { - former::ContainerAssign::assign( field, storage ); + former::CollectionAssign::assign( field, storage ); } else { @@ -624,12 +624,12 @@ where } } -pub struct Struct1SubformContainerHashset1End +pub struct Struct1SubformCollectionHashset1End { _phantom : core::marker::PhantomData<(Definition,)>, } -impl Default for Struct1SubformContainerHashset1End +impl Default for Struct1SubformCollectionHashset1End { #[ inline( always ) ] fn default() -> Self @@ -643,7 +643,7 @@ impl Default for Struct1SubformContainerHashset1End impl< Definition, > former::FormingEnd < former::HashSetDefinitionTypes< String, Struct1Former< Definition >, Struct1Former< Definition > > > -for Struct1SubformContainerHashset1End< Definition > +for Struct1SubformCollectionHashset1End< Definition > where Definition : former::FormerDefinition< Storage = Struct1FormerStorage >, Definition::Types : former::FormerDefinitionTypes< Storage = Struct1FormerStorage >, @@ -655,7 +655,7 @@ where let mut super_former = super_former.unwrap(); if let Some( ref mut field ) = super_former.storage.hashset_1 { - former::ContainerAssign::assign( field, storage ); + former::CollectionAssign::assign( field, storage ); } else { @@ -667,4 +667,4 @@ where // == end of generated -include!( "./only_test/containers_with_subformer.rs" ); +include!( "./only_test/collections_with_subformer.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container_basic_scalar.rs b/module/core/former/tests/inc/former_tests/subform_collection_basic_scalar.rs similarity index 88% rename from module/core/former/tests/inc/former_tests/subform_container_basic_scalar.rs rename to module/core/former/tests/inc/former_tests/subform_collection_basic_scalar.rs index 4b3efafb88..266e622ab8 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_basic_scalar.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_basic_scalar.rs @@ -20,4 +20,4 @@ pub struct Struct1 // == end of generated -include!( "./only_test/containers_without_subformer.rs" ); +include!( "./only_test/collections_without_subformer.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container_custom.rs b/module/core/former/tests/inc/former_tests/subform_collection_custom.rs similarity index 92% rename from module/core/former/tests/inc/former_tests/subform_container_custom.rs rename to module/core/former/tests/inc/former_tests/subform_collection_custom.rs index 58f3a72356..9c42715133 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_custom.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_custom.rs @@ -4,9 +4,9 @@ use super::*; use collection_tools::HashSet; -// == define custom containers +// == define custom collections -// Custom container that logs additions +// Custom collection that logs additions #[ derive( Debug, PartialEq ) ] pub struct LoggingSet< K > where @@ -57,7 +57,7 @@ where } } -impl< K > former::Container for LoggingSet< K > +impl< K > former::Collection for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -72,7 +72,7 @@ where } -impl< K > former::ContainerAdd for LoggingSet< K > +impl< K > former::CollectionAdd for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -85,7 +85,7 @@ where } -impl< K > former::ContainerAssign for LoggingSet< K > +impl< K > former::CollectionAssign for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -99,7 +99,7 @@ where } } -impl< K > former::ContainerValToEntry< K > for LoggingSet< K > +impl< K > former::CollectionValToEntry< K > for LoggingSet< K > where K : core::cmp::Eq + core::hash::Hash, { @@ -230,15 +230,15 @@ where // = subformer pub type LoggingSetAsSubformer< K, Context, Formed, End > = -former::ContainerFormer::< K, LoggingSetDefinition< K, Context, Formed, End > >; +former::CollectionFormer::< K, LoggingSetDefinition< K, Context, Formed, End > >; -// == use custom container +// == use custom collection /// Parent required for the template. #[ derive( Debug, Default, PartialEq, the_module::Former ) ] pub struct Parent { - #[ container ] + #[ subform_collection ] children : LoggingSet< i32 >, } diff --git a/module/core/former/tests/inc/former_tests/subform_container_implicit.rs b/module/core/former/tests/inc/former_tests/subform_collection_implicit.rs similarity index 78% rename from module/core/former/tests/inc/former_tests/subform_container_implicit.rs rename to module/core/former/tests/inc/former_tests/subform_collection_implicit.rs index 55b91e69de..d33101c283 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_implicit.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_implicit.rs @@ -17,8 +17,8 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - // #[ container( definition = former::VectorDefinition ) ] - #[ container ] + // #[ subform_collection( definition = former::VectorDefinition ) ] + #[ subform_collection ] children : Vec< Child >, } @@ -26,4 +26,4 @@ pub struct Parent // == end of generated -include!( "./only_test/subformer_container.rs" ); +include!( "./only_test/subformer_collection.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container_manual.rs b/module/core/former/tests/inc/former_tests/subform_collection_manual.rs similarity index 59% rename from module/core/former/tests/inc/former_tests/subform_container_manual.rs rename to module/core/former/tests/inc/former_tests/subform_collection_manual.rs index 26a753abe6..6540adf77b 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_manual.rs @@ -16,12 +16,12 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - // #[ container( definition = former::VectorDefinition ) ] + // #[ subform_collection( definition = former::VectorDefinition ) ] #[ scalar( setter = false ) ] children : Vec< Child >, } -// == begin of generated for Parent in context of attribute container( former::VectorDefinition ) ] +// == begin of generated for Parent in context of attribute collection( former::VectorDefinition ) ] #[ automatically_derived ] impl< Definition, > ParentFormer< Definition, > @@ -30,34 +30,34 @@ where { #[ inline( always ) ] - pub fn _children_subform_container< Former2 >( self ) -> Former2 + pub fn _children_subform_collection< Former2 >( self ) -> Former2 where - Former2 : former::FormerBegin< former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > >, + Former2 : former::FormerBegin< former::VectorDefinition< Child, Self, Self, ParentSubformCollectionChildrenEnd< Definition >, > >, { - Former2::former_begin( None, Some( self ), ParentSubformContainerChildrenEnd::< Definition >::default() ) + Former2::former_begin( None, Some( self ), ParentSubformCollectionChildrenEnd::< Definition >::default() ) } #[ inline( always ) ] - pub fn children( self ) -> former::ContainerFormer:: + pub fn children( self ) -> former::CollectionFormer:: < Child, - former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > + former::VectorDefinition< Child, Self, Self, ParentSubformCollectionChildrenEnd< Definition >, > > { - self._children_subform_container::< former::ContainerFormer::< Child, former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > > >() + self._children_subform_collection::< former::CollectionFormer::< Child, former::VectorDefinition< Child, Self, Self, ParentSubformCollectionChildrenEnd< Definition >, > > >() } } // -#[ doc = r"Callback to return original former after forming of container for `vec_1` is done. Callback replace content of container assigning new content from subformer's storage." ] -pub struct ParentSubformContainerChildrenEnd< Definition > +#[ doc = r"Callback to return original former after forming of collection for `vec_1` is done. Callback replace content of collection assigning new content from subformer's storage." ] +pub struct ParentSubformCollectionChildrenEnd< Definition > { _phantom : core::marker::PhantomData< ( Definition, ) >, } -impl< Definition > Default for ParentSubformContainerChildrenEnd< Definition > +impl< Definition > Default for ParentSubformCollectionChildrenEnd< Definition > { #[ inline( always ) ] @@ -78,7 +78,7 @@ impl< Definition, > former::FormingEnd Vec< Child > as former::EntityToDefinitionTypes< ParentFormer< Definition, >, ParentFormer< Definition, > > >::Types > -for ParentSubformContainerChildrenEnd< Definition > +for ParentSubformCollectionChildrenEnd< Definition > where Definition : former::FormerDefinition< Storage = ParentFormerStorage< > >, { @@ -94,7 +94,7 @@ where let mut super_former = super_former.unwrap(); if let Some( ref mut field ) = super_former.storage.children { - former::ContainerAssign::assign( field, storage ); + former::CollectionAssign::assign( field, storage ); } else { @@ -104,6 +104,6 @@ where } } -// == end of generated for Parent in context of attribute container( former::VectorDefinition ) ] +// == end of generated for Parent in context of attribute collection( former::VectorDefinition ) ] -include!( "./only_test/subformer_container.rs" ); +include!( "./only_test/subformer_collection.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container_named.rs b/module/core/former/tests/inc/former_tests/subform_collection_named.rs similarity index 86% rename from module/core/former/tests/inc/former_tests/subform_container_named.rs rename to module/core/former/tests/inc/former_tests/subform_collection_named.rs index 75ce8845b6..77c953de0f 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_named.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_named.rs @@ -16,7 +16,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ container( name = children2 ) ] + #[ subform_collection( name = children2 ) ] children : Vec< Child >, } @@ -29,7 +29,7 @@ where pub fn children( self ) -> &'static str { r#" - Scalar setter `children` should not be generated by default if container is used. + Scalar setter `children` should not be generated by default if collection is used. It can only be generated if req "# } @@ -40,4 +40,4 @@ where // == end of generated -include!( "./only_test/subformer_container_children2.rs" ); +include!( "./only_test/subformer_collection_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container_playground.rs b/module/core/former/tests/inc/former_tests/subform_collection_playground.rs similarity index 91% rename from module/core/former/tests/inc/former_tests/subform_container_playground.rs rename to module/core/former/tests/inc/former_tests/subform_collection_playground.rs index e6fc082da0..b4ae8e5828 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_playground.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_playground.rs @@ -55,7 +55,7 @@ where { pub name : String, pub subject : String, - #[ container( definition = former::HashMapDefinition ) ] + #[ subform_collection( definition = former::HashMapDefinition ) ] pub properties : collection_tools::HashMap< K, Property< K > >, } @@ -67,7 +67,7 @@ where Definition::Storage : former::StoragePreform, { - /// Inserts a key-value pair into the map. Make a new container if it was not made so far. + /// Inserts a key-value pair into the map. Make a new collection if it was not made so far. #[ inline( always ) ] pub fn property< Name, Description, Code > ( mut self, name : Name, description : Description, code : Code ) -> Self @@ -103,7 +103,7 @@ where K : core::hash::Hash + std::cmp::Eq, { pub parameter1 : String, - #[ container( definition = former::HashMapDefinition ) ] + #[ subform_collection( definition = former::HashMapDefinition ) ] pub commands : collection_tools::HashMap< String, Child< K > >, } diff --git a/module/core/former/tests/inc/former_tests/subform_container_setter_off.rs b/module/core/former/tests/inc/former_tests/subform_collection_setter_off.rs similarity index 75% rename from module/core/former/tests/inc/former_tests/subform_container_setter_off.rs rename to module/core/former/tests/inc/former_tests/subform_collection_setter_off.rs index e0e394c192..e6aa9dc5d4 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_setter_off.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_setter_off.rs @@ -17,7 +17,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ container( setter = false ) ] + #[ subform_collection( setter = false ) ] // #[ scalar( setter = false ) ] children : Vec< Child >, } @@ -31,21 +31,21 @@ where pub fn children( self ) -> &'static str { r#" - Scalar setter `children` should not be generated by default if container is used. + Scalar setter `children` should not be generated by default if collection is used. It can only be generated if req "# } #[ inline( always ) ] - pub fn children2( self ) -> former::ContainerFormer:: + pub fn children2( self ) -> former::CollectionFormer:: < Child, - former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > + former::VectorDefinition< Child, Self, Self, ParentSubformCollectionChildrenEnd< Definition >, > > { - self._children_subform_container::< _ >() + self._children_subform_collection::< _ >() } } -include!( "./only_test/subformer_container_children2.rs" ); +include!( "./only_test/subformer_collection_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_container_setter_on.rs b/module/core/former/tests/inc/former_tests/subform_collection_setter_on.rs similarity index 69% rename from module/core/former/tests/inc/former_tests/subform_container_setter_on.rs rename to module/core/former/tests/inc/former_tests/subform_collection_setter_on.rs index afe39b4a84..1afb93908c 100644 --- a/module/core/former/tests/inc/former_tests/subform_container_setter_on.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_setter_on.rs @@ -17,9 +17,9 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - // Such parameters switch off generation of front-end container setter and switch on scalar setter. + // Such parameters switch off generation of front-end collection setter and switch on scalar setter. // Without explicit scalar_setter( true ) scalar setter is not generated. - #[ subform( setter = false ) ] + #[ subform_entry( setter = false ) ] #[ scalar( setter = true ) ] children : Vec< Child >, } @@ -30,16 +30,16 @@ where { #[ inline( always ) ] - pub fn children2( self ) -> former::ContainerFormer:: + pub fn children2( self ) -> former::CollectionFormer:: < Child, - former::VectorDefinition< Child, Self, Self, ParentSubformContainerChildrenEnd< Definition >, > + former::VectorDefinition< Child, Self, Self, ParentSubformCollectionChildrenEnd< Definition >, > > { - self._children_subform_container::< _ >() + self._children_subform_collection::< _ >() } } include!( "./only_test/subformer_scalar_children.rs" ); -include!( "./only_test/subformer_container_children2.rs" ); +include!( "./only_test/subformer_collection_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry.rs b/module/core/former/tests/inc/former_tests/subform_entry.rs index f049627d96..417762626e 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry.rs @@ -17,7 +17,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ subform( setter = false ) ] + #[ subform_entry( setter = false ) ] children : Vec< Child >, } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_hashmap.rs b/module/core/former/tests/inc/former_tests/subform_entry_hashmap.rs index 2c0ad7e8d7..48bcddf617 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_hashmap.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_hashmap.rs @@ -19,7 +19,7 @@ pub struct Child // #[ derive( Debug, PartialEq ) ] pub struct Parent { - #[ subform ] + #[ subform_entry ] command : HashMap< String, Child >, } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs b/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs index 2fb2f5028b..1b1dce6e63 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_hashmap_custom.rs @@ -19,7 +19,7 @@ pub struct Child // #[ derive( Debug, PartialEq ) ] pub struct Parent { - #[ subform( setter = false ) ] + #[ subform_entry( setter = false ) ] command : HashMap< String, Child >, } @@ -63,10 +63,10 @@ where } if let Some( ref mut children ) = super_former.storage.command { - former::ContainerAdd::add + former::CollectionAdd::add ( children, - < < HashMap< String, Child > as former::Container >::Val as former::ValToEntry< HashMap< String, Child > > > + < < HashMap< String, Child > as former::Collection >::Val as former::ValToEntry< HashMap< String, Child > > > ::val_to_entry( former::StoragePreform::preform( substorage ) ) ); } @@ -97,12 +97,12 @@ where super_former.storage.command = Some( Default::default() ); } - // add instance to the container + // add instance to the collection super_former.storage.command.as_mut().unwrap() .entry( preformed.name.clone() ) .or_insert( preformed.clone() ); - // custom logic to add two instances to the container + // custom logic to add two instances to the collection super_former.storage.command.as_mut().unwrap() .entry( format!( "{}_2", preformed.name ) ) .or_insert( preformed.clone() ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry_manual.rs b/module/core/former/tests/inc/former_tests/subform_entry_manual.rs index f8c9bcac63..013b0b12b7 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_manual.rs @@ -15,8 +15,8 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - // #[ container( definition = former::VectorDefinition ) ] - // #[ subform ] + // #[ subform_collection( definition = former::VectorDefinition ) ] + // #[ subform_entry ] #[ scalar( setter = false ) ] children : Vec< Child >, } @@ -62,10 +62,10 @@ where } if let Some( ref mut children ) = super_former.storage.children { - former::ContainerAdd::add + former::CollectionAdd::add ( children, - < < Vec< Child > as former::Container >::Val as former::ValToEntry< Vec< Child > > > + < < Vec< Child > as former::Collection >::Val as former::ValToEntry< Vec< Child > > > ::val_to_entry( former::StoragePreform::preform( substorage ) ) ); } @@ -95,17 +95,17 @@ where // it is generated #[ inline( always ) ] pub fn _child( self ) -> - < < Vec< Child > as former::Container >::Entry as former::EntityToFormer + < < Vec< Child > as former::Collection >::Entry as former::EntityToFormer < // ChildFormerDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > >, < - < Vec< Child > as former::Container >::Entry as former::EntityToDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > > + < Vec< Child > as former::Collection >::Entry as former::EntityToDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > > >::Definition, > >::Former { self._children_subform_entry - ::< < < Vec< Child > as former::Container >::Entry as former::EntityToFormer< _ > >::Former, _, >() + ::< < < Vec< Child > as former::Collection >::Entry as former::EntityToFormer< _ > >::Former, _, >() } } @@ -143,7 +143,7 @@ where } -/// Handles the completion of and element of subformer's container. +/// Handles the completion of and element of subformer's collection. pub struct ParentSubformEntryChildrenEnd< Definition > { _phantom : core::marker::PhantomData< fn( Definition ) >, @@ -171,7 +171,7 @@ where >, Types2 : former::FormerDefinitionTypes < - Storage = < < Vec< Child > as former::Container >::Entry as former::EntityToStorage >::Storage, + Storage = < < Vec< Child > as former::Collection >::Entry as former::EntityToStorage >::Storage, Formed = ParentFormer< Definition >, Context = ParentFormer< Definition >, >, @@ -192,7 +192,7 @@ where } if let Some( ref mut fields ) = super_former.storage.children { - former::ContainerAdd::add( fields, former::StoragePreform::preform( substorage ) ); + former::CollectionAdd::add( fields, former::StoragePreform::preform( substorage ) ); } super_former } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_named.rs b/module/core/former/tests/inc/former_tests/subform_entry_named.rs index 5cbe37bb68..ee49598f06 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_named.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_named.rs @@ -17,7 +17,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ subform( name = _child ) ] + #[ subform_entry( name = _child ) ] children : Vec< Child >, } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs b/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs index 1d10b20025..d4131e8834 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs @@ -17,7 +17,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ subform ] + #[ subform_entry ] // #[ scalar( setter = false ) ] children : Vec< Child >, } @@ -48,17 +48,17 @@ where #[ inline( always ) ] pub fn _child( self ) -> - < < Vec< Child > as former::Container >::Entry as former::EntityToFormer + < < Vec< Child > as former::Collection >::Entry as former::EntityToFormer < // ChildFormerDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > >, < - < Vec< Child > as former::Container >::Entry as former::EntityToDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > > + < Vec< Child > as former::Collection >::Entry as former::EntityToDefinition< Self, Self, ParentSubformEntryChildrenEnd< Definition > > >::Definition, > >::Former { self._children_subform_entry - ::< < < Vec< Child > as former::Container >::Entry as former::EntityToFormer< _ > >::Former, _, >() + ::< < < Vec< Child > as former::Collection >::Entry as former::EntityToFormer< _ > >::Former, _, >() } } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs b/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs index d615890722..fdedd4c97d 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs @@ -17,7 +17,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ subform( setter = false ) ] + #[ subform_entry( setter = false ) ] children : Vec< Child >, } diff --git a/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs b/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs index 518e7d5d4a..6eeea2827a 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs @@ -19,7 +19,7 @@ pub struct Parent { // Such parameters switch off generation of front-end subform setter and switch on scalar setter. // Without explicit scalar_setter( true ) scalar setter is not generated. - #[ subform( setter = false ) ] + #[ subform_entry( setter = false ) ] #[ scalar( setter = true ) ] children : Vec< Child >, } diff --git a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs index 3ebce7aa91..f41ab5f575 100644 --- a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs @@ -68,7 +68,7 @@ where // = end -/// Handles the completion of and element of subformer's container. +/// Handles the completion of and element of subformer's collection. pub struct ParentFormerSubformScalarChildEnd< Definition > { _phantom : core::marker::PhantomData< fn( Definition ) >, diff --git a/module/core/former/tests/inc/mod.rs b/module/core/former/tests/inc/mod.rs index 0a089aa865..9a8bc67b8c 100644 --- a/module/core/former/tests/inc/mod.rs +++ b/module/core/former/tests/inc/mod.rs @@ -16,15 +16,15 @@ mod former_tests mod a_primitives_manual; mod a_primitives; - mod subform_container_basic_scalar; + mod subform_collection_basic_scalar; #[ cfg( not( feature = "no_std" ) ) ] - mod subform_container_basic_manual; + mod subform_collection_basic_manual; #[ cfg( not( feature = "no_std" ) ) ] - mod subform_container_basic; + mod subform_collection_basic; // = attribute - mod attribute_default_container; + mod attribute_default_collection; mod attribute_default_primitive; mod attribute_default_conflict; mod attribute_storage_with_end; @@ -65,33 +65,33 @@ mod former_tests mod user_type_no_debug; mod visibility; - // = container former + // = collection former #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod container_former_common; + mod collection_former_common; #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod container_former_vec; + mod collection_former_vec; #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod container_former_hashset; + mod collection_former_hashset; #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod container_former_hashmap; + mod collection_former_hashmap; - // = subform container + // = subform collection #[ cfg( any( not( feature = "no_std" ), feature = "use_alloc" ) ) ] - mod subform_container_playground; + mod subform_collection_playground; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_container; + mod subform_collection; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_container_manual; + mod subform_collection_manual; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_container_implicit; + mod subform_collection_implicit; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_container_setter_off; + mod subform_collection_setter_off; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_container_named; + mod subform_collection_named; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_container_custom; + mod subform_collection_custom; // = subform scalar @@ -121,14 +121,14 @@ mod former_tests #[ cfg( any( not( feature = "no_std" ) ) ) ] mod subform_entry_hashmap_custom; - // = subform entry and container + // = subform all : scalar, subform_scalar, subform_entry, subform_collection #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_entry_and_container; + mod subform_all; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_entry_and_container_private; + mod subform_all_private; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_entry_and_container_parametrized; + mod subform_all_parametrized; } diff --git a/module/core/former_meta/src/derive_former.rs b/module/core/former_meta/src/derive_former.rs index b934d9cbf9..7cbfed236c 100644 --- a/module/core/former_meta/src/derive_former.rs +++ b/module/core/former_meta/src/derive_former.rs @@ -4,7 +4,7 @@ use iter_tools::{ Itertools, process_results }; use macro_tools::{ attr, diag, generic_params, generic_args, typ, derive, Result }; use proc_macro2::TokenStream; -// qqq : implement interfaces for other containers +// qqq : implement interfaces for other collections mod field; use field::*; diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index e098c10797..c2a9019804 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -35,10 +35,10 @@ storage_field_name former_field_setter scalar_setter subform_entry_setter -subform_container_setter +subform_collection_setter scalar_setter_name -container_setter_name +collection_setter_name subform_setter_name scalar_setter_required @@ -75,7 +75,7 @@ scalar_setter_required /// /// Generate fields for initializer of a struct setting each field to `None`. /// - /// Used for initializing a Container, where on initialization all fields are None. User can alter them through builder pattern + /// Used for initializing a Collection, where on initialization all fields are None. User can alter them through builder pattern /// /// ### Basic use-case. of output /// @@ -102,7 +102,7 @@ scalar_setter_required /// /// Generate field of the former for a field of the structure /// - /// Used to generate a Container + /// Used to generate a Collection /// /// ### Basic use-case. of output /// @@ -306,7 +306,7 @@ scalar_setter_required /// /// This function is responsible for dynamically creating code that allows for the building /// or modifying of fields within a `Former`-enabled struct or enum. It supports different - /// types of setters based on the field attributes, such as scalar setters, container setters, + /// types of setters based on the field attributes, such as scalar setters, collection setters, /// and subform setters. /// /// # Returns @@ -319,7 +319,7 @@ scalar_setter_required /// /// The generation of setters is dependent on the attributes of the field: /// - **Scalar Setters**: Created for basic data types and simple fields. - /// - **Container Setters**: Generated when the field is annotated to behave as a container, + /// - **Collection Setters**: Generated when the field is annotated to behave as a collection, /// supporting operations like adding or replacing elements. /// - **Subform Setters**: Generated for fields annotated as subforms, allowing for nested /// forming processes where a field itself can be formed using a dedicated former. @@ -349,10 +349,10 @@ scalar_setter_required former_storage, ); - // container setter - let ( setters_code, namespace_code ) = if let Some( _ ) = &self.attrs.container + // collection setter + let ( setters_code, namespace_code ) = if let Some( _ ) = &self.attrs.collection { - let ( setters_code2, namespace_code2 ) = self.subform_container_setter + let ( setters_code2, namespace_code2 ) = self.subform_collection_setter ( stru, former, @@ -486,12 +486,12 @@ where } /// - /// Generate a container setter for the 'field_ident' with the 'setter_name' name. + /// Generate a collection setter for the 'field_ident' with the 'setter_name' name. /// - /// See `examples/subformer_container_manual.rs` for example of generated code. + /// See `examples/subformer_collection_manual.rs` for example of generated code. #[ inline ] - pub fn subform_container_setter + pub fn subform_collection_setter ( &self, stru : &syn::Ident, @@ -504,16 +504,16 @@ where ) -> Result< ( TokenStream, TokenStream ) > { - let attr = self.attrs.container.as_ref().unwrap(); + let attr = self.attrs.collection.as_ref().unwrap(); let field_ident = &self.ident; let field_typ = &self.non_optional_ty; let params = typ::type_parameters( &field_typ, .. ); use convert_case::{ Case, Casing }; - let subform_container_end_name = format!( "{}SubformContainer{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); - let subform_container_end = syn::Ident::new( &subform_container_end_name, field_ident.span() ); - let subform_container_name = format!( "_{}_subform_container", field_ident ); - let subform_container = syn::Ident::new( &subform_container_name, field_ident.span() ); + let subform_collection_end_name = format!( "{}SubformCollection{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); + let subform_collection_end = syn::Ident::new( &subform_collection_end_name, field_ident.span() ); + let subform_collection_name = format!( "_{}_subform_collection", field_ident ); + let subform_collection = syn::Ident::new( &subform_collection_name, field_ident.span() ); // example : `former::VectorDefinition` let subformer_definition = &attr.definition; @@ -526,27 +526,27 @@ where #( #params, )* Self, Self, - #subform_container_end< Definition >, + #subform_collection_end< Definition >, > } - // former::VectorDefinition< String, Self, Self, Struct1SubformContainerVec1End, > + // former::VectorDefinition< String, Self, Self, Struct1SubformCollectionVec1End, > } else { qt! { < - #field_typ as former::EntityToDefinition< Self, Self, #subform_container_end< Definition > > + #field_typ as former::EntityToDefinition< Self, Self, #subform_collection_end< Definition > > >::Definition } - // < Vec< String > as former::EntityToDefinition< Self, Self, Struct1SubformContainerVec1End > >::Definition + // < Vec< String > as former::EntityToDefinition< Self, Self, Struct1SubformCollectionVec1End > >::Definition }; let doc = format! ( - "Container setter for the '{}' field. Method {} unlike method {} accept custom container subformer.", + "Collection setter for the '{}' field. Method {} unlike method {} accept custom collection subformer.", field_ident, - subform_container_name, + subform_collection_name, field_ident, ); @@ -556,7 +556,7 @@ where #[ doc = #doc ] #[ inline( always ) ] - pub fn #subform_container< Former2 >( self ) -> Former2 + pub fn #subform_collection< Former2 >( self ) -> Former2 where Former2 : former::FormerBegin < @@ -564,13 +564,13 @@ where >, #subformer_definition : former::FormerDefinition < - // Storage : former::ContainerAdd< Entry = < #field_typ as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < #field_typ as former::Collection >::Entry >, Storage = #field_typ, Context = #former< #former_generics_ty >, - End = #subform_container_end< Definition >, + End = #subform_collection_end< Definition >, >, { - Former2::former_begin( None, Some( self ), #subform_container_end::< Definition >::default() ) + Former2::former_begin( None, Some( self ), #subform_collection_end::< Definition >::default() ) } // #[ inline( always ) ] @@ -578,21 +578,21 @@ where // where // Former2 : former::FormerBegin // < - // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, + // former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > >, // >, - // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > > : former::FormerDefinition + // former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > > : former::FormerDefinition // < - // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < collection_tools::HashSet< String > as former::Collection >::Entry >, // Context = Struct1Former< Definition >, - // End = Struct1SubformContainerHashset1End< Definition >, + // End = Struct1SubformCollectionHashset1End< Definition >, // >, // { - // Former2::former_begin( None, Some( self ), Struct1SubformContainerHashset1End::< Definition >::default() ) + // Former2::former_begin( None, Some( self ), Struct1SubformCollectionHashset1End::< Definition >::default() ) // } }; - let setter_name = self.container_setter_name(); + let setter_name = self.collection_setter_name(); let setter2 = if let Some( setter_name ) = setter_name { qt! @@ -600,22 +600,22 @@ where #[ doc = #doc ] #[ inline( always ) ] - pub fn #setter_name( self ) -> former::ContainerFormer:: + pub fn #setter_name( self ) -> former::CollectionFormer:: < // ( #( #params, )* ), - < #field_typ as former::Container >::Entry, + < #field_typ as former::Collection >::Entry, #subformer_definition, > where #subformer_definition : former::FormerDefinition < - // Storage : former::ContainerAdd< Entry = < #field_typ as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < #field_typ as former::Collection >::Entry >, Storage = #field_typ, Context = #former< #former_generics_ty >, - End = #subform_container_end < Definition >, + End = #subform_collection_end < Definition >, >, { - self.#subform_container::< former::ContainerFormer:: + self.#subform_collection::< former::CollectionFormer:: < _, _, @@ -625,23 +625,23 @@ where } // #[ inline( always ) ] - // pub fn hashset_1( self ) -> former::ContainerFormer:: + // pub fn hashset_1( self ) -> former::CollectionFormer:: // < // String, - // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, + // former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > >, // > // where - // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > > : former::FormerDefinition + // former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > > : former::FormerDefinition // < - // Storage : former::ContainerAdd< Entry = < collection_tools::HashSet< String > as former::Container >::Entry >, + // Storage : former::CollectionAdd< Entry = < collection_tools::HashSet< String > as former::Collection >::Entry >, // Context = Struct1Former< Definition >, - // End = Struct1SubformContainerHashset1End< Definition >, + // End = Struct1SubformCollectionHashset1End< Definition >, // >, // { - // self._hashset_1_assign::< former::ContainerFormer:: + // self._hashset_1_assign::< former::CollectionFormer:: // < // String, - // former::HashSetDefinition< String, Self, Self, Struct1SubformContainerHashset1End< Definition > >, + // former::HashSetDefinition< String, Self, Self, Struct1SubformCollectionHashset1End< Definition > >, // > > () // } @@ -658,7 +658,7 @@ where ( r#" -/// The containr setter provides a container setter that returns a ContainerFormer tailored for managing a collection of child entities. It employs a generic container definition to facilitate operations on the entire collection, such as adding or updating elements. +/// The collection setter provides a collection setter that returns a CollectionFormer tailored for managing a collection of child entities. It employs a generic collection definition to facilitate operations on the entire collection, such as adding or updating elements. impl< Definition, > {}< Definition, > where @@ -666,11 +666,11 @@ where {{ #[ inline( always ) ] - pub fn {}( self ) -> former::ContainerFormer:: + pub fn {}( self ) -> former::CollectionFormer:: < ( {} ), former::HashMapDefinition< {} Self, Self, {}< Definition >, > - // Replace `HashMapDefinition` with definition for your container + // Replace `HashMapDefinition` with definition for your collection > {{ self.{}() @@ -684,8 +684,8 @@ where field_ident, format!( "{}", qt!{ #( #params, )* } ), format!( "{}", qt!{ #( #params, )* } ), - subform_container_end, - subform_container, + subform_collection_end, + subform_collection, ); let about = format! ( @@ -703,12 +703,12 @@ field : {field_ident}"#, }; // example : `former::VectorDefinition`` - let subformer_definition = &self.attrs.container.as_ref().unwrap().definition; + let subformer_definition = &self.attrs.collection.as_ref().unwrap().definition; - let subform_container_end_doc = format! + let subform_collection_end_doc = format! ( r#" -A callback structure to manage the final stage of forming a `{0}` for the `{stru}` container. +A callback structure to manage the final stage of forming a `{0}` for the `{stru}` collection. This callback is used to integrate the contents of a temporary `{0}` back into the original `{stru}` former after the subforming process is completed. It replaces the existing content of the `{field_ident}` field in `{stru}` @@ -748,14 +748,14 @@ with the new content generated during the subforming process. let r = qt! { - #[ doc = #subform_container_end_doc ] - pub struct #subform_container_end< Definition > + #[ doc = #subform_collection_end_doc ] + pub struct #subform_collection_end< Definition > { _phantom : core::marker::PhantomData< ( Definition, ) >, } impl< Definition > Default - for #subform_container_end< Definition > + for #subform_collection_end< Definition > { #[ inline( always ) ] @@ -775,7 +775,7 @@ with the new content generated during the subforming process. // VectorDefinitionTypes #subformer_definition_types, > - for #subform_container_end< Definition > + for #subform_collection_end< Definition > where #former_generics_where { @@ -791,7 +791,7 @@ with the new content generated during the subforming process. let mut super_former = super_former.unwrap(); if let Some( ref mut field ) = super_former.storage.#field_ident { - former::ContainerAssign::assign( field, storage ); + former::CollectionAssign::assign( field, storage ); } else { @@ -809,11 +809,11 @@ with the new content generated during the subforming process. Ok( ( setters_code, namespace_code ) ) } - /// Generates setter functions for subforms within a container structure in a builder pattern. + /// Generates setter functions for subforms within a collection structure in a builder pattern. /// /// This function is a key component of the `former` crate's capability to dynamically create setters for manipulating - /// data within a nested container structure like a `HashMap` or a `Vec`. The setters facilitate the addition or - /// modification of entries within the container, directly from the parent former's context. + /// data within a nested collection structure like a `HashMap` or a `Vec`. The setters facilitate the addition or + /// modification of entries within the collection, directly from the parent former's context. /// /// See `examples/subformer_subform_manual.rs` for example of generated code. /// @@ -885,13 +885,13 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i Definition2 : former::FormerDefinition < End = #subform_entry_end< Definition >, - Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, + Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, Formed = Self, Context = Self, >, Definition2::Types : former::FormerDefinitionTypes < - Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, + Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, Formed = Self, Context = Self, >, @@ -926,17 +926,17 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i #[ doc = #doc ] #[ inline( always ) ] pub fn #setter_name( self ) -> - < < #field_typ as former::Container >::Val as former::EntityToFormer + < < #field_typ as former::Collection >::Val as former::EntityToFormer < < - < #field_typ as former::Container >::Val as former::EntityToDefinition< Self, Self, #subform_entry_end < Definition > > + < #field_typ as former::Collection >::Val as former::EntityToDefinition< Self, Self, #subform_entry_end < Definition > > >::Definition, > >::Former // #as_subformer< Self, impl #as_subformer_end< Self > > { self.#subform_entry - ::< < < #field_typ as former::Container >::Val as former::EntityToFormer< _ > >::Former, _, >() + ::< < < #field_typ as former::Collection >::Val as former::EntityToFormer< _ > >::Former, _, >() // ::< #former< _ >, _, >() } } @@ -992,7 +992,7 @@ where r#" Implements the `FormingEnd` trait for `{subform_entry_end}` to handle the final -stage of the forming process for a `{stru}` container that contains `{0}` elements. +stage of the forming process for a `{stru}` collection that contains `{0}` elements. This implementation is tailored to manage the transition of {field_ident} elements from a substorage temporary state into their final state within the `{stru}`'s storage. The function ensures @@ -1053,7 +1053,7 @@ formation process of the `{stru}`. >, Types2 : former::FormerDefinitionTypes < - Storage = < < #field_typ as former::Container >::Val as former::EntityToStorage >::Storage, + Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, Formed = #former< #former_generics_ty >, Context = #former< #former_generics_ty >, >, @@ -1075,10 +1075,10 @@ formation process of the `{stru}`. } if let Some( ref mut field ) = super_former.storage.#field_ident { - former::ContainerAdd::add + former::CollectionAdd::add ( field, - < < #field_typ as former::Container >::Val as former::ValToEntry< #field_typ > > + < < #field_typ as former::Collection >::Val as former::ValToEntry< #field_typ > > ::val_to_entry( former::StoragePreform::preform( substorage ) ), ); } @@ -1105,11 +1105,11 @@ formation process of the `{stru}`. return &self.ident; } - /// Get name of setter for container if such setter should be generated. - pub fn container_setter_name( &self ) -> Option< &syn::Ident > + /// Get name of setter for collection if such setter should be generated. + pub fn collection_setter_name( &self ) -> Option< &syn::Ident > { - if let Some( ref attr ) = self.attrs.container + if let Some( ref attr ) = self.attrs.collection { if attr.setter() { @@ -1149,7 +1149,7 @@ formation process of the `{stru}`. return None; } - /// Is scalar setter required. Does not if container of subformer setter requested. + /// Is scalar setter required. Does not if collection of subformer setter requested. pub fn scalar_setter_required( &self ) -> bool { @@ -1170,7 +1170,7 @@ formation process of the `{stru}`. } } - if self.attrs.container.is_some() && !explicit + if self.attrs.collection.is_some() && !explicit { return false; } diff --git a/module/core/former_meta/src/derive_former/field_attrs.rs b/module/core/former_meta/src/derive_former/field_attrs.rs index 0b26c138ec..4feb9c2f2c 100644 --- a/module/core/former_meta/src/derive_former/field_attrs.rs +++ b/module/core/former_meta/src/derive_former/field_attrs.rs @@ -10,7 +10,7 @@ pub struct FieldAttributes { pub config : Option< AttributeConfig >, pub scalar : Option< AttributeScalarSetter >, - pub container : Option< AttributeContainerSetter >, + pub collection : Option< AttributeCollectionSetter >, pub subform : Option< AttributeSubformSetter >, } @@ -21,7 +21,7 @@ impl FieldAttributes { let mut config = None; let mut scalar = None; - let mut container = None; + let mut collection = None; let mut subform = None; for attr in attrs { @@ -66,22 +66,22 @@ impl FieldAttributes _ => return_syn_err!( attr, "Expects an attribute of format `#[ scalar( setter = false ) ]` or `#[ scalar( setter = false, name = my_name ) ]`. \nGot: {}", qt!{ #attr } ), } } - "container" => + "subform_collection" => { match attr.meta { syn::Meta::List( ref meta_list ) => { - container.replace( syn::parse2::< AttributeContainerSetter >( meta_list.tokens.clone() )? ); + collection.replace( syn::parse2::< AttributeCollectionSetter >( meta_list.tokens.clone() )? ); }, syn::Meta::Path( ref _path ) => { - container.replace( syn::parse2::< AttributeContainerSetter >( Default::default() )? ); + collection.replace( syn::parse2::< AttributeCollectionSetter >( Default::default() )? ); }, - _ => return_syn_err!( attr, "Expects an attribute of format `#[ container ]` or `#[ container( definition = former::VectorDefinition ) ]` if you want to use default container defition. \nGot: {}", qt!{ #attr } ), + _ => return_syn_err!( attr, "Expects an attribute of format `#[ subform_collection ]` or `#[ subform_collection( definition = former::VectorDefinition ) ]` if you want to use default collection defition. \nGot: {}", qt!{ #attr } ), } } - "subform" => + "subform_entry" => { match attr.meta { @@ -93,7 +93,7 @@ impl FieldAttributes { subform.replace( syn::parse2::< AttributeSubformSetter >( Default::default() )? ); }, - _ => return_syn_err!( attr, "Expects an attribute of format `#[ subform ]` or `#[ subform( name : child )` ], \nGot: {}", qt!{ #attr } ), + _ => return_syn_err!( attr, "Expects an attribute of format `#[ subform_entry ]` or `#[ subform_entry( name : child )` ], \nGot: {}", qt!{ #attr } ), } } _ => @@ -103,7 +103,7 @@ impl FieldAttributes } } - Ok( FieldAttributes { config, scalar, container, subform } ) + Ok( FieldAttributes { config, scalar, collection, subform } ) } } @@ -252,10 +252,10 @@ impl syn::parse::Parse for AttributeScalarSetter } } -/// Represents an attribute for configuring container setter generation. +/// Represents an attribute for configuring collection setter generation. /// /// This struct is part of a meta-programming approach to enable detailed configuration of nested structs or collections such as `Vec< E >, HashMap< K, E >` and so on. -/// It allows the customization of setter methods and the specification of the container's behavior through meta attributes. +/// It allows the customization of setter methods and the specification of the collection's behavior through meta attributes. /// /// ## Example Input /// @@ -265,20 +265,20 @@ impl syn::parse::Parse for AttributeScalarSetter /// ``` /// -pub struct AttributeContainerSetter +pub struct AttributeCollectionSetter { /// Optional identifier for naming the setter. pub name : Option< syn::Ident >, /// Controls the generation of a setter method. If false, a setter method is not generated. pub setter : Option< bool >, - /// Definition of the container former to use, e.g., `former::VectorFormer`. + /// Definition of the collection former to use, e.g., `former::VectorFormer`. pub definition : Option< syn::Type >, /// Specifies whether to provide a sketch of the subform setter as a hint. /// Defaults to `false`, which means no hint is provided unless explicitly requested. pub hint : bool, } -impl AttributeContainerSetter +impl AttributeCollectionSetter { /// Should setter be generated or not? @@ -289,7 +289,7 @@ impl AttributeContainerSetter } -impl syn::parse::Parse for AttributeContainerSetter +impl syn::parse::Parse for AttributeCollectionSetter { fn parse( input : syn::parse::ParseStream< '_ > ) -> syn::Result< Self > { @@ -328,12 +328,12 @@ impl syn::parse::Parse for AttributeContainerSetter } else { - return Err( syn::Error::new_spanned( &ident, format!( "Unexpected identifier '{}'. Expected 'name', 'setter', or 'definition'. For example: `container( name = myName, setter = true, definition = MyDefinition )`", ident ) ) ); + return Err( syn::Error::new_spanned( &ident, format!( "Unexpected identifier '{}'. Expected 'name', 'setter', or 'definition'. For example: `collection( name = myName, setter = true, definition = MyDefinition )`", ident ) ) ); } } else { - return Err( syn::Error::new( input.span(), "Expected 'name', 'setter', or 'definition' identifier. For example: `container( name = myName, setter = true, definition = MyDefinition )`" ) ); + return Err( syn::Error::new( input.span(), "Expected 'name', 'setter', or 'definition' identifier. For example: `collection( name = myName, setter = true, definition = MyDefinition )`" ) ); } // Optional comma handling diff --git a/module/core/former_meta/src/lib.rs b/module/core/former_meta/src/lib.rs index cf131eef6f..f8fbcaef86 100644 --- a/module/core/former_meta/src/lib.rs +++ b/module/core/former_meta/src/lib.rs @@ -48,7 +48,7 @@ mod derive_former; /// /// - `former`: General attribute to specify various options like defaults or inclusion in the former. /// - `scalar`: Indicates that the field is a scalar value, enabling direct assignment without the need for a sub-former. -/// - `container`: Marks the field as a container that can use specific former methods to manage its contents. +/// - `collection`: Marks the field as a collection that can use specific former methods to manage its contents. /// - `subform`: Specifies that the field should utilize a nested former, facilitating the construction of complex nested structures. /// /// # Usage Example @@ -102,7 +102,7 @@ mod derive_former; attributes ( debug, perform, storage_fields, mutator, // struct attributes - former, scalar, container, subform, // field attributes + former, scalar, subform_scalar, subform_collection, subform_entry, // field attributes ) ) ] diff --git a/module/core/program_tools/src/program.rs b/module/core/program_tools/src/program.rs index 8801bea38a..adf0201ad3 100644 --- a/module/core/program_tools/src/program.rs +++ b/module/core/program_tools/src/program.rs @@ -36,9 +36,9 @@ pub( crate ) mod private { write_path : Option< PathBuf >, read_path : Option< PathBuf >, - #[ subform( name = entry ) ] + #[ subform_entry( name = entry ) ] entries : Vec< Entry >, - #[ subform( name = source ) ] + #[ subform_entry( name = source ) ] sources : Vec< SourceFile >, cargo_file : Option< CargoFile >, } diff --git a/module/move/wca/src/ca/grammar/command.rs b/module/move/wca/src/ca/grammar/command.rs index 2f12e03921..bec5b6445c 100644 --- a/module/move/wca/src/ca/grammar/command.rs +++ b/module/move/wca/src/ca/grammar/command.rs @@ -96,7 +96,7 @@ pub( crate ) mod private /// Phrase descriptor for command. pub phrase : String, /// Command subjects hints and types. - #[ subform( setter = true ) ] + #[ subform_entry( setter = true ) ] pub subjects : Vec< ValueDescription >, /// Hints and types for command options. pub properties : HashMap< String, ValueDescription >, diff --git a/module/move/willbe/src/tool/template.rs b/module/move/willbe/src/tool/template.rs index 044f1157b9..6b7a2884c5 100644 --- a/module/move/willbe/src/tool/template.rs +++ b/module/move/willbe/src/tool/template.rs @@ -107,7 +107,7 @@ mod private #[ derive( Debug, Default, Former ) ] pub struct TemplateParameters { - #[ subform( setter = false ) ] + #[ subform_entry( setter = false ) ] descriptors : Vec< TemplateParameterDescriptor > } @@ -302,7 +302,7 @@ mod private pub struct TemplateFilesBuilder { /// Stores all file descriptors for current template. - #[ subform( setter = true ) ] + #[ subform_entry( setter = true ) ] #[ scalar( setter = false, hint = false ) ] pub files : Vec< TemplateFileDescriptor >, } From 4b6594d8767635fdc3cf0bae84fecf5a12209df8 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 18:59:46 +0300 Subject: [PATCH 13/24] former : refactor --- module/move/wca/src/ca/grammar/command.rs | 2 +- module/move/willbe/src/tool/template.rs | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/module/move/wca/src/ca/grammar/command.rs b/module/move/wca/src/ca/grammar/command.rs index bec5b6445c..a582aeee91 100644 --- a/module/move/wca/src/ca/grammar/command.rs +++ b/module/move/wca/src/ca/grammar/command.rs @@ -179,7 +179,7 @@ pub( crate ) mod private /// It returns a `ValueDescriptionFormer` which can be used to further build the super-former. pub fn subject( self ) -> ValueDescriptionAsSubformer< Self, impl ValueDescriptionAsSubformerEnd< Self > > { - self._subjects_add() + self._subjects_subform_entry() } /// Sets the name and other properties of the current property. diff --git a/module/move/willbe/src/tool/template.rs b/module/move/willbe/src/tool/template.rs index 6b7a2884c5..44f0e4bb9e 100644 --- a/module/move/willbe/src/tool/template.rs +++ b/module/move/willbe/src/tool/template.rs @@ -147,7 +147,7 @@ mod private pub fn parameter( self, name : &str ) -> TemplateParameterDescriptorAsSubformer< Self, impl TemplateParameterDescriptorAsSubformerEnd< Self > > { - self._descriptors_add::< TemplateParameterDescriptorFormer< _ >, _ >() + self._descriptors_subform_entry::< TemplateParameterDescriptorFormer< _ >, _ >() .parameter( name ) } } @@ -314,7 +314,7 @@ mod private #[ inline( always ) ] pub fn file( self ) -> TemplateFileDescriptorAsSubformer< Self, impl TemplateFileDescriptorAsSubformerEnd< Self > > { - self._files_add() + self._files_subform_entry() } } From 13f364b852f74a666ab7b913e880b7e51e64e93f Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 19:13:00 +0300 Subject: [PATCH 14/24] former : refactor --- .../former_meta/src/derive_former/field.rs | 20 +-- .../src/derive_former/field_attrs.rs | 137 ++++++++++++++++-- 2 files changed, 131 insertions(+), 26 deletions(-) diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index c2a9019804..bfbbab86a1 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -350,7 +350,7 @@ scalar_setter_required ); // collection setter - let ( setters_code, namespace_code ) = if let Some( _ ) = &self.attrs.collection + let ( setters_code, namespace_code ) = if let Some( _ ) = &self.attrs.subform_collection { let ( setters_code2, namespace_code2 ) = self.subform_collection_setter ( @@ -370,7 +370,7 @@ scalar_setter_required }; // subform setter - let ( setters_code, namespace_code ) = if self.attrs.subform.is_some() + let ( setters_code, namespace_code ) = if self.attrs.subform_entry.is_some() { let ( setters_code2, namespace_code2 ) = self.subform_entry_setter ( @@ -504,7 +504,7 @@ where ) -> Result< ( TokenStream, TokenStream ) > { - let attr = self.attrs.collection.as_ref().unwrap(); + let attr = self.attrs.subform_collection.as_ref().unwrap(); let field_ident = &self.ident; let field_typ = &self.non_optional_ty; let params = typ::type_parameters( &field_typ, .. ); @@ -703,7 +703,7 @@ field : {field_ident}"#, }; // example : `former::VectorDefinition`` - let subformer_definition = &self.attrs.collection.as_ref().unwrap().definition; + let subformer_definition = &self.attrs.subform_collection.as_ref().unwrap().definition; let subform_collection_end_doc = format! ( @@ -833,7 +833,7 @@ with the new content generated during the subforming process. -> Result< ( TokenStream, TokenStream ) > { - // if self.attrs.subform.is_none() + // if self.attrs.subform_entry.is_none() // { // return Ok( qt!{ } ); // } @@ -841,7 +841,7 @@ with the new content generated during the subforming process. use convert_case::{ Case, Casing }; let field_ident = self.ident; let field_typ = self.non_optional_ty; - let attr = self.attrs.subform.as_ref().unwrap(); + let attr = self.attrs.subform_entry.as_ref().unwrap(); // let params = typ::type_parameters( &self.non_optional_ty, .. ); // example : `child` @@ -1109,7 +1109,7 @@ formation process of the `{stru}`. pub fn collection_setter_name( &self ) -> Option< &syn::Ident > { - if let Some( ref attr ) = self.attrs.collection + if let Some( ref attr ) = self.attrs.subform_collection { if attr.setter() { @@ -1131,7 +1131,7 @@ formation process of the `{stru}`. pub fn subform_setter_name( &self ) -> Option< &syn::Ident > { - if let Some( ref attr ) = self.attrs.subform + if let Some( ref attr ) = self.attrs.subform_entry { if attr.setter() { @@ -1170,12 +1170,12 @@ formation process of the `{stru}`. } } - if self.attrs.collection.is_some() && !explicit + if self.attrs.subform_collection.is_some() && !explicit { return false; } - if self.attrs.subform.is_some() && !explicit + if self.attrs.subform_entry.is_some() && !explicit { return false; } diff --git a/module/core/former_meta/src/derive_former/field_attrs.rs b/module/core/former_meta/src/derive_former/field_attrs.rs index 4feb9c2f2c..137f84249e 100644 --- a/module/core/former_meta/src/derive_former/field_attrs.rs +++ b/module/core/former_meta/src/derive_former/field_attrs.rs @@ -10,8 +10,9 @@ pub struct FieldAttributes { pub config : Option< AttributeConfig >, pub scalar : Option< AttributeScalarSetter >, - pub collection : Option< AttributeCollectionSetter >, - pub subform : Option< AttributeSubformSetter >, + pub subform_scalar : Option< AttributeSubformScalarSetter >, + pub subform_collection : Option< AttributeSubformCollectionSetter >, + pub subform_entry : Option< AttributeSubformEntrySetter >, } impl FieldAttributes @@ -21,8 +22,9 @@ impl FieldAttributes { let mut config = None; let mut scalar = None; - let mut collection = None; - let mut subform = None; + let mut subform_scalar = None; + let mut subform_collection = None; + let mut subform_entry = None; for attr in attrs { let key_ident = attr.path().get_ident() @@ -53,6 +55,7 @@ impl FieldAttributes } "scalar" => { + // qqq : move this part of parsing into attribute. do that for all attributes match attr.meta { syn::Meta::List( ref meta_list ) => @@ -63,7 +66,22 @@ impl FieldAttributes { scalar.replace( syn::parse2::< AttributeScalarSetter >( Default::default() )? ); }, - _ => return_syn_err!( attr, "Expects an attribute of format `#[ scalar( setter = false ) ]` or `#[ scalar( setter = false, name = my_name ) ]`. \nGot: {}", qt!{ #attr } ), + _ => return_syn_err!( attr, "Expects an attribute of format `#[ scalar( setter = false ) ]` or `#[ scalar( setter = true, name = my_name ) ]`. \nGot: {}", qt!{ #attr } ), + } + } + "subform_scalar" => + { + match attr.meta + { + syn::Meta::List( ref meta_list ) => + { + subform_scalar.replace( syn::parse2::< AttributeSubformScalarSetter >( meta_list.tokens.clone() )? ); + }, + syn::Meta::Path( ref _path ) => + { + subform_scalar.replace( syn::parse2::< AttributeSubformScalarSetter >( Default::default() )? ); + }, + _ => return_syn_err!( attr, "Expects an attribute of format `#[ subform_scalar( setter = false ) ]` or `#[ subform_scalar( setter = true, name = my_name ) ]`. \nGot: {}", qt!{ #attr } ), } } "subform_collection" => @@ -72,11 +90,11 @@ impl FieldAttributes { syn::Meta::List( ref meta_list ) => { - collection.replace( syn::parse2::< AttributeCollectionSetter >( meta_list.tokens.clone() )? ); + subform_collection.replace( syn::parse2::< AttributeSubformCollectionSetter >( meta_list.tokens.clone() )? ); }, syn::Meta::Path( ref _path ) => { - collection.replace( syn::parse2::< AttributeCollectionSetter >( Default::default() )? ); + subform_collection.replace( syn::parse2::< AttributeSubformCollectionSetter >( Default::default() )? ); }, _ => return_syn_err!( attr, "Expects an attribute of format `#[ subform_collection ]` or `#[ subform_collection( definition = former::VectorDefinition ) ]` if you want to use default collection defition. \nGot: {}", qt!{ #attr } ), } @@ -87,11 +105,11 @@ impl FieldAttributes { syn::Meta::List( ref meta_list ) => { - subform.replace( syn::parse2::< AttributeSubformSetter >( meta_list.tokens.clone() )? ); + subform_entry.replace( syn::parse2::< AttributeSubformEntrySetter >( meta_list.tokens.clone() )? ); }, syn::Meta::Path( ref _path ) => { - subform.replace( syn::parse2::< AttributeSubformSetter >( Default::default() )? ); + subform_entry.replace( syn::parse2::< AttributeSubformEntrySetter >( Default::default() )? ); }, _ => return_syn_err!( attr, "Expects an attribute of format `#[ subform_entry ]` or `#[ subform_entry( name : child )` ], \nGot: {}", qt!{ #attr } ), } @@ -103,7 +121,7 @@ impl FieldAttributes } } - Ok( FieldAttributes { config, scalar, collection, subform } ) + Ok( FieldAttributes { config, scalar, subform_scalar, subform_collection, subform_entry } ) } } @@ -252,6 +270,93 @@ impl syn::parse::Parse for AttributeScalarSetter } } +/// +/// Attribute to enable/disable scalar setter generation. +/// +/// ## Example Input +/// +/// A typical input to parse might look like the following: +/// +/// ```ignore +/// name = field_name, setter = true +/// ``` +/// + +pub struct AttributeSubformScalarSetter +{ + /// Optional identifier for naming the setter. + pub name : Option< syn::Ident >, + /// Controls the generation of a setter method. If false, a setter method is not generated. + pub setter : Option< bool >, + /// Specifies whether to provide a sketch of the subform setter as a hint. + /// Defaults to `false`, which means no hint is provided unless explicitly requested. + pub hint : bool, +} + +#[ allow( dead_code ) ] +impl AttributeSubformScalarSetter +{ + + /// Should setter be generated or not? + pub fn setter( &self ) -> bool + { + self.setter.is_none() || self.setter.unwrap() + } + +} + +impl syn::parse::Parse for AttributeSubformScalarSetter +{ + fn parse( input : syn::parse::ParseStream< '_ > ) -> syn::Result< Self > + { + let mut name : Option< syn::Ident > = None; + let mut setter : Option< bool > = None; + let mut hint = false; + + while !input.is_empty() + { + let lookahead = input.lookahead1(); + if lookahead.peek( syn::Ident ) + { + let ident : syn::Ident = input.parse()?; + if ident == "name" + { + input.parse::< syn::Token![ = ] >()?; + name = Some( input.parse()? ); + } + else if ident == "setter" + { + input.parse::< syn::Token![ = ] >()?; + let value : syn::LitBool = input.parse()?; + setter = Some( value.value() ); + } + else if ident == "hint" + { + input.parse::< syn::Token![ = ] >()?; + let value : syn::LitBool = input.parse()?; + hint = value.value; + } + else + { + return Err( syn::Error::new_spanned( &ident, format!( "Unexpected identifier '{}'. Expected 'name', 'setter', or 'definition'. For example: `subform_scalar( name = myName, setter = true )`", ident ) ) ); + } + } + else + { + return Err( syn::Error::new( input.span(), "Expected 'name', 'setter', or 'definition' identifier. For example: `subform_scalar( name = myName, setter = true )`" ) ); + } + + // Optional comma handling + if input.peek( syn::Token![,] ) + { + input.parse::< syn::Token![,] >()?; + } + } + + Ok( Self { name, setter, hint } ) + } +} + /// Represents an attribute for configuring collection setter generation. /// /// This struct is part of a meta-programming approach to enable detailed configuration of nested structs or collections such as `Vec< E >, HashMap< K, E >` and so on. @@ -265,7 +370,7 @@ impl syn::parse::Parse for AttributeScalarSetter /// ``` /// -pub struct AttributeCollectionSetter +pub struct AttributeSubformCollectionSetter { /// Optional identifier for naming the setter. pub name : Option< syn::Ident >, @@ -278,7 +383,7 @@ pub struct AttributeCollectionSetter pub hint : bool, } -impl AttributeCollectionSetter +impl AttributeSubformCollectionSetter { /// Should setter be generated or not? @@ -289,7 +394,7 @@ impl AttributeCollectionSetter } -impl syn::parse::Parse for AttributeCollectionSetter +impl syn::parse::Parse for AttributeSubformCollectionSetter { fn parse( input : syn::parse::ParseStream< '_ > ) -> syn::Result< Self > { @@ -365,7 +470,7 @@ impl syn::parse::Parse for AttributeCollectionSetter /// mame = field_name /// ``` -pub struct AttributeSubformSetter +pub struct AttributeSubformEntrySetter { /// An optional identifier that names the setter. It is parsed from inputs /// like `name = my_field`. @@ -378,7 +483,7 @@ pub struct AttributeSubformSetter pub hint : bool, } -impl AttributeSubformSetter +impl AttributeSubformEntrySetter { /// Should setter be generated or not? @@ -389,7 +494,7 @@ impl AttributeSubformSetter } -impl syn::parse::Parse for AttributeSubformSetter +impl syn::parse::Parse for AttributeSubformEntrySetter { fn parse( input : syn::parse::ParseStream< '_ > ) -> syn::Result< Self > { From bb7f86882c9e88d51c3cf5439e6a7350cf192a0a Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 19:26:08 +0300 Subject: [PATCH 15/24] former : introducing subform_scalar --- .../former_meta/src/derive_former/field.rs | 334 ++++++++++++++++-- 1 file changed, 314 insertions(+), 20 deletions(-) diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index bfbbab86a1..2d13d9d8d9 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -38,8 +38,9 @@ subform_entry_setter subform_collection_setter scalar_setter_name -collection_setter_name -subform_setter_name +subform_scalar_setter_name, +subform_collection_setter_name +subform_entry_setter_name scalar_setter_required */ @@ -457,6 +458,7 @@ where field_ident, ); println!( "{hint}" ); + // xxx : use diag::report_print } if !self.scalar_setter_required() @@ -488,7 +490,8 @@ where /// /// Generate a collection setter for the 'field_ident' with the 'setter_name' name. /// - /// See `examples/subformer_collection_manual.rs` for example of generated code. + /// See `tests/inc/former_tests/subform_collection_manual.rs` for example of generated code. + /// #[ inline ] pub fn subform_collection_setter @@ -592,7 +595,7 @@ where }; - let setter_name = self.collection_setter_name(); + let setter_name = self.subform_collection_setter_name(); let setter2 = if let Some( setter_name ) = setter_name { qt! @@ -809,13 +812,13 @@ with the new content generated during the subforming process. Ok( ( setters_code, namespace_code ) ) } - /// Generates setter functions for subforms within a collection structure in a builder pattern. + /// Generates setter functions to subform entries of a collection. /// /// This function is a key component of the `former` crate's capability to dynamically create setters for manipulating /// data within a nested collection structure like a `HashMap` or a `Vec`. The setters facilitate the addition or /// modification of entries within the collection, directly from the parent former's context. /// - /// See `examples/subformer_subform_manual.rs` for example of generated code. + /// See `tests/inc/former_tests/subform_entry_manual.rs` for example of generated code. /// #[ inline ] @@ -833,25 +836,20 @@ with the new content generated during the subforming process. -> Result< ( TokenStream, TokenStream ) > { - // if self.attrs.subform_entry.is_none() - // { - // return Ok( qt!{ } ); - // } - use convert_case::{ Case, Casing }; let field_ident = self.ident; let field_typ = self.non_optional_ty; let attr = self.attrs.subform_entry.as_ref().unwrap(); // let params = typ::type_parameters( &self.non_optional_ty, .. ); - // example : `child` - let setter_name = self.subform_setter_name(); + // example : `children` + let setter_name = self.subform_entry_setter_name(); // example : `ParentSubformEntryChildrenEnd`` let subform_entry_end_name = format!( "{}SubformEntry{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); let subform_entry_end = syn::Ident::new( &subform_entry_end_name, field_ident.span() ); - // example : `_children_former` + // example : `_children_subform_entry` let subform_entry_name = format!( "_{}_subform_entry", field_ident ); let subform_entry = syn::Ident::new( &subform_entry_name, field_ident.span() ); @@ -985,6 +983,7 @@ where subform_entry_name, ); println!( "{hint}" ); + // xxx : use diag::report_print } let doc = format! @@ -1092,6 +1091,285 @@ formation process of the `{stru}`. Ok( ( setters_code, namespace_code ) ) } + + /// Generates setter functions to subform entries of a collection. + /// + /// See `tests/inc/former_tests/subform_scalar_manual.rs` for example of generated code. + /// + // xxx : improve documentation + + #[ inline ] + pub fn subform_scalar_setter + ( + &self, + stru : &syn::Ident, + former : &syn::Ident, + former_storage : &syn::Ident, + former_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, + struct_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, + struct_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, + struct_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, + ) + -> Result< ( TokenStream, TokenStream ) > + { + + use convert_case::{ Case, Casing }; + let field_ident = self.ident; + let field_typ = self.non_optional_ty; + let attr = self.attrs.subform_scalar.as_ref().unwrap(); + // let params = typ::type_parameters( &self.non_optional_ty, .. ); + + // example : `children` + let setter_name = self.subform_scalar_setter_name(); + + // example : `ParentSubformScalarChildrenEnd`` + let subform_scalar_end_name = format!( "{}SubformScalar{}End", stru, field_ident.to_string().to_case( Case::Pascal ) ); + let subform_scalar_end = syn::Ident::new( &subform_scalar_end_name, field_ident.span() ); + + // example : `_children_subform_scalar` + let subform_scalar_name = format!( "_{}_subform_scalar", field_ident ); + let subform_scalar = syn::Ident::new( &subform_scalar_name, field_ident.span() ); + + let doc = format! + ( + r#" + +Initiates the addition of {field_ident} to the `{stru}` entity using a dedicated subformer. + +This method configures and returns a subformer specialized for the `{0}` entities' formation process, +which is part of the `{stru}` entity's construction. The subformer is set up with a specific end condition +handled by `{subform_scalar_end}`, ensuring that the {field_ident} are properly integrated into the +parent's structure once formed. + +# Returns + +Returns an instance of `Former2`, a subformer ready to begin the formation process for `{0}` entities, +allowing for dynamic and flexible construction of the `{stru}` entity's {field_ident}. + + "#, + format!( "{}", qt!{ #field_typ } ), + // xxx : outdated + ); + + let setters_code = qt! + { + + #[ doc = #doc ] + #[ inline( always ) ] + pub fn #subform_scalar< Former2, Definition2 >( self ) -> Former2 + where + Definition2 : former::FormerDefinition + < + End = #subform_scalar_end< Definition >, + Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, + Formed = Self, + Context = Self, + >, + Definition2::Types : former::FormerDefinitionTypes + < + Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, + Formed = Self, + Context = Self, + >, + Former2 : former::FormerBegin< Definition2 >, + { + Former2::former_begin( None, Some( self ), #subform_scalar_end::default() ) + } + + }; + + let setters_code = if attr.setter() + { + + let doc = format! + ( + r#" +Provides a user-friendly interface to add an instancce of {field_ident} to the {stru}. + +# Returns + +Returns an instance of `Former2`, a subformer ready to begin the formation process for `{0}` entities, +allowing for dynamic and flexible construction of the `{stru}` entity's {field_ident}. + + "#, + format!( "{}", qt!{ #field_typ } ), + ); + // xxx : outdated + + qt! + { + #setters_code + + #[ doc = #doc ] + #[ inline( always ) ] + pub fn #setter_name( self ) -> + < < #field_typ as former::Collection >::Val as former::EntityToFormer + < + < + < #field_typ as former::Collection >::Val as former::EntityToDefinition< Self, Self, #subform_scalar_end < Definition > > + >::Definition, + > + >::Former + { + self.#subform_scalar + ::< < < #field_typ as former::Collection >::Val as former::EntityToFormer< _ > >::Former, _, >() + // ::< #former< _ >, _, >() + } + } + + // #[ inline( always ) ] + // pub fn child( self ) -> + // ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + // { + // self._children_subform_scalar + // ::< < Child as former::EntityToFormer< _ > >::Former, _, >() + // } + + } + else + { + setters_code + }; + + if attr.hint + { + let hint = format! + ( + r#" + +/// Initializes and configures a subformer for adding named child entities. This method leverages an internal function +/// to create and return a configured subformer instance. It allows for the dynamic addition of children with specific names, +/// integrating them into the formation process of the parent entity. + +impl< Definition > {}< Definition > +where + Definition : former::FormerDefinition< Storage = {} >, +{{ + + #[ inline( always ) ] + pub fn {}( self ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + {{ + self.{}::< ChildFormer< _ >, _, >() + }} + // Replace Child with name of type of element value. + +}} + "#, + former, + former_storage, + field_ident, + subform_scalar_name, + ); + println!( "{hint}" ); + // xxx : outdated + // xxx : use diag::report_print + } + + let doc = format! + ( + r#" + +Implements the `FormingEnd` trait for `{subform_scalar_end}` to handle the final +stage of the forming process for a `{stru}` collection that contains `{0}` elements. + +This implementation is tailored to manage the transition of {field_ident} elements from a substorage +temporary state into their final state within the `{stru}`'s storage. The function ensures +that the `{stru}`'s {field_ident} storage is initialized if not already set, and then adds the +preformed elements to this storage. + +# Type Parameters + +- `Types2`: Represents the specific types associated with the `Former` trait being applied, + which include storage, formed type, and context. +- `Definition`: Defines the `FormerDefinition` that outlines the storage structure and + the end conditions for the formation process. + +# Parameters + +- `substorage`: The storage from which {field_ident} elements are preformed and retrieved. +- `super_former`: An optional context which, upon invocation, contains the `{former}` + instance being formed. + +# Returns + +Returns the updated `{former}` instance with newly added {field_ident}, completing the +formation process of the `{stru}`. + + "#, + format!( "{}", qt!{ #field_typ } ), + ); + // xxx : outdated + + let namespace_code = qt! + { + + #[ doc = #doc ] + pub struct #subform_scalar_end< Definition > + { + _phantom : core::marker::PhantomData< fn( Definition ) >, + } + + impl< Definition > Default + for #subform_scalar_end< Definition > + { + #[ inline( always ) ] + fn default() -> Self + { + Self + { + _phantom : core::marker::PhantomData, + } + } + } + + impl< #struct_generics_impl Types2, Definition > former::FormingEnd< Types2, > + for #subform_scalar_end< Definition > + where + Definition : former::FormerDefinition + < + Storage = < #stru < #struct_generics_ty > as former::EntityToStorage >::Storage, + >, + Types2 : former::FormerDefinitionTypes + < + Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, + Formed = #former< #former_generics_ty >, + Context = #former< #former_generics_ty >, + >, + #struct_generics_where + { + #[ inline( always ) ] + fn call + ( + &self, + substorage : Types2::Storage, + super_former : core::option::Option< Types2::Context >, + ) + -> Types2::Formed + { + let mut super_former = super_former.unwrap(); + if super_former.storage.#field_ident.is_none() + { + super_former.storage.#field_ident = Some( Default::default() ); + } + if let Some( ref mut field ) = super_former.storage.#field_ident + { + former::CollectionAdd::add + ( + field, + < < #field_typ as former::Collection >::Val as former::ValToEntry< #field_typ > > + ::val_to_entry( former::StoragePreform::preform( substorage ) ), + ); + } + super_former + } + } + + }; + + // tree_print!( setters_code.as_ref().unwrap() ); + Ok( ( setters_code, namespace_code ) ) + } + /// Get name of scalar setter. pub fn scalar_setter_name( &self ) -> &syn::Ident { @@ -1105,10 +1383,29 @@ formation process of the `{stru}`. return &self.ident; } - /// Get name of setter for collection if such setter should be generated. - pub fn collection_setter_name( &self ) -> Option< &syn::Ident > + /// Get name of setter for subform scalar if such setter should be generated. + pub fn subform_scalar_setter_name( &self ) -> Option< &syn::Ident > { + if let Some( ref attr ) = self.attrs.subform_scalar + { + if attr.setter() + { + if let Some( ref name ) = attr.name + { + return Some( &name ) + } + else + { + return Some( &self.ident ) + } + } + } + return None; + } + /// Get name of setter for collection if such setter should be generated. + pub fn subform_collection_setter_name( &self ) -> Option< &syn::Ident > + { if let Some( ref attr ) = self.attrs.subform_collection { if attr.setter() @@ -1123,14 +1420,12 @@ formation process of the `{stru}`. } } } - return None; } /// Get name of setter for subform if such setter should be generated. - pub fn subform_setter_name( &self ) -> Option< &syn::Ident > + pub fn subform_entry_setter_name( &self ) -> Option< &syn::Ident > { - if let Some( ref attr ) = self.attrs.subform_entry { if attr.setter() @@ -1145,7 +1440,6 @@ formation process of the `{stru}`. } } } - return None; } From 3a46150b69145db5bcb05948dcd52b74e914abf8 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 19:53:00 +0300 Subject: [PATCH 16/24] former : introducing subform_scalar --- module/core/former/Readme.md | 12 ++- .../former_custom_container_setter.rs | 14 +-- .../examples/former_custom_scalar_setter.rs | 14 +-- .../examples/former_custom_subform_setter.rs | 14 +-- .../examples/former_custom_subform_setter2.rs | 14 +-- .../tests/inc/former_tests/subform_scalar.rs | 2 +- .../inc/former_tests/subform_scalar_manual.rs | 18 +++- module/core/former/tests/inc/mod.rs | 4 +- .../former_meta/src/derive_former/field.rs | 96 ++++++++++++------- 9 files changed, 120 insertions(+), 68 deletions(-) diff --git a/module/core/former/Readme.md b/module/core/former/Readme.md index 0d5e327f77..c3e87d09a2 100644 --- a/module/core/former/Readme.md +++ b/module/core/former/Readme.md @@ -756,15 +756,17 @@ Subformers are specialized builders used within the former to construct nested o ## Types of Setters / Subformers -It's crucial to understand the differences among subform setters, collection setters, and scalar setters: +Understanding the distinctions among the types of setters or subformers is essential for effectively employing the builder pattern in object construction. Each type of setter is designed to meet specific needs in building complex, structured data entities: -- **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +- **Scalar Setter**: Handles the direct assignment of scalar values or simple fields within an entity. These setters manage basic data types or individual fields and do not involve nested formers or complex structuring. -- **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +- **Subform Collection Setter**: Facilitates the management of a collection as a whole by returning a former that provides an interface to configure the entire collection. This setter is beneficial for applying uniform configurations or validations to all elements in a collection, such as a `HashMap` of children. -- **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +- **Subform Entry Setter**: This setter allows for the individual formation of elements within a collection. It returns a former for each element, enabling detailed configuration and addition of complex elements within collections, exemplified by managing `Child` entities within a `Parent`'s `HashMap`. -Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. +- **Subform Scalar Setter**: Similar to the subform entry setter but designed for scalar fields that have a former implementation. This setter does not collect instances into a collection because there is no collection involved, only a scalar field. It is used when the scalar field itself needs to be configured or modified through its dedicated former. + +These setters ensure that developers can precisely and efficiently set properties, manage collections, and configure complex structures within their applications. ## Example : Collection Setter for a Vector diff --git a/module/core/former/examples/former_custom_container_setter.rs b/module/core/former/examples/former_custom_container_setter.rs index 756d74b330..f2d323dd27 100644 --- a/module/core/former/examples/former_custom_container_setter.rs +++ b/module/core/former/examples/former_custom_container_setter.rs @@ -5,17 +5,19 @@ //! //! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. //! -//! #### Types of Setters +//! #### Types of Setters / Subformers //! -//! It's crucial to understand the differences among subform setters, collection setters, and scalar setters: +//! Understanding the distinctions among the types of setters or subformers is essential for effectively employing the builder pattern in object construction. Each type of setter is designed to meet specific needs in building complex, structured data entities: //! -//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +//! - **Scalar Setter**: Handles the direct assignment of scalar values or simple fields within an entity. These setters manage basic data types or individual fields and do not involve nested formers or complex structuring. //! -//! - **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +//! - **Subform Collection Setter**: Facilitates the management of a collection as a whole by returning a former that provides an interface to configure the entire collection. This setter is beneficial for applying uniform configurations or validations to all elements in a collection, such as a `HashMap` of children. //! -//! - **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +//! - **Subform Entry Setter**: This setter allows for the individual formation of elements within a collection. It returns a former for each element, enabling detailed configuration and addition of complex elements within collections, exemplified by managing `Child` entities within a `Parent`'s `HashMap`. //! -//! Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. +//! - **Subform Scalar Setter**: Similar to the subform entry setter but designed for scalar fields that have a former implementation. This setter does not collect instances into a collection because there is no collection involved, only a scalar field. It is used when the scalar field itself needs to be configured or modified through its dedicated former. +//! +//! These setters ensure that developers can precisely and efficiently set properties, manage collections, and configure complex structures within their applications. //! // Ensure the example only compiles when the appropriate features are enabled. diff --git a/module/core/former/examples/former_custom_scalar_setter.rs b/module/core/former/examples/former_custom_scalar_setter.rs index 8cd2a5dcd0..bd74f8640f 100644 --- a/module/core/former/examples/former_custom_scalar_setter.rs +++ b/module/core/former/examples/former_custom_scalar_setter.rs @@ -6,17 +6,19 @@ //! //! Unlike the more complex subform and collection setters shown in previous examples, this example focuses on a straightforward approach to directly set a scalar value within a parent entity. The `Parent` struct manages a `HashMap` of `Child` entities, and the scalar setter is used to set the entire `HashMap` directly. The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. //! -//! #### Types of Setters +//! #### Types of Setters / Subformers //! -//! It's crucial to understand the differences among subform setters, collection setters, and scalar setters: +//! Understanding the distinctions among the types of setters or subformers is essential for effectively employing the builder pattern in object construction. Each type of setter is designed to meet specific needs in building complex, structured data entities: //! -//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +//! - **Scalar Setter**: Handles the direct assignment of scalar values or simple fields within an entity. These setters manage basic data types or individual fields and do not involve nested formers or complex structuring. //! -//! - **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +//! - **Subform Collection Setter**: Facilitates the management of a collection as a whole by returning a former that provides an interface to configure the entire collection. This setter is beneficial for applying uniform configurations or validations to all elements in a collection, such as a `HashMap` of children. //! -//! - **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +//! - **Subform Entry Setter**: This setter allows for the individual formation of elements within a collection. It returns a former for each element, enabling detailed configuration and addition of complex elements within collections, exemplified by managing `Child` entities within a `Parent`'s `HashMap`. //! -//! Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. +//! - **Subform Scalar Setter**: Similar to the subform entry setter but designed for scalar fields that have a former implementation. This setter does not collect instances into a collection because there is no collection involved, only a scalar field. It is used when the scalar field itself needs to be configured or modified through its dedicated former. +//! +//! These setters ensure that developers can precisely and efficiently set properties, manage collections, and configure complex structures within their applications. //! #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] diff --git a/module/core/former/examples/former_custom_subform_setter.rs b/module/core/former/examples/former_custom_subform_setter.rs index 965a9bda9a..aa759e8ffe 100644 --- a/module/core/former/examples/former_custom_subform_setter.rs +++ b/module/core/former/examples/former_custom_subform_setter.rs @@ -5,17 +5,19 @@ //! //! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. //! -//! #### Types of Setters +//! #### Types of Setters / Subformers //! -//! It's crucial to understand the differences among subform setters, collection setters, and scalar setters: +//! Understanding the distinctions among the types of setters or subformers is essential for effectively employing the builder pattern in object construction. Each type of setter is designed to meet specific needs in building complex, structured data entities: //! -//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +//! - **Scalar Setter**: Handles the direct assignment of scalar values or simple fields within an entity. These setters manage basic data types or individual fields and do not involve nested formers or complex structuring. //! -//! - **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +//! - **Subform Collection Setter**: Facilitates the management of a collection as a whole by returning a former that provides an interface to configure the entire collection. This setter is beneficial for applying uniform configurations or validations to all elements in a collection, such as a `HashMap` of children. //! -//! - **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +//! - **Subform Entry Setter**: This setter allows for the individual formation of elements within a collection. It returns a former for each element, enabling detailed configuration and addition of complex elements within collections, exemplified by managing `Child` entities within a `Parent`'s `HashMap`. //! -//! Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. +//! - **Subform Scalar Setter**: Similar to the subform entry setter but designed for scalar fields that have a former implementation. This setter does not collect instances into a collection because there is no collection involved, only a scalar field. It is used when the scalar field itself needs to be configured or modified through its dedicated former. +//! +//! These setters ensure that developers can precisely and efficiently set properties, manage collections, and configure complex structures within their applications. //! #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] diff --git a/module/core/former/examples/former_custom_subform_setter2.rs b/module/core/former/examples/former_custom_subform_setter2.rs index ab1fbfca9d..545adfe7f4 100644 --- a/module/core/former/examples/former_custom_subform_setter2.rs +++ b/module/core/former/examples/former_custom_subform_setter2.rs @@ -7,17 +7,19 @@ //! //! The `child` function within `ParentFormer` is a custom subform setter that plays a crucial role. It uniquely employs the `ChildFormer` to add and configure children by their names within the parent's builder pattern. This method demonstrates a powerful technique for integrating subformers that manage specific elements of a collection—each child entity in this case. //! -//! #### Types of Setters +//! #### Types of Setters / Subformers //! -//! It's crucial to understand the differences among subform setters, collection setters, and scalar setters: +//! Understanding the distinctions among the types of setters or subformers is essential for effectively employing the builder pattern in object construction. Each type of setter is designed to meet specific needs in building complex, structured data entities: //! -//! - **Scalar Setter**: Directly sets scalar values or simple fields within the forming entity. Unlike subform or collection setters that manage complex objects or collections, scalar setters handle basic data types or individual fields. These are typically straightforward setter methods that do not involve nested formers or additional structuring. +//! - **Scalar Setter**: Handles the direct assignment of scalar values or simple fields within an entity. These setters manage basic data types or individual fields and do not involve nested formers or complex structuring. //! -//! - **Collection Setter**: Returns a former of the collection itself, offering an interface to manage the collection as a whole rather than its individual elements. This type of setter is useful for applying configurations or validations to the entire collection, such as a `HashMap` of children. +//! - **Subform Collection Setter**: Facilitates the management of a collection as a whole by returning a former that provides an interface to configure the entire collection. This setter is beneficial for applying uniform configurations or validations to all elements in a collection, such as a `HashMap` of children. //! -//! - **Subform Setter**: Returns a former of an element within a collection, providing an interface to individually form each element. For example, the `child` method acts as a subform setter, allowing for the addition and configuration of individual `Child` entities within the `Parent`'s `HashMap`. +//! - **Subform Entry Setter**: This setter allows for the individual formation of elements within a collection. It returns a former for each element, enabling detailed configuration and addition of complex elements within collections, exemplified by managing `Child` entities within a `Parent`'s `HashMap`. //! -//! Each type of setter is designed to address different needs in the formation process, ensuring that users can build complex, nested structures or simply set individual field values as required. +//! - **Subform Scalar Setter**: Similar to the subform entry setter but designed for scalar fields that have a former implementation. This setter does not collect instances into a collection because there is no collection involved, only a scalar field. It is used when the scalar field itself needs to be configured or modified through its dedicated former. +//! +//! These setters ensure that developers can precisely and efficiently set properties, manage collections, and configure complex structures within their applications. //! // Ensure the example only compiles when the appropriate features are enabled. diff --git a/module/core/former/tests/inc/former_tests/subform_scalar.rs b/module/core/former/tests/inc/former_tests/subform_scalar.rs index c4c17ee75b..f7003286d7 100644 --- a/module/core/former/tests/inc/former_tests/subform_scalar.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar.rs @@ -17,7 +17,7 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ scalar_subform ] + #[ subform_scalar ] child : Child, } diff --git a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs index f41ab5f575..5df4cbc594 100644 --- a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs @@ -68,7 +68,23 @@ where // = end -/// Handles the completion of and element of subformer's collection. +/// Represents the endpoint for the forming process of a scalar field managed by a subformer within a `Parent` entity. +/// +/// This structure is a critical component of the forming process when using a subform scalar setter. It handles +/// the finalization of the scalar field's value that has been configured through its dedicated subformer. +/// Essentially, this end action integrates the individually formed scalar value back into the parent structure. +/// +/// ## Type Parameters +/// +/// - `Definition`: The type that defines the former setup for the `Parent` entity, influencing storage and behavior during forming. +/// +/// ## Parameters of `call` +/// +/// - `substorage`: Storage type specific to the `Child`, containing the newly formed scalar value. +/// - `super_former`: An optional context of the `ParentFormer`, which will receive the value. The function ensures +/// that this context is not `None` and inserts the formed value into the designated field within `Parent`'s storage. +/// + pub struct ParentFormerSubformScalarChildEnd< Definition > { _phantom : core::marker::PhantomData< fn( Definition ) >, diff --git a/module/core/former/tests/inc/mod.rs b/module/core/former/tests/inc/mod.rs index 9a8bc67b8c..0936faa6e2 100644 --- a/module/core/former/tests/inc/mod.rs +++ b/module/core/former/tests/inc/mod.rs @@ -96,8 +96,8 @@ mod former_tests // = subform scalar // xxx - // #[ cfg( any( not( feature = "no_std" ) ) ) ] - // mod subform_scalar; + #[ cfg( any( not( feature = "no_std" ) ) ) ] + mod subform_scalar; #[ cfg( any( not( feature = "no_std" ) ) ) ] mod subform_scalar_manual; diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index 2d13d9d8d9..a6aa274249 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -1269,36 +1269,25 @@ where ( r#" -Implements the `FormingEnd` trait for `{subform_scalar_end}` to handle the final -stage of the forming process for a `{stru}` collection that contains `{0}` elements. +Represents the endpoint for the forming process of a scalar field managed by a subformer within a `{stru}` entity. -This implementation is tailored to manage the transition of {field_ident} elements from a substorage -temporary state into their final state within the `{stru}`'s storage. The function ensures -that the `{stru}`'s {field_ident} storage is initialized if not already set, and then adds the -preformed elements to this storage. +This structure is a critical component of the forming process when using a subform scalar setter. It handles +the finalization of the scalar field's value that has been configured through its dedicated subformer. +Essentially, this end action integrates the individually formed scalar value back into the parent structure. -# Type Parameters +## Type Parameters -- `Types2`: Represents the specific types associated with the `Former` trait being applied, - which include storage, formed type, and context. -- `Definition`: Defines the `FormerDefinition` that outlines the storage structure and - the end conditions for the formation process. - -# Parameters - -- `substorage`: The storage from which {field_ident} elements are preformed and retrieved. -- `super_former`: An optional context which, upon invocation, contains the `{former}` - instance being formed. +- `Definition`: The type that defines the former setup for the `{stru}` entity, influencing storage and behavior during forming. -# Returns +## Parameters of `call` -Returns the updated `{former}` instance with newly added {field_ident}, completing the -formation process of the `{stru}`. +- `substorage`: Storage type specific to the `{0}`, containing the newly formed scalar value. +- `super_former`: An optional context of the `{former}`, which will receive the value. The function ensures + that this context is not `None` and inserts the formed value into the designated field within `{stru}`'s storage. "#, format!( "{}", qt!{ #field_typ } ), ); - // xxx : outdated let namespace_code = qt! { @@ -1331,7 +1320,7 @@ formation process of the `{stru}`. >, Types2 : former::FormerDefinitionTypes < - Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, + Storage = < #field_typ as former::EntityToStorage >::Storage, Formed = #former< #former_generics_ty >, Context = #former< #former_generics_ty >, >, @@ -1347,23 +1336,60 @@ formation process of the `{stru}`. -> Types2::Formed { let mut super_former = super_former.unwrap(); - if super_former.storage.#field_ident.is_none() - { - super_former.storage.#field_ident = Some( Default::default() ); - } - if let Some( ref mut field ) = super_former.storage.#field_ident - { - former::CollectionAdd::add - ( - field, - < < #field_typ as former::Collection >::Val as former::ValToEntry< #field_typ > > - ::val_to_entry( former::StoragePreform::preform( substorage ) ), - ); - } + debug_assert!( super_former.storage.#field_ident.is_none() ); + super_former.storage.#field_ident = Some( ::core::convert::Into::into( former::StoragePreform::preform( substorage ) ) ); super_former } } +// pub struct ParentFormerSubformScalarChildEnd< Definition > +// { +// _phantom : core::marker::PhantomData< fn( Definition ) >, +// } +// +// impl< Definition > Default +// for ParentFormerSubformScalarChildEnd< Definition > +// { +// #[ inline( always ) ] +// fn default() -> Self +// { +// Self +// { +// _phantom : core::marker::PhantomData, +// } +// } +// } +// +// impl< Types2, Definition > former::FormingEnd< Types2, > +// for ParentFormerSubformScalarChildEnd< Definition > +// where +// Definition : former::FormerDefinition +// < +// Storage = < Parent as former::EntityToStorage >::Storage, +// >, +// Types2 : former::FormerDefinitionTypes +// < +// Storage = < Child as former::EntityToStorage >::Storage, +// Formed = ParentFormer< Definition >, +// Context = ParentFormer< Definition >, +// >, +// { +// #[ inline( always ) ] +// fn call +// ( +// &self, +// substorage : Types2::Storage, +// super_former : core::option::Option< Types2::Context >, +// ) +// -> Types2::Formed +// { +// let mut super_former = super_former.unwrap(); +// debug_assert!( super_former.storage.child.is_none() ); +// super_former.storage.child = Some( ::core::convert::Into::into( former::StoragePreform::preform( substorage ) ) ); +// super_former +// } +// } + }; // tree_print!( setters_code.as_ref().unwrap() ); From fe4490ffc789a81c43323e8ffd7c73c523bb8f87 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 20:18:44 +0300 Subject: [PATCH 17/24] former : introducing subform_scalar --- .../tests/inc/former_tests/subform_scalar.rs | 4 +- .../inc/former_tests/subform_scalar_manual.rs | 30 +++--- .../former_meta/src/derive_former/field.rs | 96 +++++++++++++++++-- 3 files changed, 103 insertions(+), 27 deletions(-) diff --git a/module/core/former/tests/inc/former_tests/subform_scalar.rs b/module/core/former/tests/inc/former_tests/subform_scalar.rs index f7003286d7..996c0db1e7 100644 --- a/module/core/former/tests/inc/former_tests/subform_scalar.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar.rs @@ -32,5 +32,5 @@ where // == end of generated -// include!( "./only_test/subformer_scalar.rs" ); -// xxx : uncomment \ No newline at end of file +include!( "./only_test/subformer_scalar_subform.rs" ); +// xxx : uncomment diff --git a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs index 5df4cbc594..013dc02cf5 100644 --- a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs @@ -22,21 +22,6 @@ pub struct Parent child : Child, } -impl< Definition > ParentFormer< Definition > -where - Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, -{ - - #[ inline( always ) ] - pub fn child( self ) -> - ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > - { - self._child_scalar_subformer - ::< < Child as former::EntityToFormer< _ > >::Former, _, >() - } - -} - impl< Definition > ParentFormer< Definition > where Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, @@ -66,6 +51,21 @@ where } +impl< Definition > ParentFormer< Definition > +where + Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, +{ + + #[ inline( always ) ] + pub fn child( self ) -> + ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + { + self._child_scalar_subformer + ::< < Child as former::EntityToFormer< _ > >::Former, _, >() + } + +} + // = end /// Represents the endpoint for the forming process of a scalar field managed by a subformer within a `Parent` entity. diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index a6aa274249..d2d28f7f23 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -343,6 +343,8 @@ scalar_setter_required ) -> Result< ( TokenStream, TokenStream ) > { + + // scalar setter let namespace_code = qt! {}; let setters_code = self.scalar_setter ( @@ -350,7 +352,27 @@ scalar_setter_required former_storage, ); - // collection setter + // subform scalar setter + let ( setters_code, namespace_code ) = if self.attrs.subform_scalar.is_some() + { + let ( setters_code2, namespace_code2 ) = self.subform_scalar_setter + ( + stru, + former, + former_storage, + former_generics_ty, + struct_generics_impl, + struct_generics_ty, + struct_generics_where, + )?; + ( qt! { #setters_code #setters_code2 }, qt! { #namespace_code #namespace_code2 } ) + } + else + { + ( setters_code, namespace_code ) + }; + + // subform collection setter let ( setters_code, namespace_code ) = if let Some( _ ) = &self.attrs.subform_collection { let ( setters_code2, namespace_code2 ) = self.subform_collection_setter @@ -370,7 +392,7 @@ scalar_setter_required ( setters_code, namespace_code ) }; - // subform setter + // subform entry setter let ( setters_code, namespace_code ) = if self.attrs.subform_entry.is_some() { let ( setters_code2, namespace_code2 ) = self.subform_entry_setter @@ -485,6 +507,7 @@ where self } } + } /// @@ -1092,7 +1115,7 @@ formation process of the `{stru}`. } - /// Generates setter functions to subform entries of a collection. + /// Generates setter functions to subform scalar. /// /// See `tests/inc/former_tests/subform_scalar_manual.rs` for example of generated code. /// @@ -1156,18 +1179,19 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i #[ doc = #doc ] #[ inline( always ) ] - pub fn #subform_scalar< Former2, Definition2 >( self ) -> Former2 + pub fn #subform_scalar< Former2, Definition2 >( self ) -> + Former2 where Definition2 : former::FormerDefinition < End = #subform_scalar_end< Definition >, - Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, + Storage = < #field_typ as former::EntityToStorage >::Storage, Formed = Self, Context = Self, >, Definition2::Types : former::FormerDefinitionTypes < - Storage = < < #field_typ as former::Collection >::Val as former::EntityToStorage >::Storage, + Storage = < #field_typ as former::EntityToStorage >::Storage, Formed = Self, Context = Self, >, @@ -1176,6 +1200,28 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i Former2::former_begin( None, Some( self ), #subform_scalar_end::default() ) } + // #[ inline( always ) ] + // pub fn _child_scalar_subformer< Former2, Definition2 >( self ) -> + // Former2 + // where + // Definition2 : former::FormerDefinition + // < + // End = ParentFormerSubformScalarChildEnd< Definition >, + // Storage = < Child as former::EntityToStorage >::Storage, + // Formed = Self, + // Context = Self, + // >, + // Definition2::Types : former::FormerDefinitionTypes + // < + // Storage = < Child as former::EntityToStorage >::Storage, + // Formed = Self, + // Context = Self, + // >, + // Former2 : former::FormerBegin< Definition2 >, + // { + // Former2::former_begin( None, Some( self ), ParentFormerSubformScalarChildEnd::default() ) + // } + }; let setters_code = if attr.setter() @@ -1200,21 +1246,46 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i { #setters_code + // #[ doc = #doc ] + // #[ inline( always ) ] + // pub fn #setter_name( self ) -> + // < < #field_typ as former::Collection >::Val as former::EntityToFormer + // < + // < + // < #field_typ as former::Collection >::Val as former::EntityToDefinition< Self, Self, #subform_scalar_end < Definition > > + // >::Definition, + // > + // >::Former + // { + // self.#subform_scalar + // ::< < < #field_typ as former::Collection >::Val as former::EntityToFormer< _ > >::Former, _, >() + // // ::< #former< _ >, _, >() + // } + // xxx : clean + #[ doc = #doc ] #[ inline( always ) ] pub fn #setter_name( self ) -> - < < #field_typ as former::Collection >::Val as former::EntityToFormer + < #field_typ as former::EntityToFormer < < - < #field_typ as former::Collection >::Val as former::EntityToDefinition< Self, Self, #subform_scalar_end < Definition > > + #field_typ as former::EntityToDefinition< Self, Self, #subform_scalar_end < Definition > > >::Definition, > >::Former { self.#subform_scalar - ::< < < #field_typ as former::Collection >::Val as former::EntityToFormer< _ > >::Former, _, >() - // ::< #former< _ >, _, >() + ::< < #field_typ as former::EntityToFormer< _ > >::Former, _, >() } + + // #[ inline( always ) ] + // pub fn child( self ) -> + // ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + // { + // self._child_scalar_subformer + // ::< < Child as former::EntityToFormer< _ > >::Former, _, >() + // } + } // #[ inline( always ) ] @@ -1490,6 +1561,11 @@ Essentially, this end action integrates the individually formed scalar value bac } } + if self.attrs.subform_scalar.is_some() && !explicit + { + return false; + } + if self.attrs.subform_collection.is_some() && !explicit { return false; From 82dd8418cbabe56705a91fcbd2132e7e22c6d783 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 20:29:43 +0300 Subject: [PATCH 18/24] former : introducing subform_scalar --- .../former_meta/src/derive_former/field.rs | 63 +++++++------------ 1 file changed, 24 insertions(+), 39 deletions(-) diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index d2d28f7f23..0832c15933 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -1157,21 +1157,30 @@ formation process of the `{stru}`. ( r#" -Initiates the addition of {field_ident} to the `{stru}` entity using a dedicated subformer. +Initiates the scalar subformer for a `{0}` entity within a `{stru}`. -This method configures and returns a subformer specialized for the `{0}` entities' formation process, -which is part of the `{stru}` entity's construction. The subformer is set up with a specific end condition -handled by `{subform_scalar_end}`, ensuring that the {field_ident} are properly integrated into the -parent's structure once formed. +This function creates a subformer specifically for handling scalar values associated with a `{0}` entity, +leveraging a dedicated end structure to integrate the formed value seamlessly back into the `{stru}`. -# Returns +## Type Parameters -Returns an instance of `Former2`, a subformer ready to begin the formation process for `{0}` entities, -allowing for dynamic and flexible construction of the `{stru}` entity's {field_ident}. +- `Former2`: Represents the specific former to be returned. +- `Definition2`: Defines the former's setup including its end action and storage specifics. + +## Returns + +- `Former2`: An instance of the former configured to handle the scalar formation of a `{0}`. + +This method prepares the forming context, ensuring that the subforming process for a scalar field in `{stru}` +is properly initialized with all necessary configurations, including the default end action for integration. + +## Usage + +This function is typically called internally by a more user-friendly method that abstracts away the complex +generics, providing a cleaner interface for initiating subform operations on scalar fields. "#, format!( "{}", qt!{ #field_typ } ), - // xxx : outdated ); let setters_code = qt! @@ -1230,39 +1239,23 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i let doc = format! ( r#" -Provides a user-friendly interface to add an instancce of {field_ident} to the {stru}. +Provides a user-friendly interface to begin subforming a scalar `{0}` field within a `{stru}`. -# Returns +This method abstracts the underlying complex generics involved in setting up the former, simplifying the +user interaction needed to initiate the subform process for a scalar field associated with a `{0}`. -Returns an instance of `Former2`, a subformer ready to begin the formation process for `{0}` entities, -allowing for dynamic and flexible construction of the `{stru}` entity's {field_ident}. +This method utilizes the more generic `{subform_scalar}` method to set up and return the subformer, +providing a straightforward and type-safe interface for client code. It encapsulates details about the specific +former and end action types, ensuring a seamless developer experience when forming parts of a `{stru}`. "#, format!( "{}", qt!{ #field_typ } ), ); - // xxx : outdated qt! { #setters_code - // #[ doc = #doc ] - // #[ inline( always ) ] - // pub fn #setter_name( self ) -> - // < < #field_typ as former::Collection >::Val as former::EntityToFormer - // < - // < - // < #field_typ as former::Collection >::Val as former::EntityToDefinition< Self, Self, #subform_scalar_end < Definition > > - // >::Definition, - // > - // >::Former - // { - // self.#subform_scalar - // ::< < < #field_typ as former::Collection >::Val as former::EntityToFormer< _ > >::Former, _, >() - // // ::< #former< _ >, _, >() - // } - // xxx : clean - #[ doc = #doc ] #[ inline( always ) ] pub fn #setter_name( self ) -> @@ -1288,14 +1281,6 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i } - // #[ inline( always ) ] - // pub fn child( self ) -> - // ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > - // { - // self._children_subform_scalar - // ::< < Child as former::EntityToFormer< _ > >::Former, _, >() - // } - } else { From d5fbe32ec8e847150add0af4bef47f5e84a16db4 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 20:56:54 +0300 Subject: [PATCH 19/24] former : introducing subform_scalar --- module/core/former/Readme.md | 295 +++++++++++------- ...ntainer.rs => former_custom_collection.rs} | 0 ...rs => former_custom_subform_collection.rs} | 2 + ...tter.rs => former_custom_subform_entry.rs} | 3 +- ...er2.rs => former_custom_subform_entry2.rs} | 0 .../examples/former_custom_subform_scalar.rs | 88 ++++++ .../inc/former_tests/subform_scalar_manual.rs | 2 + .../former_meta/src/derive_former/field.rs | 30 +- 8 files changed, 294 insertions(+), 126 deletions(-) rename module/core/former/examples/{former_custom_container.rs => former_custom_collection.rs} (100%) rename module/core/former/examples/{former_custom_container_setter.rs => former_custom_subform_collection.rs} (98%) rename module/core/former/examples/{former_custom_subform_setter.rs => former_custom_subform_entry.rs} (98%) rename module/core/former/examples/{former_custom_subform_setter2.rs => former_custom_subform_entry2.rs} (100%) create mode 100644 module/core/former/examples/former_custom_subform_scalar.rs diff --git a/module/core/former/Readme.md b/module/core/former/Readme.md index c3e87d09a2..01d72ba291 100644 --- a/module/core/former/Readme.md +++ b/module/core/former/Readme.md @@ -646,110 +646,6 @@ Storage is not just a passive collection; it is an active part of a larger ecosy These elements work in concert to ensure that the forming process is not only about building an object step-by-step but also about integrating it seamlessly into larger, more complex structures or systems. -## Concept of Definitions - -Definitions are utilized to encapsulate and manage generic parameters efficiently and avoid passing each parameter individually. - -Two key definition Traits: - -1. **`FormerDefinitionTypes`**: - - This trait outlines the essential components involved in the formation process, including the types of storage, the form being created, and the context used. It focuses on the types involved rather than the termination of the formation process. -2. **`FormerDefinition`**: - - Building upon `FormerDefinitionTypes`, this trait incorporates the `FormingEnd` callback, linking the formation types with a definitive ending. It specifies how the formation process should conclude, which may involve validations, transformations, or integrations into larger structures. - - The inclusion of the `End` type parameter specifies the end conditions of the formation process, effectively connecting the temporary state held in storage to its ultimate form. - -## Overview of Formation Traits - -The formation process utilizes several core traits, each serving a specific purpose in the lifecycle of entity creation. These traits ensure that entities are constructed methodically, adhering to a structured pattern that enhances maintainability and scalability. Below is a summary of these key traits: - -- `EntityToDefinition`: Links entities to their respective formation definitions which dictate their construction process. -- `EntityToFormer`: Connects entities with formers that are responsible for their step-by-step construction. -- `EntityToStorage`: Specifies the storage structures that temporarily hold the state of an entity during its formation. -- `FormerDefinition`, `FormerDefinitionTypes`: Define the essential properties and ending conditions of the formation process, ensuring entities are formed according to predetermined rules and logic. -- `Storage`: Establishes the fundamental interface for storage types used in the formation process, ensuring each can initialize to a default state. -- `StoragePreform`: Describes the transformation of storage from a mutable, intermediate state into the final, immutable state of the entity, crucial for accurately concluding the formation process. -- `FormerMutator`: Allows for custom mutation logic on the storage and context immediately before the formation process completes, ensuring last-minute adjustments are possible. -- `FormingEnd`: Specifies the closure action at the end of the formation process, which can transform or validate the final state of the entity. -- `FormingEndClosure`: Provides a flexible mechanism for dynamically handling the end of the formation process using closures, useful for complex scenarios. -- `FormerBegin`: Initiates a subforming process, managing how entities begin their formation in terms of storage and context setup. - -These traits collectively facilitate a robust and flexible builder pattern that supports complex object creation and configuration scenarios. - -## Example : Custom Definition - -Define a custom former definition and custom forming logic, and apply them to a collection. - -The example showcases how to accumulate elements into a collection and then transform them into a single result using a custom `FormingEnd` implementation. This pattern is useful for scenarios where the formation process involves aggregation or transformation of input elements into a different type or form. - -```rust -# #[ cfg( any( not( feature = "derive_former" ), not( feature = "enabled" ) ) ) ] -# fn main() {} - -# #[ cfg( all( feature = "derive_former", feature = "enabled" ) ) ] -# fn main() -# { - - // Define a struct `Sum` that will act as a custom former definition. - struct Sum; - - // Implement `FormerDefinitionTypes` for `Sum`. - // This trait defines the types used during the forming process. - impl former::FormerDefinitionTypes for Sum - { - type Storage = Vec; // Collection for the integers. - type Formed = i32; // The final type after forming, which is a single integer. - type Context = (); // No additional context is used in this example. - } - - // Implement `FormerMutator` for `Sum`. - // This trait could include custom mutation logic applied during the forming process, but it's empty in this example. - impl former::FormerMutator for Sum - { - } - - // Implement `FormerDefinition` for `Sum`. - // This trait links the custom types to the former. - impl former::FormerDefinition for Sum - { - type Types = Sum; // Associate the `FormerDefinitionTypes` with `Sum`. - type End = Sum; // Use `Sum` itself as the end handler. - type Storage = Vec; // Specify the storage type. - type Formed = i32; // Specify the final formed type. - type Context = (); // Specify the context type, not used here. - } - - // Implement `FormingEnd` for `Sum`. - // This trait handles the final step of the forming process. - impl former::FormingEnd for Sum - { - fn call - ( - &self, - storage: < Sum as former::FormerDefinitionTypes >::Storage, - _context: Option< < Sum as former::FormerDefinitionTypes >::Context> - ) - -> < Sum as former::FormerDefinitionTypes >::Formed - { - // Sum all integers in the storage vector. - storage.iter().sum() - } - } - - // Use the custom `Former` to sum a list of integers. - let got = former::CollectionFormer::::new(Sum) - .add( 1 ) // Add an integer to the storage. - .add( 2 ) // Add another integer. - .add( 10 ) // Add another integer. - .form(); // Perform the form operation, which triggers the summing logic. - let exp = 13; // Expected result after summing 1, 2, and 10. - assert_eq!(got, exp); // Assert the result is as expected. - - dbg!(got); // Debug print the result to verify the output. - // > got = 13 - -# } -``` - ## Concept of subformer Subformers are specialized builders used within the former to construct nested or collection-based data structures like vectors, hash maps, and hash sets. They simplify the process of adding elements to these structures by providing a fluent interface that can be seamlessly integrated into the overall builder pattern of a parent struct. This approach allows for clean and intuitive initialization of complex data structures, enhancing code readability and maintainability. @@ -964,7 +860,82 @@ Try out `cargo run --example former_custom_scalar_setter`.
[See code](./examples/former_custom_scalar_setter.rs). -## Example : Custom Collection Setter +## Example : Custom Subform Scalar Setter + +Implementation of a custom subform scalar setter using the `Former` trait in Rust. + +This example focuses on the usage of a subform scalar setter to manage complex scalar types within a parent structure. +Unlike more general subform setters that handle collections, this setter specifically configures scalar fields that have +their own formers, allowing for detailed configuration within a nested builder pattern. + +```rust + +# #[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] +# fn main() +# {} +# +# // Ensures the example only compiles when the appropriate features are enabled. +# #[ cfg( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ] +# fn main() +# { + + use former::Former; + + // Child struct with Former derived for builder pattern support + #[ derive( Debug, PartialEq, Former ) ] + // Optional: Use `#[debug]` to expand and debug generated code. + // #[debug] + pub struct Child + { + name : String, + description : String, + } + + // Parent struct designed to hold a single Child instance using subform scalar + #[ derive( Debug, PartialEq, Former ) ] + // Optional: Use `#[debug]` to expand and debug generated code. + // #[debug] + pub struct Parent + { + // The `subform_scalar` attribute is used to specify that the 'child' field has its own former + // and can be individually configured via a subform setter. This is not a collection but a single scalar entity. + #[ subform_scalar( setter = false, hint = false ) ] + child : Child, + } + + /// Extends `ParentFormer` to include a method that initializes and configures a subformer for the 'child' field. + /// This function demonstrates the dynamic addition of a named child, leveraging a subformer to specify detailed properties. + impl< Definition > ParentFormer< Definition > + where + Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, + { + #[ inline( always ) ] + pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + { + self._child_subform_scalar::< ChildFormer< _ >, _, >().name( name ) + } + } + + // Creating an instance of `Parent` using the builder pattern to configure `Child` + let ca = Parent::former() + .child( "echo" ) // starts the configuration of the `child` subformer + .description( "prints all subjects and properties" ) // sets additional properties for the `Child` + .end() // finalize the child configuration + .form(); // finalize the Parent configuration + + dbg!( &ca ); // Outputs the structured data for review + // Expected output: + //> Parent { + //> child: Child { + //> name: "echo", + //> description: "prints all subjects and properties", + //> }, + //> } + +# } +``` + +## Example : Custom Subform Collection Setter This example demonstrates the use of collection setters to manage complex nested data structures with the `Former` trait, focusing on a parent-child relationship structured around a collection `HashMap`. Unlike typical builder patterns that add individual elements using subform setters, this example uses a collection setter to manage the entire collection of children. @@ -1041,11 +1012,11 @@ The `child` function within `ParentFormer` is a custom subform setter that plays # } ``` -Try out `cargo run --example former_custom_collection_setter`. +Try out `cargo run --example former_custom_subform_collection`.
-[See code](./examples/former_custom_collection_setter.rs). +[See code](./examples/former_custom_subform_collection.rs). -## Example : Custom Subform Setter +## Example : Custom Subform Entry Setter This example illustrates the implementation of nested builder patterns using the `Former` trait, emphasizing a parent-child relationship. Here, the `Parent` struct utilizes `ChildFormer` as a custom subformer to dynamically manage its `child` field—a `HashMap`. Each child in the `HashMap` is uniquely identified and configured via the `ChildFormer`. @@ -1135,9 +1106,9 @@ The `child` function within `ParentFormer` is a custom subform setter that plays # } ``` -Try out `cargo run --example former_custom_subform_setter`. +Try out `cargo run --example former_custom_subform_entry`.
-[See code](./examples/former_custom_subform_setter.rs). +[See code](./examples/former_custom_subform_entry.rs). ## General Collection Interface @@ -1255,6 +1226,110 @@ Try out `cargo run --example former_custom_mutator`.
[See code](./examples/former_custom_mutator.rs). +## Concept of Definitions + +Definitions are utilized to encapsulate and manage generic parameters efficiently and avoid passing each parameter individually. + +Two key definition Traits: + +1. **`FormerDefinitionTypes`**: + - This trait outlines the essential components involved in the formation process, including the types of storage, the form being created, and the context used. It focuses on the types involved rather than the termination of the formation process. +2. **`FormerDefinition`**: + - Building upon `FormerDefinitionTypes`, this trait incorporates the `FormingEnd` callback, linking the formation types with a definitive ending. It specifies how the formation process should conclude, which may involve validations, transformations, or integrations into larger structures. + - The inclusion of the `End` type parameter specifies the end conditions of the formation process, effectively connecting the temporary state held in storage to its ultimate form. + +## Overview of Formation Traits + +The formation process utilizes several core traits, each serving a specific purpose in the lifecycle of entity creation. These traits ensure that entities are constructed methodically, adhering to a structured pattern that enhances maintainability and scalability. Below is a summary of these key traits: + +- `EntityToDefinition`: Links entities to their respective formation definitions which dictate their construction process. +- `EntityToFormer`: Connects entities with formers that are responsible for their step-by-step construction. +- `EntityToStorage`: Specifies the storage structures that temporarily hold the state of an entity during its formation. +- `FormerDefinition`, `FormerDefinitionTypes`: Define the essential properties and ending conditions of the formation process, ensuring entities are formed according to predetermined rules and logic. +- `Storage`: Establishes the fundamental interface for storage types used in the formation process, ensuring each can initialize to a default state. +- `StoragePreform`: Describes the transformation of storage from a mutable, intermediate state into the final, immutable state of the entity, crucial for accurately concluding the formation process. +- `FormerMutator`: Allows for custom mutation logic on the storage and context immediately before the formation process completes, ensuring last-minute adjustments are possible. +- `FormingEnd`: Specifies the closure action at the end of the formation process, which can transform or validate the final state of the entity. +- `FormingEndClosure`: Provides a flexible mechanism for dynamically handling the end of the formation process using closures, useful for complex scenarios. +- `FormerBegin`: Initiates a subforming process, managing how entities begin their formation in terms of storage and context setup. + +These traits collectively facilitate a robust and flexible builder pattern that supports complex object creation and configuration scenarios. + +## Example : Custom Definition + +Define a custom former definition and custom forming logic, and apply them to a collection. + +The example showcases how to accumulate elements into a collection and then transform them into a single result using a custom `FormingEnd` implementation. This pattern is useful for scenarios where the formation process involves aggregation or transformation of input elements into a different type or form. + +```rust +# #[ cfg( any( not( feature = "derive_former" ), not( feature = "enabled" ) ) ) ] +# fn main() {} + +# #[ cfg( all( feature = "derive_former", feature = "enabled" ) ) ] +# fn main() +# { + + // Define a struct `Sum` that will act as a custom former definition. + struct Sum; + + // Implement `FormerDefinitionTypes` for `Sum`. + // This trait defines the types used during the forming process. + impl former::FormerDefinitionTypes for Sum + { + type Storage = Vec; // Collection for the integers. + type Formed = i32; // The final type after forming, which is a single integer. + type Context = (); // No additional context is used in this example. + } + + // Implement `FormerMutator` for `Sum`. + // This trait could include custom mutation logic applied during the forming process, but it's empty in this example. + impl former::FormerMutator for Sum + { + } + + // Implement `FormerDefinition` for `Sum`. + // This trait links the custom types to the former. + impl former::FormerDefinition for Sum + { + type Types = Sum; // Associate the `FormerDefinitionTypes` with `Sum`. + type End = Sum; // Use `Sum` itself as the end handler. + type Storage = Vec; // Specify the storage type. + type Formed = i32; // Specify the final formed type. + type Context = (); // Specify the context type, not used here. + } + + // Implement `FormingEnd` for `Sum`. + // This trait handles the final step of the forming process. + impl former::FormingEnd for Sum + { + fn call + ( + &self, + storage: < Sum as former::FormerDefinitionTypes >::Storage, + _context: Option< < Sum as former::FormerDefinitionTypes >::Context> + ) + -> < Sum as former::FormerDefinitionTypes >::Formed + { + // Sum all integers in the storage vector. + storage.iter().sum() + } + } + + // Use the custom `Former` to sum a list of integers. + let got = former::CollectionFormer::::new(Sum) + .add( 1 ) // Add an integer to the storage. + .add( 2 ) // Add another integer. + .add( 10 ) // Add another integer. + .form(); // Perform the form operation, which triggers the summing logic. + let exp = 13; // Expected result after summing 1, 2, and 10. + assert_eq!(got, exp); // Assert the result is as expected. + + dbg!(got); // Debug print the result to verify the output. + // > got = 13 + +# } +``` + ## Index of Examples diff --git a/module/core/former/examples/former_custom_container.rs b/module/core/former/examples/former_custom_collection.rs similarity index 100% rename from module/core/former/examples/former_custom_container.rs rename to module/core/former/examples/former_custom_collection.rs diff --git a/module/core/former/examples/former_custom_container_setter.rs b/module/core/former/examples/former_custom_subform_collection.rs similarity index 98% rename from module/core/former/examples/former_custom_container_setter.rs rename to module/core/former/examples/former_custom_subform_collection.rs index f2d323dd27..0f0e309c3d 100644 --- a/module/core/former/examples/former_custom_container_setter.rs +++ b/module/core/former/examples/former_custom_subform_collection.rs @@ -1,5 +1,7 @@ // Example former_custom_collection_setter.rs +//! +//! ## Example : Custom Subform Collection Setter //! //! This example demonstrates the use of collection setters to manage complex nested data structures with the `Former` trait, focusing on a parent-child relationship structured around a collection `HashMap`. Unlike typical builder patterns that add individual elements using subform setters, this example uses a collection setter to manage the entire collection of children. //! diff --git a/module/core/former/examples/former_custom_subform_setter.rs b/module/core/former/examples/former_custom_subform_entry.rs similarity index 98% rename from module/core/former/examples/former_custom_subform_setter.rs rename to module/core/former/examples/former_custom_subform_entry.rs index aa759e8ffe..f035ea53a6 100644 --- a/module/core/former/examples/former_custom_subform_setter.rs +++ b/module/core/former/examples/former_custom_subform_entry.rs @@ -1,5 +1,6 @@ -// Example former_custom_subformer.rs +// Example former_custom_subform_entry.rs +//! ## Example : Custom Subform Entry Setter //! //! This example illustrates the implementation of nested builder patterns using the `Former` trait, emphasizing a parent-child relationship. Here, the `Parent` struct utilizes `ChildFormer` as a custom subformer to dynamically manage its `child` field—a `HashMap`. Each child in the `HashMap` is uniquely identified and configured via the `ChildFormer`. //! diff --git a/module/core/former/examples/former_custom_subform_setter2.rs b/module/core/former/examples/former_custom_subform_entry2.rs similarity index 100% rename from module/core/former/examples/former_custom_subform_setter2.rs rename to module/core/former/examples/former_custom_subform_entry2.rs diff --git a/module/core/former/examples/former_custom_subform_scalar.rs b/module/core/former/examples/former_custom_subform_scalar.rs new file mode 100644 index 0000000000..b63f9e2d1d --- /dev/null +++ b/module/core/former/examples/former_custom_subform_scalar.rs @@ -0,0 +1,88 @@ +// Example former_custom_subform_scalar.rs + +//! +//! ## Example : Custom Subform Scalar Setter +//! +//! Implementation of a custom subform scalar setter using the `Former` trait in Rust. +//! +//! This example focuses on the usage of a subform scalar setter to manage complex scalar types within a parent structure. +//! Unlike more general subform setters that handle collections, this setter specifically configures scalar fields that have +//! their own formers, allowing for detailed configuration within a nested builder pattern. +//! +//! #### Types of Setters / Subformers +//! +//! Understanding the distinctions among the types of setters or subformers is essential for effectively employing the builder pattern in object construction. Each type of setter is designed to meet specific needs in building complex, structured data entities: +//! +//! - **Scalar Setter**: Handles the direct assignment of scalar values or simple fields within an entity. These setters manage basic data types or individual fields and do not involve nested formers or complex structuring. +//! +//! - **Subform Collection Setter**: Facilitates the management of a collection as a whole by returning a former that provides an interface to configure the entire collection. This setter is beneficial for applying uniform configurations or validations to all elements in a collection, such as a `HashMap` of children. +//! +//! - **Subform Entry Setter**: This setter allows for the individual formation of elements within a collection. It returns a former for each element, enabling detailed configuration and addition of complex elements within collections, exemplified by managing `Child` entities within a `Parent`'s `HashMap`. +//! +//! - **Subform Scalar Setter**: Similar to the subform entry setter but designed for scalar fields that have a former implementation. This setter does not collect instances into a collection because there is no collection involved, only a scalar field. It is used when the scalar field itself needs to be configured or modified through its dedicated former. +//! +//! These setters ensure that developers can precisely and efficiently set properties, manage collections, and configure complex structures within their applications. +//! + + +#[ cfg( not( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ) ] +fn main() +{} + +// Ensures the example only compiles when the appropriate features are enabled. +#[ cfg( all( feature = "enabled", feature = "derive_former", not( feature = "no_std" ) ) ) ] +fn main() +{ + use former::Former; + + // Child struct with Former derived for builder pattern support + #[ derive( Debug, PartialEq, Former ) ] + // Optional: Use `#[debug]` to expand and debug generated code. + // #[debug] + pub struct Child + { + name : String, + description : String, + } + + // Parent struct designed to hold a single Child instance using subform scalar + #[ derive( Debug, PartialEq, Former ) ] + // Optional: Use `#[debug]` to expand and debug generated code. + // #[debug] + pub struct Parent + { + // The `subform_scalar` attribute is used to specify that the 'child' field has its own former + // and can be individually configured via a subform setter. This is not a collection but a single scalar entity. + #[ subform_scalar( setter = false, hint = false ) ] + child : Child, + } + + /// Extends `ParentFormer` to include a method that initializes and configures a subformer for the 'child' field. + /// This function demonstrates the dynamic addition of a named child, leveraging a subformer to specify detailed properties. + impl< Definition > ParentFormer< Definition > + where + Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, + { + #[ inline( always ) ] + pub fn child( self, name : &str ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + { + self._child_subform_scalar::< ChildFormer< _ >, _, >().name( name ) + } + } + + // Creating an instance of `Parent` using the builder pattern to configure `Child` + let ca = Parent::former() + .child( "echo" ) // starts the configuration of the `child` subformer + .description( "prints all subjects and properties" ) // sets additional properties for the `Child` + .end() // finalize the child configuration + .form(); // finalize the Parent configuration + + dbg!( &ca ); // Outputs the structured data for review + // Expected output: + //> Parent { + //> child: Child { + //> name: "echo", + //> description: "prints all subjects and properties", + //> }, + //> } +} diff --git a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs index 013dc02cf5..6c795e2b7d 100644 --- a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs @@ -139,3 +139,5 @@ where include!( "./only_test/subformer_scalar_subform.rs" ); // xxx : uncomment +// xxx : write few more tests to cover name, setter +// xxx : extend all test diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index 0832c15933..9ba4b06be7 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -680,6 +680,7 @@ where if attr.hint { + // xxx : maybe improve let hint = format! ( r#" @@ -978,6 +979,7 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i if attr.hint { + // xxx : maybe improve let hint = format! ( r#" @@ -1127,7 +1129,7 @@ formation process of the `{stru}`. &self, stru : &syn::Ident, former : &syn::Ident, - former_storage : &syn::Ident, + _former_storage : &syn::Ident, former_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, struct_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, struct_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, @@ -1293,28 +1295,26 @@ former and end action types, ensuring a seamless developer experience when formi ( r#" -/// Initializes and configures a subformer for adding named child entities. This method leverages an internal function -/// to create and return a configured subformer instance. It allows for the dynamic addition of children with specific names, -/// integrating them into the formation process of the parent entity. +/// Extends `{former}` to include a method that initializes and configures a subformer for the '{field_ident}' field. +/// This function demonstrates the dynamic addition of a named {field_ident}, leveraging a subformer to specify detailed properties. -impl< Definition > {}< Definition > +impl< Definition > {former}< Definition > where - Definition : former::FormerDefinition< Storage = {} >, + Definition : former::FormerDefinition< Storage = < {stru} as former::EntityToStorage >::Storage >, {{ - #[ inline( always ) ] - pub fn {}( self ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + pub fn {field_ident}( self, name : &str ) -> {0}AsSubformer< Self, impl {0}AsSubformerEnd< Self > > {{ - self.{}::< ChildFormer< _ >, _, >() + self._{field_ident}_subform_scalar::< {0}Former< _ >, _, >().name( name ) }} - // Replace Child with name of type of element value. - }} + "#, - former, - former_storage, - field_ident, - subform_scalar_name, + format!( "{}", qt!{ #field_typ } ), + // former, + // former_storage, + // field_ident, + // subform_scalar_name, ); println!( "{hint}" ); // xxx : outdated From 8d698aa05d560d07777939e08a0416d894d9be8b Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 21:04:07 +0300 Subject: [PATCH 20/24] former : improving hints --- .../former_meta/src/derive_former/field.rs | 20 ++++++++++--------- 1 file changed, 11 insertions(+), 9 deletions(-) diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index 9ba4b06be7..5ec6901b94 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -863,6 +863,8 @@ with the new content generated during the subforming process. use convert_case::{ Case, Casing }; let field_ident = self.ident; let field_typ = self.non_optional_ty; + let entry_typ : &syn::Type = typ::parameter_first( field_typ )?; + let attr = self.attrs.subform_entry.as_ref().unwrap(); // let params = typ::type_parameters( &self.non_optional_ty, .. ); @@ -988,24 +990,24 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i /// to create and return a configured subformer instance. It allows for the dynamic addition of children with specific names, /// integrating them into the formation process of the parent entity. -impl< Definition > {}< Definition > +impl< Definition > {former}< Definition > where - Definition : former::FormerDefinition< Storage = {} >, + Definition : former::FormerDefinition< Storage = {former_storage} >, {{ #[ inline( always ) ] - pub fn {}( self ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + pub fn {field_ident}( self ) -> {0}AsSubformer< Self, impl {0}AsSubformerEnd< Self > > {{ - self.{}::< ChildFormer< _ >, _, >() + self.{subform_entry_name}::< {0}Former< _ >, _, >() }} - // Replace Child with name of type of element value. }} "#, - former, - former_storage, - field_ident, - subform_entry_name, + format!( "{}", qt!{ #entry_typ } ), + // former, + // former_storage, + // field_ident, + // subform_entry_name, ); println!( "{hint}" ); // xxx : use diag::report_print From c86a53df989a1a79085c95c5bc4d22d8eb1de02f Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 21:09:45 +0300 Subject: [PATCH 21/24] former : improving hints --- .../former_meta/src/derive_former/field.rs | 26 +++++++++---------- 1 file changed, 13 insertions(+), 13 deletions(-) diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index 5ec6901b94..42f9581e07 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -687,32 +687,32 @@ where /// The collection setter provides a collection setter that returns a CollectionFormer tailored for managing a collection of child entities. It employs a generic collection definition to facilitate operations on the entire collection, such as adding or updating elements. -impl< Definition, > {}< Definition, > +impl< Definition, > {former}< Definition, > where - Definition : former::FormerDefinition< Storage = {} >, + Definition : former::FormerDefinition< Storage = {former_storage} >, {{ #[ inline( always ) ] - pub fn {}( self ) -> former::CollectionFormer:: + pub fn {field_ident}( self ) -> former::CollectionFormer:: < - ( {} ), - former::HashMapDefinition< {} Self, Self, {}< Definition >, > + ( {0} ), + former::HashMapDefinition< {0} Self, Self, {subform_collection_end}< Definition >, > // Replace `HashMapDefinition` with definition for your collection > {{ - self.{}() + self.{subform_collection}() }} }} "#, - former, - former_storage, - field_ident, - format!( "{}", qt!{ #( #params, )* } ), + // former, + // former_storage, + // field_ident, format!( "{}", qt!{ #( #params, )* } ), - subform_collection_end, - subform_collection, + // format!( "{}", qt!{ #( #params, )* } ), + // subform_collection_end, + // subform_collection, ); let about = format! ( @@ -981,7 +981,6 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i if attr.hint { - // xxx : maybe improve let hint = format! ( r#" @@ -1000,6 +999,7 @@ where {{ self.{subform_entry_name}::< {0}Former< _ >, _, >() }} + // Replace {0} with name of type of entry value. }} "#, From c897ec34c191d5039f5a4d6b9b8db96aca492d23 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 21:15:05 +0300 Subject: [PATCH 22/24] former : improving hints --- .../former_custom_setter_overriden.rs | 10 +++++--- .../former_custom_subform_collection.rs | 2 +- .../former_meta/src/derive_former/field.rs | 24 +++++-------------- 3 files changed, 14 insertions(+), 22 deletions(-) diff --git a/module/core/former/examples/former_custom_setter_overriden.rs b/module/core/former/examples/former_custom_setter_overriden.rs index 4723ab16e2..9e6cb53bda 100644 --- a/module/core/former/examples/former_custom_setter_overriden.rs +++ b/module/core/former/examples/former_custom_setter_overriden.rs @@ -15,13 +15,13 @@ fn main() #[ derive( Debug, Former ) ] pub struct StructWithCustomSetters { - #[ scalar( setter = false ) ] + // Use `hint = true` to gennerate sketch of setter. + #[ scalar( setter = false, hint = false ) ] word : String, } impl StructWithCustomSettersFormer { - // Custom alternative setter for `word` pub fn word( mut self, value : impl Into< String > ) -> Self { @@ -29,11 +29,15 @@ fn main() self.storage.word = Some( format!( "{}!", value.into() ) ); self } - } let example = StructWithCustomSetters::former() .word( "Hello" ) .form(); assert_eq!( example.word, "Hello!".to_string() ); + dbg!( example ); + //> StructWithCustomSetters { + //> word: "Hello!", + //> } + } diff --git a/module/core/former/examples/former_custom_subform_collection.rs b/module/core/former/examples/former_custom_subform_collection.rs index 0f0e309c3d..0fdb14e674 100644 --- a/module/core/former/examples/former_custom_subform_collection.rs +++ b/module/core/former/examples/former_custom_subform_collection.rs @@ -1,4 +1,4 @@ -// Example former_custom_collection_setter.rs +// Example former_custom_subform_collection.rs //! //! ## Example : Custom Subform Collection Setter diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index 42f9581e07..0a8e2149fb 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -456,28 +456,23 @@ scalar_setter_required ( r#" -impl< Definition > {}< Definition > +impl< Definition > {former}< Definition > where - Definition : former::FormerDefinition< Storage = {} >, + Definition : former::FormerDefinition< Storage = {former_storage} >, {{ #[ inline ] - pub fn {}< Src >( mut self, src : Src ) -> Self + pub fn {field_ident}< Src >( mut self, src : Src ) -> Self where - Src : ::core::convert::Into< {} >, + Src : ::core::convert::Into< {0} >, {{ - debug_assert!( self.storage.{}.is_none() ); - self.storage.{} = ::core::option::Option::Some( ::core::convert::Into::into( src ) ); + debug_assert!( self.storage.{field_ident}.is_none() ); + self.storage.{field_ident} = ::core::option::Option::Some( ::core::convert::Into::into( src ) ); self }} }} "#, - former, - former_storage, - field_ident, format!( "{}", qt!{ #typ } ), - field_ident, - field_ident, ); println!( "{hint}" ); // xxx : use diag::report_print @@ -680,7 +675,6 @@ where if attr.hint { - // xxx : maybe improve let hint = format! ( r#" @@ -706,13 +700,7 @@ where }} "#, - // former, - // former_storage, - // field_ident, format!( "{}", qt!{ #( #params, )* } ), - // format!( "{}", qt!{ #( #params, )* } ), - // subform_collection_end, - // subform_collection, ); let about = format! ( From 7dbf1155fbce3a096fe68a7f5407621efeaf93a4 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 21:27:12 +0300 Subject: [PATCH 23/24] former : improving hints and cleaning --- module/core/former/Readme.md | 52 ++++++++++------- .../former_custom_setter_overriden.rs | 14 ++++- module/core/former_meta/src/derive_former.rs | 17 ++++-- .../former_meta/src/derive_former/field.rs | 58 ++++++++++--------- 4 files changed, 85 insertions(+), 56 deletions(-) diff --git a/module/core/former/Readme.md b/module/core/former/Readme.md index 01d72ba291..89b702ba71 100644 --- a/module/core/former/Readme.md +++ b/module/core/former/Readme.md @@ -533,33 +533,41 @@ But it's also possible to completely override setter and write its own from scra # fn main() # { -use former::Former; - -/// Structure with a custom setter. -#[ derive( Debug, Former ) ] -pub struct StructWithCustomSetters -{ - #[ scalar( setter = false ) ] - word : String, -} - -impl StructWithCustomSettersFormer -{ + use former::Former; - // Custom alternative setter for `word` - pub fn word( mut self, value : impl Into< String > ) -> Self + /// Structure with a custom setter. + #[ derive( Debug, Former ) ] + pub struct StructWithCustomSetters { - debug_assert!( self.storage.word.is_none() ); - self.storage.word = Some( format!( "{}!", value.into() ) ); - self + // Use `hint = true` to gennerate sketch of setter. + #[ scalar( setter = false, hint = false ) ] + word : String, } -} + impl< Definition > StructWithCustomSettersFormer< Definition > + where + Definition : former::FormerDefinition< Storage = StructWithCustomSettersFormerStorage >, + { + // Custom alternative setter for `word` + #[ inline ] + pub fn word< Src >( mut self, src : Src ) -> Self + where + Src : ::core::convert::Into< String >, + { + debug_assert!( self.storage.word.is_none() ); + self.storage.word = Some( format!( "{}!", src.into() ) ); + self + } + } -let example = StructWithCustomSetters::former() -.word( "Hello" ) -.form(); -assert_eq!( example.word, "Hello!".to_string() ); + let example = StructWithCustomSetters::former() + .word( "Hello" ) + .form(); + assert_eq!( example.word, "Hello!".to_string() ); + dbg!( example ); + //> StructWithCustomSetters { + //> word: "Hello!", + //> } # } ``` diff --git a/module/core/former/examples/former_custom_setter_overriden.rs b/module/core/former/examples/former_custom_setter_overriden.rs index 9e6cb53bda..08acd738a0 100644 --- a/module/core/former/examples/former_custom_setter_overriden.rs +++ b/module/core/former/examples/former_custom_setter_overriden.rs @@ -1,3 +1,6 @@ +//! +//! ## Example : Custom Setter Overriding +//! //! It's also possible to completely override setter and write its own from scratch. //! //! For that use attribe `[ setter( false ) ]` to disable setter. In the example, the default setter for `word` is disabled, and a custom setter is defined to automatically append an exclamation mark to the string. This method allows for complete control over the data assignment process, enabling the inclusion of any necessary logic or validation steps. @@ -20,13 +23,18 @@ fn main() word : String, } - impl StructWithCustomSettersFormer + impl< Definition > StructWithCustomSettersFormer< Definition > + where + Definition : former::FormerDefinition< Storage = StructWithCustomSettersFormerStorage >, { // Custom alternative setter for `word` - pub fn word( mut self, value : impl Into< String > ) -> Self + #[ inline ] + pub fn word< Src >( mut self, src : Src ) -> Self + where + Src : ::core::convert::Into< String >, { debug_assert!( self.storage.word.is_none() ); - self.storage.word = Some( format!( "{}!", value.into() ) ); + self.storage.word = Some( format!( "{}!", src.into() ) ); self } } diff --git a/module/core/former_meta/src/derive_former.rs b/module/core/former_meta/src/derive_former.rs index 7cbfed236c..3ad56cca8d 100644 --- a/module/core/former_meta/src/derive_former.rs +++ b/module/core/former_meta/src/derive_former.rs @@ -43,6 +43,8 @@ use struct_attrs::*; pub fn mutator ( + stru : &syn::Ident, + original_input : &proc_macro::TokenStream, mutator : &AttributeMutator, former_definition_types : &syn::Ident, former_definition_types_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, @@ -76,7 +78,7 @@ pub fn mutator = Example of custom mutator impl< {} > former::FormerMutator -for {} < {} > +for {former_definition_types} < {} > where {} {{ @@ -88,11 +90,16 @@ where }} "#, format!( "{}", qt!{ #former_definition_types_generics_impl } ), - former_definition_types, format!( "{}", qt!{ #former_definition_types_generics_ty } ), format!( "{}", qt!{ #former_definition_types_generics_where } ), ); - println!( "{hint}" ); + // println!( "{hint}" ); + let about = format! + ( +r#"derive : Former +structure : {stru}"#, + ); + diag::report_print( about, original_input, hint ); }; Ok( former_mutator_code ) @@ -296,6 +303,7 @@ specific needs of the broader forming context. It mandates the implementation of field.former_field_setter ( &stru, + &original_input, &struct_generics_impl, &struct_generics_ty, &struct_generics_where, @@ -304,7 +312,6 @@ specific needs of the broader forming context. It mandates the implementation of &former_generics_ty, &former_generics_where, &former_storage, - &original_input, ), )}).multiunzip(); @@ -315,6 +322,8 @@ specific needs of the broader forming context. It mandates the implementation of let former_mutator_code = mutator ( + &stru, + &original_input, &struct_attrs.mutator, &former_definition_types, &former_definition_types_generics_impl, diff --git a/module/core/former_meta/src/derive_former/field.rs b/module/core/former_meta/src/derive_former/field.rs index 0a8e2149fb..b6bf5a9ce3 100644 --- a/module/core/former_meta/src/derive_former/field.rs +++ b/module/core/former_meta/src/derive_former/field.rs @@ -331,6 +331,7 @@ scalar_setter_required ( &self, stru : &syn::Ident, + original_input : &proc_macro::TokenStream, struct_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, struct_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, struct_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, @@ -339,7 +340,6 @@ scalar_setter_required former_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, former_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, former_storage : &syn::Ident, - original_input : &proc_macro::TokenStream, ) -> Result< ( TokenStream, TokenStream ) > { @@ -348,8 +348,10 @@ scalar_setter_required let namespace_code = qt! {}; let setters_code = self.scalar_setter ( + stru, former, former_storage, + original_input, ); // subform scalar setter @@ -364,6 +366,7 @@ scalar_setter_required struct_generics_impl, struct_generics_ty, struct_generics_where, + original_input, )?; ( qt! { #setters_code #setters_code2 }, qt! { #namespace_code #namespace_code2 } ) } @@ -404,6 +407,7 @@ scalar_setter_required struct_generics_impl, struct_generics_ty, struct_generics_where, + original_input, )?; ( qt! { #setters_code #setters_code2 }, qt! { #namespace_code #namespace_code2 } ) } @@ -440,8 +444,10 @@ scalar_setter_required pub fn scalar_setter ( &self, + stru : &syn::Ident, former : &syn::Ident, former_storage : &syn::Ident, + original_input : &proc_macro::TokenStream, ) -> TokenStream { @@ -455,7 +461,6 @@ scalar_setter_required let hint = format! ( r#" - impl< Definition > {former}< Definition > where Definition : former::FormerDefinition< Storage = {former_storage} >, @@ -470,12 +475,16 @@ where self }} }} - "#, format!( "{}", qt!{ #typ } ), ); - println!( "{hint}" ); - // xxx : use diag::report_print + let about = format! + ( +r#"derive : Former +structure : {stru} +field : {field_ident}"#, + ); + diag::report_print( about, original_input, hint ); } if !self.scalar_setter_required() @@ -678,7 +687,6 @@ where let hint = format! ( r#" - /// The collection setter provides a collection setter that returns a CollectionFormer tailored for managing a collection of child entities. It employs a generic collection definition to facilitate operations on the entire collection, such as adding or updating elements. impl< Definition, > {former}< Definition, > @@ -698,7 +706,6 @@ where }} }} - "#, format!( "{}", qt!{ #( #params, )* } ), ); @@ -844,6 +851,7 @@ with the new content generated during the subforming process. struct_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, struct_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, struct_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, + original_input : &proc_macro::TokenStream, ) -> Result< ( TokenStream, TokenStream ) > { @@ -972,7 +980,6 @@ allowing for dynamic and flexible construction of the `{stru}` entity's {field_i let hint = format! ( r#" - /// Initializes and configures a subformer for adding named child entities. This method leverages an internal function /// to create and return a configured subformer instance. It allows for the dynamic addition of children with specific names, /// integrating them into the formation process of the parent entity. @@ -992,13 +999,14 @@ where }} "#, format!( "{}", qt!{ #entry_typ } ), - // former, - // former_storage, - // field_ident, - // subform_entry_name, ); - println!( "{hint}" ); - // xxx : use diag::report_print + let about = format! + ( +r#"derive : Former +structure : {stru} +field : {field_ident}"#, + ); + diag::report_print( about, original_input, hint ); } let doc = format! @@ -1106,12 +1114,9 @@ formation process of the `{stru}`. Ok( ( setters_code, namespace_code ) ) } - - /// Generates setter functions to subform scalar. + /// Generates setter functions to subform scalar and all corresponding helpers. /// /// See `tests/inc/former_tests/subform_scalar_manual.rs` for example of generated code. - /// - // xxx : improve documentation #[ inline ] pub fn subform_scalar_setter @@ -1124,6 +1129,7 @@ formation process of the `{stru}`. struct_generics_impl : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, struct_generics_ty : &syn::punctuated::Punctuated< syn::GenericParam, syn::token::Comma >, struct_generics_where : &syn::punctuated::Punctuated< syn::WherePredicate, syn::token::Comma >, + original_input : &proc_macro::TokenStream, ) -> Result< ( TokenStream, TokenStream ) > { @@ -1284,7 +1290,6 @@ former and end action types, ensuring a seamless developer experience when formi let hint = format! ( r#" - /// Extends `{former}` to include a method that initializes and configures a subformer for the '{field_ident}' field. /// This function demonstrates the dynamic addition of a named {field_ident}, leveraging a subformer to specify detailed properties. @@ -1298,17 +1303,16 @@ where self._{field_ident}_subform_scalar::< {0}Former< _ >, _, >().name( name ) }} }} - "#, format!( "{}", qt!{ #field_typ } ), - // former, - // former_storage, - // field_ident, - // subform_scalar_name, ); - println!( "{hint}" ); - // xxx : outdated - // xxx : use diag::report_print + let about = format! + ( +r#"derive : Former +structure : {stru} +field : {field_ident}"#, + ); + diag::report_print( about, original_input, hint ); } let doc = format! From 401a6bdb82659dd22e7912f98adcd3e65c38cd92 Mon Sep 17 00:00:00 2001 From: wandalen Date: Sun, 12 May 2024 21:40:06 +0300 Subject: [PATCH 24/24] former : introduce subform_scalar ready --- module/core/derive_tools/src/lib.rs | 31 ++++++-- .../inc/former_tests/a_primitives_manual.rs | 1 - .../{subformer_basic.rs => subform_basic.rs} | 0 ...er_collection.rs => subform_collection.rs} | 0 ...en2.rs => subform_collection_children2.rs} | 0 ...ubform_child.rs => subform_entry_child.rs} | 0 ...hildren2.rs => subform_entry_children2.rs} | 0 ...er_scalar_subform.rs => subform_scalar.rs} | 2 +- .../tests/inc/former_tests/subform_all.rs | 8 +- .../former_tests/subform_all_parametrized.rs | 10 +-- .../inc/former_tests/subform_all_private.rs | 8 +- .../inc/former_tests/subform_collection.rs | 2 +- .../subform_collection_implicit.rs | 2 +- .../former_tests/subform_collection_manual.rs | 2 +- .../former_tests/subform_collection_named.rs | 2 +- .../subform_collection_playground.rs | 4 +- .../subform_collection_setter_off.rs | 2 +- .../subform_collection_setter_on.rs | 4 +- .../tests/inc/former_tests/subform_entry.rs | 2 +- .../inc/former_tests/subform_entry_manual.rs | 3 +- .../inc/former_tests/subform_entry_named.rs | 2 +- .../subform_entry_named_manual.rs | 2 +- .../former_tests/subform_entry_setter_off.rs | 2 +- .../former_tests/subform_entry_setter_on.rs | 2 +- .../tests/inc/former_tests/subform_scalar.rs | 10 +-- .../inc/former_tests/subform_scalar_manual.rs | 9 +-- .../inc/former_tests/subform_scalar_name.rs | 73 +++++++++++++++++++ module/core/former/tests/inc/mod.rs | 5 +- 28 files changed, 134 insertions(+), 54 deletions(-) rename module/core/former/tests/inc/former_tests/only_test/{subformer_basic.rs => subform_basic.rs} (100%) rename module/core/former/tests/inc/former_tests/only_test/{subformer_collection.rs => subform_collection.rs} (100%) rename module/core/former/tests/inc/former_tests/only_test/{subformer_collection_children2.rs => subform_collection_children2.rs} (100%) rename module/core/former/tests/inc/former_tests/only_test/{subformer_subform_child.rs => subform_entry_child.rs} (100%) rename module/core/former/tests/inc/former_tests/only_test/{subformer_subform_children2.rs => subform_entry_children2.rs} (100%) rename module/core/former/tests/inc/former_tests/only_test/{subformer_scalar_subform.rs => subform_scalar.rs} (90%) create mode 100644 module/core/former/tests/inc/former_tests/subform_scalar_name.rs diff --git a/module/core/derive_tools/src/lib.rs b/module/core/derive_tools/src/lib.rs index 3e29da3f59..9401495344 100644 --- a/module/core/derive_tools/src/lib.rs +++ b/module/core/derive_tools/src/lib.rs @@ -2,13 +2,32 @@ #![ doc( html_logo_url = "https://raw.githubusercontent.com/Wandalen/wTools/master/asset/img/logo_v3_trans_square.png" ) ] #![ doc( html_favicon_url = "https://raw.githubusercontent.com/Wandalen/wTools/alpha/asset/img/logo_v3_trans_square_icon_small_v2.ico" ) ] #![ doc( html_root_url = "https://docs.rs/derive_tools/latest/derive_tools/" ) ] - -//! -//! Collection of derives which extend STD. -//! - #![ doc = include_str!( concat!( env!( "CARGO_MANIFEST_DIR" ), "/", "Readme.md" ) ) ] +// // xxx : implement derive new +// +// #[ derive( Debug, PartialEq, Default ) ] +// pub struct Property< Name > +// { +// name : Name, +// description : String, +// code : isize, +// } +// +// /// generated by new +// impl< Name > Property< Name > +// { +// #[ inline ] +// pub fn new< Description, Code >( name : Name, description : Description, code : Code ) -> Self +// where +// Name : core::convert::Into< Name >, +// Description : core::convert::Into< String >, +// Code : core::convert::Into< isize >, +// { +// Self { name : name.into(), description : description.into(), code : code.into() } +// } +// } + #[ cfg( feature = "enabled" ) ] pub mod wtools; @@ -56,7 +75,7 @@ mod derive_more // #[ cfg( feature = "derive_reflect" ) ] // pub mod reflect; -// use derive_tools_meta::Deref; +// use derive_tools_meta::Deref; // use derive_tools_meta::VariadicFrom; /// Namespace with dependencies. diff --git a/module/core/former/tests/inc/former_tests/a_primitives_manual.rs b/module/core/former/tests/inc/former_tests/a_primitives_manual.rs index 90e1290d6b..baafc6e1ae 100644 --- a/module/core/former/tests/inc/former_tests/a_primitives_manual.rs +++ b/module/core/former/tests/inc/former_tests/a_primitives_manual.rs @@ -203,7 +203,6 @@ where return result; } - // xxx : update description #[ inline( always ) ] pub fn new( on_end : Definition::End ) -> Self { diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_basic.rs b/module/core/former/tests/inc/former_tests/only_test/subform_basic.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/subformer_basic.rs rename to module/core/former/tests/inc/former_tests/only_test/subform_basic.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_collection.rs b/module/core/former/tests/inc/former_tests/only_test/subform_collection.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/subformer_collection.rs rename to module/core/former/tests/inc/former_tests/only_test/subform_collection.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_collection_children2.rs b/module/core/former/tests/inc/former_tests/only_test/subform_collection_children2.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/subformer_collection_children2.rs rename to module/core/former/tests/inc/former_tests/only_test/subform_collection_children2.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_subform_child.rs b/module/core/former/tests/inc/former_tests/only_test/subform_entry_child.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/subformer_subform_child.rs rename to module/core/former/tests/inc/former_tests/only_test/subform_entry_child.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_subform_children2.rs b/module/core/former/tests/inc/former_tests/only_test/subform_entry_children2.rs similarity index 100% rename from module/core/former/tests/inc/former_tests/only_test/subformer_subform_children2.rs rename to module/core/former/tests/inc/former_tests/only_test/subform_entry_children2.rs diff --git a/module/core/former/tests/inc/former_tests/only_test/subformer_scalar_subform.rs b/module/core/former/tests/inc/former_tests/only_test/subform_scalar.rs similarity index 90% rename from module/core/former/tests/inc/former_tests/only_test/subformer_scalar_subform.rs rename to module/core/former/tests/inc/former_tests/only_test/subform_scalar.rs index 7753f38dd5..90ba084724 100644 --- a/module/core/former/tests/inc/former_tests/only_test/subformer_scalar_subform.rs +++ b/module/core/former/tests/inc/former_tests/only_test/subform_scalar.rs @@ -1,6 +1,6 @@ #[ test ] -fn child() +fn subforme_scalar() { let got = Parent::former() diff --git a/module/core/former/tests/inc/former_tests/subform_all.rs b/module/core/former/tests/inc/former_tests/subform_all.rs index b201f63c02..6a4cd78a03 100644 --- a/module/core/former/tests/inc/former_tests/subform_all.rs +++ b/module/core/former/tests/inc/former_tests/subform_all.rs @@ -16,9 +16,9 @@ pub struct Child // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent { - #[ subform_entry( name = _child ) ] - #[ subform_collection( name = children2 ) ] #[ scalar( name = children3 ) ] + #[ subform_collection( name = children2 ) ] + #[ subform_entry( name = _child ) ] children : Vec< Child >, } @@ -51,6 +51,6 @@ where // == end of generated -include!( "./only_test/subformer_subform_child.rs" ); -include!( "./only_test/subformer_collection_children2.rs" ); +include!( "./only_test/subform_entry_child.rs" ); +include!( "./only_test/subform_collection_children2.rs" ); include!( "./only_test/scalar_children3.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_all_parametrized.rs b/module/core/former/tests/inc/former_tests/subform_all_parametrized.rs index 9d45778855..3f754f164c 100644 --- a/module/core/former/tests/inc/former_tests/subform_all_parametrized.rs +++ b/module/core/former/tests/inc/former_tests/subform_all_parametrized.rs @@ -20,9 +20,9 @@ where // #[ derive( Debug, Default, PartialEq ) ] pub struct Parent< 'child > { - #[ subform_entry( name = _child ) ] - #[ subform_collection( name = children2 ) ] #[ scalar( name = children3 ) ] + #[ subform_collection( name = children2 ) ] + #[ subform_entry( name = _child ) ] children : Vec< Child< 'child, str > >, } @@ -129,6 +129,6 @@ fn scalar() } -// include!( "./only_test/subformer_subform_child.rs" ); -// include!( "./only_test/subformer_collection_children2.rs" ); -// include!( "./only_test/subformer_scalar_children3.rs" ); +// include!( "./only_test/subform_entry_child.rs" ); +// include!( "./only_test/subform_collection_children2.rs" ); +// include!( "./only_test/subform_scalar_children3.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_all_private.rs b/module/core/former/tests/inc/former_tests/subform_all_private.rs index dda702f5d0..df7f1e4738 100644 --- a/module/core/former/tests/inc/former_tests/subform_all_private.rs +++ b/module/core/former/tests/inc/former_tests/subform_all_private.rs @@ -16,9 +16,9 @@ struct Child // #[ derive( Debug, Default, PartialEq ) ] struct Parent { - #[ subform_entry( name = _child ) ] - #[ subform_collection( name = children2 ) ] #[ scalar( name = children3 ) ] + #[ subform_collection( name = children2 ) ] + #[ subform_entry( name = _child ) ] children : Vec< Child >, } @@ -51,6 +51,6 @@ where // == end of generated -include!( "./only_test/subformer_subform_child.rs" ); -include!( "./only_test/subformer_collection_children2.rs" ); +include!( "./only_test/subform_entry_child.rs" ); +include!( "./only_test/subform_collection_children2.rs" ); include!( "./only_test/scalar_children3.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_collection.rs b/module/core/former/tests/inc/former_tests/subform_collection.rs index d9941e680b..782cc7f213 100644 --- a/module/core/former/tests/inc/former_tests/subform_collection.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection.rs @@ -24,4 +24,4 @@ pub struct Parent // == end of generated -include!( "./only_test/subformer_collection.rs" ); +include!( "./only_test/subform_collection.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_collection_implicit.rs b/module/core/former/tests/inc/former_tests/subform_collection_implicit.rs index d33101c283..101e5cd210 100644 --- a/module/core/former/tests/inc/former_tests/subform_collection_implicit.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_implicit.rs @@ -26,4 +26,4 @@ pub struct Parent // == end of generated -include!( "./only_test/subformer_collection.rs" ); +include!( "./only_test/subform_collection.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_collection_manual.rs b/module/core/former/tests/inc/former_tests/subform_collection_manual.rs index 6540adf77b..ee30f941b8 100644 --- a/module/core/former/tests/inc/former_tests/subform_collection_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_manual.rs @@ -106,4 +106,4 @@ where // == end of generated for Parent in context of attribute collection( former::VectorDefinition ) ] -include!( "./only_test/subformer_collection.rs" ); +include!( "./only_test/subform_collection.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_collection_named.rs b/module/core/former/tests/inc/former_tests/subform_collection_named.rs index 77c953de0f..1f06c4b6ea 100644 --- a/module/core/former/tests/inc/former_tests/subform_collection_named.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_named.rs @@ -40,4 +40,4 @@ where // == end of generated -include!( "./only_test/subformer_collection_children2.rs" ); +include!( "./only_test/subform_collection_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_collection_playground.rs b/module/core/former/tests/inc/former_tests/subform_collection_playground.rs index b4ae8e5828..0e3782a900 100644 --- a/module/core/former/tests/inc/former_tests/subform_collection_playground.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_playground.rs @@ -31,7 +31,7 @@ pub struct Property< Name > code : isize, } -// xxx : implement derive new +// zzz : implement derive new /// generated by new impl< Name > Property< Name > { @@ -109,4 +109,4 @@ where // == -include!( "./only_test/subformer_basic.rs" ); +include!( "./only_test/subform_basic.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_collection_setter_off.rs b/module/core/former/tests/inc/former_tests/subform_collection_setter_off.rs index e6aa9dc5d4..fa01385e98 100644 --- a/module/core/former/tests/inc/former_tests/subform_collection_setter_off.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_setter_off.rs @@ -48,4 +48,4 @@ where } -include!( "./only_test/subformer_collection_children2.rs" ); +include!( "./only_test/subform_collection_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_collection_setter_on.rs b/module/core/former/tests/inc/former_tests/subform_collection_setter_on.rs index 1afb93908c..0f35a3c2a0 100644 --- a/module/core/former/tests/inc/former_tests/subform_collection_setter_on.rs +++ b/module/core/former/tests/inc/former_tests/subform_collection_setter_on.rs @@ -41,5 +41,5 @@ where } -include!( "./only_test/subformer_scalar_children.rs" ); -include!( "./only_test/subformer_collection_children2.rs" ); +include!( "./only_test/subform_scalar_children.rs" ); +include!( "./only_test/subform_collection_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry.rs b/module/core/former/tests/inc/former_tests/subform_entry.rs index 417762626e..063fec5dc4 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry.rs @@ -46,4 +46,4 @@ where // == end of generated -include!( "./only_test/subformer_subform_child.rs" ); +include!( "./only_test/subform_entry_child.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry_manual.rs b/module/core/former/tests/inc/former_tests/subform_entry_manual.rs index 013b0b12b7..2a210b97bb 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_manual.rs @@ -118,7 +118,6 @@ where // Definition::Types : former::FormerDefinitionTypes< Storage = < Parent as former::EntityToStorage >::Storage >, { - // xxx : rename #[ inline( always ) ] pub fn _children_subform_entry< Former2, Definition2 >( self ) -> Former2 @@ -200,4 +199,4 @@ where // == end of generated for Parent in context of attribute subform -include!( "./only_test/subformer_subform_child.rs" ); +include!( "./only_test/subform_entry_child.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry_named.rs b/module/core/former/tests/inc/former_tests/subform_entry_named.rs index ee49598f06..37e2c79d55 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_named.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_named.rs @@ -59,4 +59,4 @@ where // == end of generated -include!( "./only_test/subformer_subform_child.rs" ); +include!( "./only_test/subform_entry_child.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs b/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs index d4131e8834..3d0542c592 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_named_manual.rs @@ -69,4 +69,4 @@ where // == end of generated for Parent in context of attribute subform -include!( "./only_test/subformer_subform_child.rs" ); +include!( "./only_test/subform_entry_child.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs b/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs index fdedd4c97d..ae08d3c05c 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_setter_off.rs @@ -46,4 +46,4 @@ where } -include!( "./only_test/subformer_subform_children2.rs" ); +include!( "./only_test/subform_entry_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs b/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs index 6eeea2827a..fd5608463e 100644 --- a/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs +++ b/module/core/former/tests/inc/former_tests/subform_entry_setter_on.rs @@ -41,4 +41,4 @@ where } include!( "./only_test/scalar_children.rs" ); -include!( "./only_test/subformer_subform_children2.rs" ); +include!( "./only_test/subform_entry_children2.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_scalar.rs b/module/core/former/tests/inc/former_tests/subform_scalar.rs index 996c0db1e7..bf081269fb 100644 --- a/module/core/former/tests/inc/former_tests/subform_scalar.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar.rs @@ -21,16 +21,8 @@ pub struct Parent child : Child, } -impl< Definition > ParentFormer< Definition > -where - Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, -{ - -} - // == begin of generated // == end of generated -include!( "./only_test/subformer_scalar_subform.rs" ); -// xxx : uncomment +include!( "./only_test/subform_scalar.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs index 6c795e2b7d..d0d8ef9608 100644 --- a/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs +++ b/module/core/former/tests/inc/former_tests/subform_scalar_manual.rs @@ -28,7 +28,7 @@ where { #[ inline( always ) ] - pub fn _child_scalar_subformer< Former2, Definition2 >( self ) -> + pub fn _child_subform_scalar< Former2, Definition2 >( self ) -> Former2 where Definition2 : former::FormerDefinition @@ -60,7 +60,7 @@ where pub fn child( self ) -> ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > { - self._child_scalar_subformer + self._child_subform_scalar ::< < Child as former::EntityToFormer< _ > >::Former, _, >() } @@ -137,7 +137,4 @@ where // == end of generated -include!( "./only_test/subformer_scalar_subform.rs" ); -// xxx : uncomment -// xxx : write few more tests to cover name, setter -// xxx : extend all test +include!( "./only_test/subform_scalar.rs" ); diff --git a/module/core/former/tests/inc/former_tests/subform_scalar_name.rs b/module/core/former/tests/inc/former_tests/subform_scalar_name.rs new file mode 100644 index 0000000000..87a0d52ded --- /dev/null +++ b/module/core/former/tests/inc/former_tests/subform_scalar_name.rs @@ -0,0 +1,73 @@ +#![ allow( dead_code ) ] + +use super::*; + +/// Child +#[ derive( Debug, Default, PartialEq, the_module::Former ) ] +pub struct Child +{ + name : String, + data : bool, +} + +/// Parent + +#[ derive( Debug, Default, PartialEq, the_module::Former ) ] +// #[ debug ] +// #[ derive( Debug, Default, PartialEq ) ] +pub struct Parent +{ + #[ subform_scalar( name = child2 ) ] + child : Child, +} + +impl< Definition > ParentFormer< Definition > +where + Definition : former::FormerDefinition< Storage = < Parent as former::EntityToStorage >::Storage >, +{ + + pub fn child() + { + } + + #[ inline( always ) ] + pub fn child3( self ) -> + ChildAsSubformer< Self, impl ChildAsSubformerEnd< Self > > + { + self._child_subform_scalar + ::< < Child as former::EntityToFormer< _ > >::Former, _, >() + } + +} + +// == begin of generated + +// == end of generated + +#[ test ] +fn subforme_scalar_2() +{ + + let got = Parent::former() + .child2().name( "a" ).data( true ).end() + .form(); + + let exp = Parent { child : Child { name : "a".to_string(), data : true } }; + a_id!( got, exp ); + +} + +#[ test ] +fn subforme_scalar_3() +{ + + let got = Parent::former() + .child3().name( "a" ).data( true ).end() + .form(); + + let exp = Parent { child : Child { name : "a".to_string(), data : true } }; + a_id!( got, exp ); + +} + +// qqq : write tests similar to `subform_all` which apply attributes `scalar`, `subform_entry` and `subform_scalar` on the same field and check all three attribtues don't interfere with each other diff --git a/module/core/former/tests/inc/mod.rs b/module/core/former/tests/inc/mod.rs index 0936faa6e2..9f94e5f37d 100644 --- a/module/core/former/tests/inc/mod.rs +++ b/module/core/former/tests/inc/mod.rs @@ -95,11 +95,12 @@ mod former_tests // = subform scalar - // xxx + #[ cfg( any( not( feature = "no_std" ) ) ) ] + mod subform_scalar_manual; #[ cfg( any( not( feature = "no_std" ) ) ) ] mod subform_scalar; #[ cfg( any( not( feature = "no_std" ) ) ) ] - mod subform_scalar_manual; + mod subform_scalar_name; // = subform entry