aboutsummaryrefslogtreecommitdiff
path: root/README.md
diff options
context:
space:
mode:
authorAlexander Kiryukhin <a.kiryukhin@mail.ru>2020-07-15 15:26:24 +0300
committerAlexander Kiryukhin <a.kiryukhin@mail.ru>2020-07-15 15:26:24 +0300
commit083fa85ee5301f3e330510e7ea1a279d4f47c208 (patch)
treee94872a6d30d472c9a310d4e9deed78d8f2736a1 /README.md
parent09339ddae33acc8ceaaf84ef8154da92d76985af (diff)
Updatev1.0.0
Diffstat (limited to 'README.md')
-rw-r--r--README.md44
1 files changed, 23 insertions, 21 deletions
diff --git a/README.md b/README.md
index efde801..4f43fab 100644
--- a/README.md
+++ b/README.md
@@ -9,19 +9,21 @@ Simple state machine. Inspired by [Symfony Workflow](https://github.com/symfony/
```go
o := new(ObjectImplementedPlaceer)
-w := NewWorkflow("initial")
-w.AddTransition("From initial to A", []Place{"initial"}, "A")
-w.AddTransition("From initial to B", []Place{"initial"}, "B")
-w.AddTransition("From A to C", []Place{"A"}, "C")
-w.AddTransition("From B,C to D", []Place{"B", "C"}, "D")
-w.AddTransition("From C,D to Finish", []Place{"C", "D"}, "Finish")
-
-w.Can(o, "From initial to A") // == nil
-w.Can(o, "From A to C") // == ErrCantApply
-
-w.GetEnabledTransitions(o) // []string{"From initial to A", "From initial to B"}
-w.Apply(o, "From inital to A") // o now at "A" place
-w.GetEnabledTransitions(o) // []string{"From A to C"}
+w := NewWorkflow("Start")
+w.AddTransition("Start", "A")
+w.AddTransition("Start", "B")
+w.AddTransition("A", "C")
+w.AddTransition("B", "D")
+w.AddTransition( "C", "D")
+w.AddTransition("C", "Finish")
+w.AddTransition("D", "Finish")
+
+w.Can(o, "A") // == nil
+w.Can(o, "C") // == ErrTransitionNotFound
+
+w.GetEnabledTransitions(o) // []Place{"A", "B"}
+w.Apply(o, "A") // o now at "A" place
+w.GetEnabledTransitions(o) // []Place{"C"}
w.DumpToDot() // See above
```
@@ -30,14 +32,14 @@ w.DumpToDot() // See above
```
digraph {
- initial[color="blue"];
- initial -> A[label="From initial to A"];
- initial -> B[label="From initial to B"];
- A -> C[label="From A to C"];
- B -> D[label="From B,C to D"];
- C -> D[label="From B,C to D"];
- C -> Finish[label="From C,D to Finish"];
- D -> Finish[label="From C,D to Finish"];
+ Start[color="blue"]
+ Start -> A[label="Start → A"];
+ Start -> B[label="Start → B"];
+ A -> C[label="A → C"];
+ B -> D[label="B → D"];
+ C -> D[label="C → D"];
+ C -> Finish[label="C → Finish"];
+ D -> Finish[label="D → Finish"];
}
```