---
source: hydroflow/tests/surface_examples.rs
expression: output
---
%%{init:{'theme':'base','themeVariables':{'clusterBkg':'#ddd','clusterBorder':'#888'}}}%%
flowchart TD
classDef pullClass fill:#8af,stroke:#000,text-align:left,white-space:pre
classDef pushClass fill:#ff8,stroke:#000,text-align:left,white-space:pre
classDef otherClass fill:#fdc,stroke:#000,text-align:left,white-space:pre
linkStyle default stroke:#aaa
1v1[\"(1v1) source_iter(vec![0])
"/]:::pullClass
2v1[\"(2v1) source_stream(edges_recv)
"/]:::pullClass
3v1[\"(3v1) map(|v| (v, ()))
"/]:::pullClass
4v1[\"(4v1) join()
"/]:::pullClass
5v1[\"(5v1) flat_map(|(src, (_, dst))| [src, dst])
"/]:::pullClass
6v1[\"(6v1) unique()
"/]:::pullClass
7v1[/"(7v1) for_each(|n| println!("Reached: {}", n))
"\]:::pushClass
3v1-->|0|4v1
1v1-->3v1
2v1-->|1|4v1
4v1-->5v1
6v1-->7v1
5v1-->6v1
subgraph sg_1v1 ["sg_1v1 stratum 0"]
1v1
2v1
3v1
4v1
5v1
6v1
7v1
subgraph sg_1v1_var_my_join ["var my_join"]
4v1
5v1
end
subgraph sg_1v1_var_origin ["var origin"]
1v1
end
subgraph sg_1v1_var_stream_of_edges ["var stream_of_edges"]
2v1
end
end
Reached: 0
Reached: 1
Reached: 3