aboutsummaryrefslogtreecommitdiff
path: root/include/cru/platform/Check.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-06-28 00:03:11 +0800
committercrupest <crupest@outlook.com>2020-06-28 00:03:11 +0800
commit06d1d0442276a05b6caad6e3468f4afb1e8ee5df (patch)
treeebd46f0fb7343dc57bf947b7b5fffc139c3ddeac /include/cru/platform/Check.hpp
parente11be6caa9ef9b2b198ca61846e32f469627556e (diff)
downloadcru-06d1d0442276a05b6caad6e3468f4afb1e8ee5df.tar.gz
cru-06d1d0442276a05b6caad6e3468f4afb1e8ee5df.tar.bz2
cru-06d1d0442276a05b6caad6e3468f4afb1e8ee5df.zip
...
Diffstat (limited to 'include/cru/platform/Check.hpp')
-rw-r--r--include/cru/platform/Check.hpp40
1 files changed, 40 insertions, 0 deletions
diff --git a/include/cru/platform/Check.hpp b/include/cru/platform/Check.hpp
new file mode 100644
index 00000000..f4bbcfe8
--- /dev/null
+++ b/include/cru/platform/Check.hpp
@@ -0,0 +1,40 @@
+#pragma once
+#include "Exception.hpp"
+#include "Resource.hpp"
+
+#include <fmt/format.h>
+#include <memory>
+#include <type_traits>
+
+namespace cru::platform {
+template <typename TTarget>
+TTarget* CheckPlatform(INativeResource* resource,
+ const std::string_view& target_platform) {
+ Expects(resource);
+ const auto result = dynamic_cast<TTarget*>(resource);
+ if (result == nullptr) {
+ throw UnsupportPlatformException(fmt::format(
+ "Try to convert resource to target platform failed. Platform id of "
+ "resource to convert: {} . Target platform id: {} .",
+ resource->GetPlatformId(), target_platform));
+ }
+ return result;
+}
+
+template <typename TTarget, typename TSource>
+std::shared_ptr<TTarget> CheckPlatform(
+ const std::shared_ptr<TSource>& resource,
+ const std::string_view& target_platform) {
+ static_assert(std::is_base_of_v<INativeResource, TSource>,
+ "TSource must be a subclass of INativeResource.");
+ Expects(resource);
+ const auto result = std::dynamic_pointer_cast<TTarget>(resource);
+ if (result == nullptr) {
+ throw UnsupportPlatformException(fmt::format(
+ "Try to convert resource to target platform failed. Platform id of "
+ "resource to convert: {} . Target platform id: {} .",
+ resource->GetPlatformId(), target_platform));
+ }
+ return result;
+}
+} // namespace cru::platform