aboutsummaryrefslogtreecommitdiff
path: root/src/ui/mapper
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-01-19 23:14:21 +0800
committercrupest <crupest@outlook.com>2022-01-19 23:14:21 +0800
commit31422f87f729bd35bcebfb277d08b230424e3618 (patch)
treef4479c6da9dcc64a9a39e165ed0459efff051eb3 /src/ui/mapper
parent2028bc4914638360fb756079dbddbdbe52676821 (diff)
downloadcru-31422f87f729bd35bcebfb277d08b230424e3618.tar.gz
cru-31422f87f729bd35bcebfb277d08b230424e3618.tar.bz2
cru-31422f87f729bd35bcebfb277d08b230424e3618.zip
...
Diffstat (limited to 'src/ui/mapper')
-rw-r--r--src/ui/mapper/ThicknessMapper.cpp25
1 files changed, 24 insertions, 1 deletions
diff --git a/src/ui/mapper/ThicknessMapper.cpp b/src/ui/mapper/ThicknessMapper.cpp
index 684d0a4b..11f0be0d 100644
--- a/src/ui/mapper/ThicknessMapper.cpp
+++ b/src/ui/mapper/ThicknessMapper.cpp
@@ -2,10 +2,33 @@
#include "cru/xml/XmlNode.hpp"
namespace cru::ui::mapper {
-bool ThicknessMapper::XmlElementIsOfThisType(xml::XmlElementNode *node) {
+bool ThicknessMapper::XmlElementIsOfThisType(xml::XmlElementNode* node) {
if (node->GetTag() == u"Thickness") {
return true;
}
return false;
}
+
+std::unique_ptr<Thickness> ThicknessMapper::DoMapFromString(String str) {
+ std::vector<float> values = str.ParseToFloatList();
+ if (values.size() == 4) {
+ return std::make_unique<Thickness>(values[0], values[1], values[2],
+ values[3]);
+ } else if (values.size() == 2) {
+ return std::make_unique<Thickness>(values[0], values[1], values[0],
+ values[1]);
+ } else if (values.size() == 1) {
+ return std::make_unique<Thickness>(values[0], values[0], values[0],
+ values[0]);
+ } else {
+ throw Exception(u"Invalid Thickness string.");
+ }
+}
+
+std::unique_ptr<Thickness> ThicknessMapper::DoMapFromXml(
+ xml::XmlElementNode* node) {
+ auto value_attr = node->GetOptionalAttribute(u"value");
+ if (!value_attr) return std::make_unique<Thickness>();
+ return DoMapFromString(*value_attr);
+}
} // namespace cru::ui::mapper