3 releases
0.1.2 | Jul 3, 2021 |
---|---|
0.1.1 | Jun 28, 2021 |
0.1.0 | Jun 28, 2021 |
#1176 in Data structures
7KB
61 lines
Cd
: A "smart pointer" that tracks changes to the data it owns.
Usage
use changed::Cd;
// Create the change tracker with an i32
let mut test: Changed<i32> = Changed::new(20);
// Mutate it (calling deref_mut through the *)
*test += 5;
// changed() reports whether or not it was changed
assert!(test.changed());
// Reset it the tracker back to false
test.reset();
// Read the data
assert_eq!(*test, 25);
// That didn't trip the change detection!
assert!(!test.changed());
How it works
Technically, it doesn't track changes. It tracks calls to deref_mut()
so it is entirely possible to call deref_mut()
and not change it, giving a false positive.
Along with that, there is a function to mutate a Cd
without tripping change detection.
lib.rs
:
Cd
: A "smart pointer" that tracks changes to the data it owns.
Usage
use changed::Cd;
// Create the change tracker with an i32
let mut test: Cd<i32> = Cd::new(20);
// Mutate it (calling deref_mut through the *)
*test += 5;
// changed() reports whether or not it was changed
assert!(test.changed());
// Reset the tracker back to false
test.reset();
// Read the data
assert_eq!(*test, 25);
// That didn't trip the change detection!
assert!(!test.changed());
How it works
Technically, it doesn't track changes. It tracks calls to deref_mut()
so it is entirely possible to call deref_mut()
and not change it, giving a false positive.
Along with that, there is a function to mutate a Cd
without tripping change detection.