Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/JoshMcguigan/arr_macro
Initialize arrays with ease!
https://github.com/JoshMcguigan/arr_macro
Last synced: 5 days ago
JSON representation
Initialize arrays with ease!
- Host: GitHub
- URL: https://github.com/JoshMcguigan/arr_macro
- Owner: JoshMcguigan
- License: apache-2.0
- Created: 2018-12-23T04:03:15.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-01-05T22:25:45.000Z (almost 2 years ago)
- Last Synced: 2024-04-24T09:19:51.561Z (7 months ago)
- Language: Rust
- Size: 14.6 KB
- Stars: 84
- Watchers: 7
- Forks: 5
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE.txt
Awesome Lists containing this project
README
# Array Macro [![Build Status](https://api.travis-ci.org/JoshMcguigan/arr_macro.svg?branch=master)](https://travis-ci.org/JoshMcguigan/arr_macro) [![crates.io badge](https://img.shields.io/crates/v/arr_macro.svg)](https://crates.io/crates/arr_macro)
Array macro helps initialize arrays. It is useful when initializing large arrays (greater than 32 elements), or arrays of types which do not implement the copy or default traits.
Array macro is implemented in 100% safe Rust.
For further background on the motivation behind this crate, check out [this blog post](https://www.joshmcguigan.com/blog/array-initialization-rust/).
## Usage
```rust
use arr_macro::arr;fn main() {
let x: [Option; 3] = arr![None; 3];
assert_eq!(
[None, None, None],
x
);// works with all enum types (and impl copy is not required)
#[allow(dead_code)]
enum MyEnum {
A,
B
}
let _: [MyEnum; 33] = arr![MyEnum::A; 33];// Vec::new()
let _: [Vec; 33] = arr![Vec::new(); 33];// or your own struct type
// and you can even use a counter to behave differently based on the array index
#[derive(Debug)]
struct MyStruct {
member: u16,
}
impl MyStruct {
fn new(member: u16) -> Self {
MyStruct { member }
}
}
let mut i = 0u16;
let x: [MyStruct; 33] = arr![MyStruct::new({i += 1; i - 1}); 33];assert_eq!(0, x[0].member);
assert_eq!(1, x[1].member);
assert_eq!(2, x[2].member);
}
```## License
Licensed under either of
* Apache License, Version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0)
* MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT)at your option.
### Contribution
Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you, as defined in the Apache-2.0 license, shall be dual licensed as above, without any additional terms or conditions.