Functional programming in Rust. Still largely a WIP.
Hopefully, make things easier by allowing stuff like this:
```rust use frust::monoid::*;
let v = vec![Some(1), Some(3)]; asserteq!(combineall(&v), Some(4));
// Slightly more magical let t1 = (1, 2.5f32, String::from("hi"), Some(3)); let t2 = (1, 2.5f32, String::from(" world"), None); let t3 = (1, 2.5f32, String::from(", goodbye"), Some(10)); let tuples = vec![t1, t2, t3];
let expected = (3, 7.5f32, String::from("hi world, goodbye"), Some(13)); asserteq!(combineall(&tuples), expected); ```
Things that can be combined.
```rust use frust::semigroup::*;
assert_eq!(Some(1).combine(&Some(2)), Some(3));
asserteq!(All(3).combine(&All(5)), All(1)); // bit-wise && asserteq!(All(true).combine(&All(false)), All(false)); ```
Things that can be combined and have an empty/id value.
```rust use frust::monoid::*;
let t1 = (1, 2.5f32, String::from("hi"), Some(3)); let t2 = (1, 2.5f32, String::from(" world"), None); let t3 = (1, 2.5f32, String::from(", goodbye"), Some(10)); let tuples = vec![t1, t2, t3];
let expected = (3, 7.5f32, String::from("hi world, goodbye"), Some(13)); asserteq!(combineall(&tuples), expected)
let productnums = vec![Product(2), Product(3), Product(4)]; asserteq!(combineall(&productnums), Product(24)) ```
Statically typed heterogeneous lists. Pop as much as you want from one of these; everything remains typed.
```rust
use frust::hlist::*;
let h = hlist![true, "hello", Some(41)]; let (h1, tail1) = h.pop(); asserteq!(h1, true); asserteq!(tail1, hlist!["hello", Some(41)]); ```
It makes sense to start by implementing things that are useful even for idiomatic Rust usage (efficient, and safe). The following might be nice to have:
These are not implemented at all, nor do I know for sure if they
are possible given that Rust has no support for Higher Kinded Types. In addition,
Rustaceans are used to calling iter()
on collections to get a lazy view,
manipulating their lists, and then doing a collect()
at the end to keep things efficient.
The use of these following structures maybe limited in that context.
Functor
Monad
Apply
Applicative
Show
, Monoid
, HList
, and Semigroup
are at least partially (mostly?) implemented.
Benchmarks would be nice but they're an unstable feature, so perhaps in a different branch.
Scalaz, Cats, Haskell, the usual suspects ;)
Yes please !
The following are considered important, in keeping with the spirit of Rust and functional programming: