commit 229aa88: [Minor] Move utilities to a separate header

Vsevolod Stakhov vsevolod at highsecure.ru
Thu Mar 11 19:42:11 UTC 2021


Author: Vsevolod Stakhov
Date: 2021-03-11 15:35:04 +0000
URL: https://github.com/rspamd/rspamd/commit/229aa886d9288f13ac4f9f6cf4ea2df53723b3a7 (HEAD -> master)

[Minor] Move utilities to a separate header

---
 src/libserver/css/css_rule.hxx | 31 +---------------------
 src/libutil/cxx/util.hxx       | 58 ++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 59 insertions(+), 30 deletions(-)

diff --git a/src/libserver/css/css_rule.hxx b/src/libserver/css/css_rule.hxx
index fa9f2a78e..dbd4fb1c7 100644
--- a/src/libserver/css/css_rule.hxx
+++ b/src/libserver/css/css_rule.hxx
@@ -22,6 +22,7 @@
 #include "css_property.hxx"
 #include "css_parser.hxx"
 #include "contrib/robin-hood/robin_hood.h"
+#include "libutil/cxx/util.hxx"
 #include <vector>
 #include <memory>
 
@@ -75,36 +76,6 @@ public:
 
 namespace rspamd::css {
 
-/*
- * We have to define transparent hash and compare methods
- *
- * TODO: move to some utility library
- */
-template<typename T>
-struct shared_ptr_equal {
-	using is_transparent = void; /* We want to find values in a set of shared_ptr by reference */
-	auto operator()(const std::shared_ptr<T> &a, const std::shared_ptr<T> &b) const {
-		return (*a) == (*b);
-	}
-	auto operator()(const std::shared_ptr<T> &a, const T &b) const {
-		return (*a) == b;
-	}
-	auto operator()(const T &a, const std::shared_ptr<T> &b) const {
-		return a == (*b);
-	}
-};
-
-template<typename T>
-struct shared_ptr_hash {
-	using is_transparent = void; /* We want to find values in a set of shared_ptr by reference */
-	auto operator()(const std::shared_ptr<T> &a) const {
-		return std::hash<T>()(*a);
-	}
-	auto operator()(const T &a) const {
-		return std::hash<T>()(a);
-	}
-};
-
 class css_declarations_block {
 public:
 	using rule_shared_ptr = std::shared_ptr<css_rule>;
diff --git a/src/libutil/cxx/util.hxx b/src/libutil/cxx/util.hxx
new file mode 100644
index 000000000..a61399977
--- /dev/null
+++ b/src/libutil/cxx/util.hxx
@@ -0,0 +1,58 @@
+/*-
+ * Copyright 2021 Vsevolod Stakhov
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *   http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+#ifndef RSPAMD_UTIL_HXX
+#define RSPAMD_UTIL_HXX
+
+#pragma once
+
+#include <memory>
+
+/*
+ * Common C++ utilities
+ */
+
+namespace rspamd {
+/*
+ * Transparent smart pointers hashing
+ */
+template<typename T>
+struct shared_ptr_equal {
+	using is_transparent = void; /* We want to find values in a set of shared_ptr by reference */
+	auto operator()(const std::shared_ptr<T> &a, const std::shared_ptr<T> &b) const {
+		return (*a) == (*b);
+	}
+	auto operator()(const std::shared_ptr<T> &a, const T &b) const {
+		return (*a) == b;
+	}
+	auto operator()(const T &a, const std::shared_ptr<T> &b) const {
+		return a == (*b);
+	}
+};
+
+template<typename T>
+struct shared_ptr_hash {
+	using is_transparent = void; /* We want to find values in a set of shared_ptr by reference */
+	auto operator()(const std::shared_ptr<T> &a) const {
+		return std::hash<T>()(*a);
+	}
+	auto operator()(const T &a) const {
+		return std::hash<T>()(a);
+	}
+};
+
+}
+
+#endif //RSPAMD_UTIL_HXX


More information about the Commits mailing list