summaryrefslogtreecommitdiff
path: root/src/buildtool/build_engine/base_maps/module_name.hpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/buildtool/build_engine/base_maps/module_name.hpp')
-rw-r--r--src/buildtool/build_engine/base_maps/module_name.hpp36
1 files changed, 36 insertions, 0 deletions
diff --git a/src/buildtool/build_engine/base_maps/module_name.hpp b/src/buildtool/build_engine/base_maps/module_name.hpp
new file mode 100644
index 00000000..26465bf6
--- /dev/null
+++ b/src/buildtool/build_engine/base_maps/module_name.hpp
@@ -0,0 +1,36 @@
+#ifndef INCLUDED_SRC_BUILDTOOL_BUILD_ENGINE_BASE_MAPS_MODULE_NAME_HPP
+#define INCLUDED_SRC_BUILDTOOL_BUILD_ENGINE_BASE_MAPS_MODULE_NAME_HPP
+
+#include "src/utils/cpp/hash_combine.hpp"
+
+namespace BuildMaps::Base {
+
+struct ModuleName {
+ std::string repository{};
+ std::string module{};
+
+ ModuleName(std::string repository, std::string module)
+ : repository{std::move(repository)}, module{std::move(module)} {}
+
+ [[nodiscard]] auto operator==(ModuleName const& other) const noexcept
+ -> bool {
+ return module == other.module && repository == other.repository;
+ }
+};
+} // namespace BuildMaps::Base
+
+namespace std {
+template <>
+struct hash<BuildMaps::Base::ModuleName> {
+ [[nodiscard]] auto operator()(
+ const BuildMaps::Base::ModuleName& t) const noexcept -> std::size_t {
+ size_t seed{};
+ hash_combine<std::string>(&seed, t.repository);
+ hash_combine<std::string>(&seed, t.module);
+ return seed;
+ }
+};
+
+} // namespace std
+
+#endif