Name |
Date |
Size |
#Lines |
LOC |
||
---|---|---|---|---|---|---|
.. | - | - | ||||
LICENSES/ | 03-May-2024 | - | 203 | 169 | ||
examples/ | 03-May-2024 | - | 76 | 59 | ||
src/ | 03-May-2024 | - | 224 | 64 | ||
tests/ | 03-May-2024 | - | 841 | 670 | ||
Android.bp | D | 03-May-2024 | 1 KiB | 46 | 42 | |
CHANGELOG.md | D | 03-May-2024 | 249 | 10 | 3 | |
Cargo.lock | D | 03-May-2024 | 16.5 KiB | 373 | 331 | |
Cargo.toml | D | 03-May-2024 | 1.3 KiB | 52 | 44 | |
Cargo.toml.orig | D | 03-May-2024 | 829 | 35 | 29 | |
LICENSE | D | 03-May-2024 | 11.1 KiB | 203 | 169 | |
METADATA | D | 03-May-2024 | 359 | 20 | 19 | |
MODULE_LICENSE_APACHE2 | D | 03-May-2024 | 0 | |||
OWNERS | D | 03-May-2024 | 65 | 3 | 2 | |
README.md | D | 03-May-2024 | 2.9 KiB | 99 | 70 | |
cargo2android.json | D | 03-May-2024 | 36 | 5 | 4 |
README.md
1<!--- 2Copyright (C) 2020 Robin Krahl <robin.krahl@ireas.org> 3SPDX-License-Identifier: CC0-1.0 4--> 5 6# merge-rs 7 8The `merge` crate provides the `Merge` trait that can be used to merge multiple 9values into one: 10 11```rust 12trait Merge { 13 fn merge(&mut self, other: Self); 14} 15``` 16 17`Merge` is implemented for `Option` and can be derived for structs: 18 19<!-- should be kept in sync with examples/user.rs --> 20```rust 21use merge::Merge; 22 23#[derive(Merge)] 24struct User { 25 // Fields with the skip attribute are skipped by Merge 26 #[merge(skip)] 27 pub name: &'static str, 28 29 // The Merge implementation for Option replaces its value if it is None 30 pub location: Option<&'static str>, 31 32 // The strategy attribute is used to customize the merge behavior 33 #[merge(strategy = merge::vec::append)] 34 pub groups: Vec<&'static str>, 35} 36 37let defaults = User { 38 name: "", 39 location: Some("Internet"), 40 groups: vec!["rust"], 41}; 42let mut ferris = User { 43 name: "Ferris", 44 location: None, 45 groups: vec!["mascot"], 46}; 47ferris.merge(defaults); 48 49assert_eq!("Ferris", ferris.name); 50assert_eq!(Some("Internet"), ferris.location); 51assert_eq!(vec!["mascot", "rust"], ferris.groups); 52``` 53 54A merge strategy is a function with the signature `fn merge<T>(left: &mut T, 55right: T)` that merges `right` into `left`. The `merge` crate provides 56strategies for the most common types, but you can also define your own 57strategies. 58 59The trait can be used to merge configuration from different sources, for 60example environment variables, multiple configuration files and command-line 61arguments, see the `args.rs` example. 62 63## Features 64 65This crate has the following features: 66 67- `derive` (default): Enables the derive macro for the `Merge` trait using the 68 `merge_derive` crate. 69- `num` (default): Enables the merge strategies in the `num` module that 70 require the `num_traits` crate. 71- `std` (default): Enables the merge strategies in the `vec` module that 72 require the standard library. If this feature is not set, `merge` is a 73 `no_std` library. 74 75## Minimum Supported Rust Version 76 77This crate supports Rust 1.36.0 or later. 78 79## Contact 80 81For bug reports, patches, feature requests and other messages, please send a 82mail to [~ireas/public-inbox@lists.sr.ht][] using the `[merge-rs]` prefix in 83the subject. 84 85## License 86 87This project is dual-licensed under the [Apache-2.0][] and [MIT][] licenses. 88The documentation and configuration files contained in this repository are 89licensed under the [Creative Commons Zero][CC0] license. You can find a copy 90of the license texts in the `LICENSES` directory. 91 92`merge-rs` complies with [version 3.0 of the REUSE specification][reuse]. 93 94[~ireas/public-inbox@lists.sr.ht]: mailto:~ireas/public-inbox@lists.sr.ht 95[Apache-2.0]: https://opensource.org/licenses/Apache-2.0 96[MIT]: https://opensource.org/licenses/MIT 97[CC0]: https://creativecommons.org/publicdomain/zero/1.0/ 98[reuse]: https://reuse.software/practices/3.0/ 99