summaryrefslogtreecommitdiff
path: root/src/buildtool/progress_reporting/progress.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/buildtool/progress_reporting/progress.hpp')
-rw-r--r--src/buildtool/progress_reporting/progress.hpp71
1 files changed, 71 insertions, 0 deletions
diff --git a/src/buildtool/progress_reporting/progress.hpp b/src/buildtool/progress_reporting/progress.hpp
new file mode 100644
index 00000000..5940c880
--- /dev/null
+++ b/src/buildtool/progress_reporting/progress.hpp
@@ -0,0 +1,71 @@
+#ifndef INCLUDED_SRC_BUILDTOOL_PROGRESS_REPORTING_PROGRESS_HPP
+#define INCLUDED_SRC_BUILDTOOL_PROGRESS_REPORTING_PROGRESS_HPP
+
+#include <cstdint>
+#include <mutex>
+#include <string>
+#include <unordered_map>
+#include <utility>
+#include <vector>
+
+#include "src/buildtool/build_engine/target_map/configured_target.hpp"
+#include "src/buildtool/logging/logger.hpp"
+
+class Progress {
+ public:
+ [[nodiscard]] static auto Instance() noexcept -> Progress& {
+ static Progress instance{};
+ return instance;
+ }
+
+ void Start(const std::string& id) noexcept {
+ std::unique_lock lock(m_);
+ ++prio_;
+ try {
+ running_.emplace(id, prio_);
+ } catch (...) {
+ Logger::Log(LogLevel::Warning,
+ "Internal error in progress tracking; progress reports "
+ "might be incorrect.");
+ }
+ }
+ void Stop(const std::string& id) noexcept {
+ std::unique_lock lock(m_);
+ running_.erase(id);
+ }
+
+ auto Sample() -> std::string {
+ std::unique_lock lock(m_);
+ std::string result;
+ uint64_t started = prio_ + 1;
+ for (auto const& it : running_) {
+ if (it.second < started) {
+ result = it.first;
+ started = it.second;
+ }
+ }
+ return result;
+ }
+
+ // Return a reference to the origin map. It is the responsibility
+ // of the caller to ensure that access happens only happens in a
+ // single-threaded context.
+ auto OriginMap() -> std::unordered_map<
+ std::string,
+ std::vector<
+ std::pair<BuildMaps::Target::ConfiguredTarget, std::size_t>>>& {
+ return origin_map_;
+ }
+
+ private:
+ uint64_t prio_{};
+ std::mutex m_{};
+ std::unordered_map<std::string, uint64_t> running_{};
+ std::unordered_map<
+ std::string,
+ std::vector<
+ std::pair<BuildMaps::Target::ConfiguredTarget, std::size_t>>>
+ origin_map_;
+};
+
+#endif