File: visualization_dsl.cpp

package info (click to toggle)
taskflow 3.9.0%2Bds-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 45,948 kB
  • sloc: cpp: 39,058; xml: 35,572; python: 12,935; javascript: 1,732; makefile: 59; sh: 16
file content (44 lines) | stat: -rw-r--r-- 1,282 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
// 2020/08/28 - Created by netcan: https://github.com/netcan
// This example demonstrates how to use 'dump' method to inspect
// a taskflow graph.
// use task dsl
#include <taskflow/taskflow.hpp>
#include <taskflow/dsl.hpp> // for support dsl

int main() {
  tf::Taskflow tf("Visualization Demo");

  // ------------------------------------------------------
  // Static Tasking
  // ------------------------------------------------------
  make_task((A), { std::cout << "TaskA\n"; };);
  make_task((B), { std::cout << "TaskB\n"; };);
  make_task((C), { std::cout << "TaskC\n"; };);
  make_task((D), { std::cout << "TaskD\n"; };);
  make_task((E), { std::cout << "TaskE\n"; };);

  auto tasks = build_taskflow(
    task(A)
      -> fork_tasks(B, C)
      -> task(D),
    merge_tasks(A, B)
      -> task(E)
  )(tf);

  std::cout << "[dump without name assignment]\n";
  tf.dump(std::cout);

  std::cout << "[dump with name assignment]\n";
  tasks.get_task<A>().name("A");
  tasks.get_task<B>().name("B");
  tasks.get_task<C>().name("C");
  tasks.get_task<D>().name("D");
  tasks.get_task<E>().name("E");
  tf.dump(std::cout);

  // ------------------------------------------------------
  // Dynamic Tasking
  // ------------------------------------------------------

  return 0;
}