aboutsummaryrefslogtreecommitdiff
path: root/include/cru/platform/Check.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-07-05 23:06:02 +0800
committercrupest <crupest@outlook.com>2020-07-05 23:06:02 +0800
commit5c805e494425a88da1813902b1ad8a1ab351e30d (patch)
treebe3cfd96dcac19db3e256d610d48b5083c489a6c /include/cru/platform/Check.hpp
parentbbec59718bf8a824583869126762013112f8e568 (diff)
downloadcru-5c805e494425a88da1813902b1ad8a1ab351e30d.tar.gz
cru-5c805e494425a88da1813902b1ad8a1ab351e30d.tar.bz2
cru-5c805e494425a88da1813902b1ad8a1ab351e30d.zip
...
Diffstat (limited to 'include/cru/platform/Check.hpp')
-rw-r--r--include/cru/platform/Check.hpp10
1 files changed, 6 insertions, 4 deletions
diff --git a/include/cru/platform/Check.hpp b/include/cru/platform/Check.hpp
index f4bbcfe8..d3180582 100644
--- a/include/cru/platform/Check.hpp
+++ b/include/cru/platform/Check.hpp
@@ -2,6 +2,8 @@
#include "Exception.hpp"
#include "Resource.hpp"
+#include "cru/common/StringUtil.hpp"
+
#include <fmt/format.h>
#include <memory>
#include <type_traits>
@@ -9,14 +11,14 @@
namespace cru::platform {
template <typename TTarget>
TTarget* CheckPlatform(INativeResource* resource,
- const std::string_view& target_platform) {
+ const std::u16string_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));
+ ToUtf8(resource->GetPlatformId()), ToUtf8(target_platform)));
}
return result;
}
@@ -24,7 +26,7 @@ TTarget* CheckPlatform(INativeResource* resource,
template <typename TTarget, typename TSource>
std::shared_ptr<TTarget> CheckPlatform(
const std::shared_ptr<TSource>& resource,
- const std::string_view& target_platform) {
+ const std::u16string_view& target_platform) {
static_assert(std::is_base_of_v<INativeResource, TSource>,
"TSource must be a subclass of INativeResource.");
Expects(resource);
@@ -33,7 +35,7 @@ std::shared_ptr<TTarget> CheckPlatform(
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));
+ ToUtf8(resource->GetPlatformId()), ToUtf8(target_platform)));
}
return result;
}