Parsing rule strings of life-like and other cellular automata.
Currently the following rules are supported:
B3/S23
.B2ci3ai4c8/S02ae3eijkq4iz5ar6i7e
.MAPARYXfhZofugWaH7oaIDogBZofuhogOiAaIDogIAAgAAWaH7oaIDogGiA6ICAAIAAaIDogIAAgACAAIAAAAAAAA
.B2/S34H
.B2o3-o4m/S12m3o4m5H
.MAPFgFoF2gXgH5oF4B+gH4A6AH
.B2/S013V
.MAPHmlphg
.3457/357/5
.For non-Generations rules, four different notations are supported:
B3/S23
)23/3
)MAPARYXfhZofugWaH7oaIDogBZofuhogOiAaIDogIAAgAAWaH7oaIDogGiA6ICAAIAAaIDogIAAgACAAIAAAAAAAA
)For Generations rules, four different notations are supported:
B357/S3457/C5
)3457/357/5
)g5b357s3457
)MAPARYBFxZpF38WaRd/aZZ//hZpF39pln/+aZZ//pZp/ukWaRd/aZZ//mmWf/6Waf7paZZ//pZp/umWaf7paZbplg/5
)Please refer to Life Wiki for detailed definitions and notations of these rule strings.
```rust use ca_rules::ParseLife;
// Define a struct for your rule:
struct Rule {
b: Vec
// Implement a parser trait for your rule:
// The choice of the trait depends on the type of rules you want to parse.
impl ParseLife for Rule {
// Implement a function to construct the rule from b and s data:
fn from_bs(b: Vec
// Then you can parse a rule string: let life = Rule::parserule("B3/S23").unwrap(); asserteq!( life, Rule { b: vec![3], s: vec![2, 3], } ) ```
For details, please refer to the doc.