aboutsummaryrefslogtreecommitdiff
path: root/include/cru
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2022-01-24 18:28:25 +0800
committercrupest <crupest@outlook.com>2022-01-24 18:28:25 +0800
commit549b072d241a8d2d1ca187bba8c1cb5190dd737e (patch)
tree1058514562df4a43df89982e63984a49d5fef79e /include/cru
parent7a95d9af36221f36402495513c3563c5dc2163ad (diff)
downloadcru-549b072d241a8d2d1ca187bba8c1cb5190dd737e.tar.gz
cru-549b072d241a8d2d1ca187bba8c1cb5190dd737e.tar.bz2
cru-549b072d241a8d2d1ca187bba8c1cb5190dd737e.zip
...
Diffstat (limited to 'include/cru')
-rw-r--r--include/cru/ui/mapper/style/BorderStylerMapper.hpp9
-rw-r--r--include/cru/ui/mapper/style/CursorStylerMapper.hpp9
-rw-r--r--include/cru/ui/mapper/style/IStylerMapper.hpp17
3 files changed, 33 insertions, 2 deletions
diff --git a/include/cru/ui/mapper/style/BorderStylerMapper.hpp b/include/cru/ui/mapper/style/BorderStylerMapper.hpp
index 6c967bed..2f48550c 100644
--- a/include/cru/ui/mapper/style/BorderStylerMapper.hpp
+++ b/include/cru/ui/mapper/style/BorderStylerMapper.hpp
@@ -1,12 +1,14 @@
#pragma once
#include "../Mapper.hpp"
#include "cru/common/ClonablePtr.hpp"
+#include "cru/ui/mapper/style/IStylerMapper.hpp"
#include "cru/ui/style/Styler.hpp"
#include "cru/xml/XmlNode.hpp"
namespace cru::ui::mapper::style {
class CRU_UI_API BorderStylerMapper
- : public BasicPtrMapper<ui::style::BorderStyler> {
+ : public BasicPtrMapper<ui::style::BorderStyler>,
+ public virtual IStylerMapper {
public:
CRU_DEFAULT_CONSTRUCTOR_DESTRUCTOR(BorderStylerMapper)
@@ -14,6 +16,11 @@ class CRU_UI_API BorderStylerMapper
bool SupportMapFromXml() override { return true; }
bool XmlElementIsOfThisType(xml::XmlElementNode* node) override;
+ ClonablePtr<ui::style::Styler> MapStylerFromXml(
+ xml::XmlElementNode* node) override {
+ return MapFromXml(node);
+ }
+
protected:
ClonablePtr<ui::style::BorderStyler> DoMapFromXml(
xml::XmlElementNode* node) override;
diff --git a/include/cru/ui/mapper/style/CursorStylerMapper.hpp b/include/cru/ui/mapper/style/CursorStylerMapper.hpp
index c12efbd9..2b0c62a8 100644
--- a/include/cru/ui/mapper/style/CursorStylerMapper.hpp
+++ b/include/cru/ui/mapper/style/CursorStylerMapper.hpp
@@ -1,10 +1,12 @@
#pragma once
#include "../Mapper.hpp"
+#include "cru/ui/mapper/style/IStylerMapper.hpp"
#include "cru/ui/style/Styler.hpp"
namespace cru::ui::mapper::style {
class CRU_UI_API CursorStylerMapper
- : public BasicPtrMapper<ui::style::CursorStyler> {
+ : public BasicPtrMapper<ui::style::CursorStyler>,
+ public virtual IStylerMapper {
public:
CRU_DEFAULT_CONSTRUCTOR_DESTRUCTOR(CursorStylerMapper)
@@ -12,6 +14,11 @@ class CRU_UI_API CursorStylerMapper
bool SupportMapFromXml() override { return true; }
bool XmlElementIsOfThisType(xml::XmlElementNode* node) override;
+ ClonablePtr<ui::style::Styler> MapStylerFromXml(
+ xml::XmlElementNode* node) override {
+ return MapFromXml(node);
+ }
+
protected:
ClonablePtr<ui::style::CursorStyler> DoMapFromXml(
xml::XmlElementNode* node) override;
diff --git a/include/cru/ui/mapper/style/IStylerMapper.hpp b/include/cru/ui/mapper/style/IStylerMapper.hpp
new file mode 100644
index 00000000..03ee4289
--- /dev/null
+++ b/include/cru/ui/mapper/style/IStylerMapper.hpp
@@ -0,0 +1,17 @@
+#pragma once
+#include "../../Base.hpp"
+#include "cru/common/ClonablePtr.hpp"
+#include "cru/ui/mapper/Mapper.hpp"
+#include "cru/ui/style/Styler.hpp"
+#include "cru/xml/XmlNode.hpp"
+
+namespace cru::ui::mapper::style {
+struct IStylerMapper : virtual Interface {
+ bool XmlElementIsOfThisType(xml::XmlElementNode* node) {
+ return dynamic_cast<MapperBase*>(this)->XmlElementIsOfThisType(node);
+ }
+
+ virtual ClonablePtr<ui::style::Styler> MapStylerFromXml(
+ xml::XmlElementNode* node) = 0;
+};
+} // namespace cru::ui::mapper::style