summaryrefslogtreecommitdiff
path: root/competition/multilog.h
diff options
context:
space:
mode:
authorTom Smeding <tom.smeding@gmail.com>2018-07-21 22:03:31 +0200
committerTom Smeding <tom.smeding@gmail.com>2018-07-21 22:03:31 +0200
commitf0b6d1b9c46578183b427bcec4bbe99ab10c7b97 (patch)
tree111df40d4485f7dc7a66d0d463688021474512c1 /competition/multilog.h
parent53291958e0cda68ed762c0dfb36c0602f876c06d (diff)
competition: reorganisation and multithread
Diffstat (limited to 'competition/multilog.h')
-rw-r--r--competition/multilog.h32
1 files changed, 32 insertions, 0 deletions
diff --git a/competition/multilog.h b/competition/multilog.h
new file mode 100644
index 0000000..ba0ff4d
--- /dev/null
+++ b/competition/multilog.h
@@ -0,0 +1,32 @@
+#pragma once
+
+#include <vector>
+#include <string_view>
+#include <mutex>
+
+using namespace std;
+
+
+// Access is thread-safe
+class MultiLog {
+ struct Item {
+ int id;
+ string line;
+ bool complete = false;
+
+ Item();
+ };
+
+ mutex mut;
+ vector<Item> items;
+
+ // Methods assume mutex is taken.
+ size_t findId(int id);
+ void redrawLine(size_t idx);
+
+public:
+ // Returns id of new item
+ int add(const string_view prefix);
+ void append(int id, const string_view text);
+ void complete(int id);
+};