aboutsummaryrefslogtreecommitdiff
path: root/include/cru/platform/Check.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-02-08 16:53:51 +0800
committercrupest <crupest@outlook.com>2022-02-08 16:53:51 +0800
commit74bb9cd27242b9320f99ff4d2b50c3051576cc14 (patch)
tree744bac5799c593d1d6f81e7b09581bea626f2cde /include/cru/platform/Check.hpp
parentb90c398de829d1ba5329651d75bae82f5e4085fe (diff)
downloadcru-74bb9cd27242b9320f99ff4d2b50c3051576cc14.tar.gz
cru-74bb9cd27242b9320f99ff4d2b50c3051576cc14.tar.bz2
cru-74bb9cd27242b9320f99ff4d2b50c3051576cc14.zip
...
Diffstat (limited to 'include/cru/platform/Check.hpp')
-rw-r--r--include/cru/platform/Check.hpp41
1 files changed, 0 insertions, 41 deletions
diff --git a/include/cru/platform/Check.hpp b/include/cru/platform/Check.hpp
deleted file mode 100644
index 121e3505..00000000
--- a/include/cru/platform/Check.hpp
+++ /dev/null
@@ -1,41 +0,0 @@
-#pragma once
-#include "Exception.hpp"
-#include "Resource.hpp"
-
-#include "cru/common/String.hpp"
-#include "cru/common/Format.hpp"
-
-#include <memory>
-#include <type_traits>
-
-namespace cru::platform {
-template <typename TTarget>
-TTarget* CheckPlatform(IPlatformResource* resource,
- const String& target_platform) {
- Expects(resource);
- const auto result = dynamic_cast<TTarget*>(resource);
- if (result == nullptr) {
- throw UnsupportPlatformException(Format(
- u"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 String& target_platform) {
- static_assert(std::is_base_of_v<IPlatformResource, TSource>,
- "TSource must be a subclass of INativeResource.");
- Expects(resource);
- const auto result = std::dynamic_pointer_cast<TTarget>(resource);
- if (result == nullptr) {
- throw UnsupportPlatformException(Format(
- u"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