Compare commits
2 Commits
3d82c58a51
...
16d7190a1d
Author | SHA1 | Date |
---|---|---|
annieversary | 16d7190a1d | |
annieversary | 0d91633f2b |
|
@ -0,0 +1,48 @@
|
||||||
|
use bad_optics::{lenses::*, prisms::*, traversals::*};
|
||||||
|
|
||||||
|
#[derive(Debug, PartialEq, Clone)]
|
||||||
|
struct MyStruct {
|
||||||
|
hey: (u8, (u8, [Option<i32>; 5])),
|
||||||
|
}
|
||||||
|
|
||||||
|
fn main() {
|
||||||
|
// make a lens that accesses `hey` in `MyStruct`
|
||||||
|
let hey = lens(
|
||||||
|
|hello: MyStruct| hello.hey,
|
||||||
|
|mut hello: MyStruct, v| {
|
||||||
|
hello.hey = v;
|
||||||
|
hello
|
||||||
|
},
|
||||||
|
);
|
||||||
|
|
||||||
|
// the thing we want to access
|
||||||
|
let thing: (MyStruct, &'static str) = (
|
||||||
|
MyStruct {
|
||||||
|
hey: (1, (2, [None, Some(1), Some(2), None, Some(4)])),
|
||||||
|
},
|
||||||
|
"hello",
|
||||||
|
);
|
||||||
|
|
||||||
|
let array_lens = _0 // access the first element in the tuple
|
||||||
|
+ hey // access hey
|
||||||
|
+ _1 // access the second element in the tuple
|
||||||
|
+ _1; // access the second element in the tuple
|
||||||
|
|
||||||
|
assert_eq!(array_lens(thing.clone()).len(), 5);
|
||||||
|
|
||||||
|
let lens = array_lens
|
||||||
|
+ each // access each element of the [Option<i32>; 5] array
|
||||||
|
+ _Some; // access the ones that are Some;
|
||||||
|
|
||||||
|
assert_eq!(lens(thing.clone()), vec![1, 2, 4]);
|
||||||
|
|
||||||
|
assert_eq!(
|
||||||
|
lens(thing, |v| v + 10),
|
||||||
|
(
|
||||||
|
MyStruct {
|
||||||
|
hey: (1, (2, [None, Some(11), Some(12), None, Some(14)])),
|
||||||
|
},
|
||||||
|
"hello",
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
|
@ -0,0 +1,12 @@
|
||||||
|
#[macro_export]
|
||||||
|
macro_rules! field_lens {
|
||||||
|
($type:ident, $field:ident) => {
|
||||||
|
lens(
|
||||||
|
|v: $type| v.$field,
|
||||||
|
|mut u: $type, v| {
|
||||||
|
u.$field = v;
|
||||||
|
u
|
||||||
|
},
|
||||||
|
)
|
||||||
|
};
|
||||||
|
}
|
|
@ -1,3 +1,5 @@
|
||||||
|
mod fields;
|
||||||
|
|
||||||
mod identity;
|
mod identity;
|
||||||
pub use identity::id;
|
pub use identity::id;
|
||||||
|
|
||||||
|
@ -164,6 +166,18 @@ mod tests {
|
||||||
assert_eq!(l(hello), 8);
|
assert_eq!(l(hello), 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[test]
|
||||||
|
fn can_make_lens_for_field() {
|
||||||
|
// making a lens
|
||||||
|
let l = crate::field_lens!(Hello, hey);
|
||||||
|
|
||||||
|
let hello = Hello { hey: 8 };
|
||||||
|
assert_eq!(l(hello), 8);
|
||||||
|
|
||||||
|
let hello = Hello { hey: 8 };
|
||||||
|
assert_eq!(l(hello, |v| v + 1), Hello { hey: 9 });
|
||||||
|
}
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn can_make_lens_out_of_funcs() {
|
fn can_make_lens_out_of_funcs() {
|
||||||
// making a lens
|
// making a lens
|
||||||
|
|
Loading…
Reference in New Issue