summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFelix Morgner <felix.morgner@gmail.com>2025-05-13 15:59:02 +0200
committerFelix Morgner <felix.morgner@gmail.com>2025-05-13 15:59:02 +0200
commit9513f7303ffde9fbda869e346523a23197f4ece9 (patch)
treef35ab8afa3273d1a8c4da2fc2ac9580a157a3a2c
parent661e98cf8bb61f29049d405aef9cdaace1449ac8 (diff)
downloadturns-9513f7303ffde9fbda869e346523a23197f4ece9.tar.xz
turns-9513f7303ffde9fbda869e346523a23197f4ece9.zip
lib: begin TurnOrder implementation
-rw-r--r--core/include/turns/core/disposition.hpp39
-rw-r--r--core/include/turns/core/fwd.hpp14
-rw-r--r--core/include/turns/core/init.hpp11
-rw-r--r--core/include/turns/core/participant.hpp82
-rw-r--r--core/src/disposition.cpp51
-rw-r--r--core/src/init.cpp20
-rw-r--r--core/src/participant.cpp116
-rw-r--r--lib/CMakeLists.txt7
-rw-r--r--lib/src/turns-init.cpp4
-rw-r--r--lib/src/turns-participant.h2
-rw-r--r--lib/src/turns-turn-order.cpp80
-rw-r--r--lib/src/turns-turn-order.h18
-rw-r--r--lib/src/turnsmm/init.cpp5
-rw-r--r--lib/src/turnsmm/private/turn-order_p.hpp31
-rw-r--r--lib/src/turnsmm/turn-order.cpp92
-rw-r--r--lib/src/turnsmm/turn-order.hpp45
-rw-r--r--lib/tests/turns-turn-order.cpp16
-rw-r--r--lib/tests/turnsmm/turn-order.cpp16
18 files changed, 313 insertions, 336 deletions
diff --git a/core/include/turns/core/disposition.hpp b/core/include/turns/core/disposition.hpp
deleted file mode 100644
index cd00836..0000000
--- a/core/include/turns/core/disposition.hpp
+++ /dev/null
@@ -1,39 +0,0 @@
-#ifndef TURNS_CORE_DISPOSITION_HPP
-#define TURNS_CORE_DISPOSITION_HPP
-
-#include <glibmm/ustring.h>
-#include <glibmm/value.h>
-
-#include <glib-object.h>
-
-#include <cstdint>
-
-namespace turns::core
-{
- enum struct Disposition : std::uint8_t
- {
- Neutral,
- Friendly,
- Hostile,
- Secret,
-
- ///! End marker
- END
- };
-
- auto presentation_name_for(Disposition value) -> Glib::ustring;
-} // namespace turns::core
-
-namespace Glib
-{
- template<>
- class Value<turns::core::Disposition> : public Glib::Value_Enum<turns::core::Disposition>
- {
- GType static constinit inline gtype_{};
-
- public:
- auto static value_type() -> GType;
- };
-} // namespace Glib
-
-#endif \ No newline at end of file
diff --git a/core/include/turns/core/fwd.hpp b/core/include/turns/core/fwd.hpp
deleted file mode 100644
index c006084..0000000
--- a/core/include/turns/core/fwd.hpp
+++ /dev/null
@@ -1,14 +0,0 @@
-#ifndef TURNS_CORE_FWD_HPP
-#define TURNS_CORE_FWD_HPP
-
-#include <cstdint>
-
-namespace turns::core
-{
- enum struct Disposition : std::uint8_t;
-
- struct Participant;
- struct TurnOderModel;
-} // namespace turns::core
-
-#endif \ No newline at end of file
diff --git a/core/include/turns/core/init.hpp b/core/include/turns/core/init.hpp
deleted file mode 100644
index f0dc70e..0000000
--- a/core/include/turns/core/init.hpp
+++ /dev/null
@@ -1,11 +0,0 @@
-#ifndef TURNS_CORE_INIT_HPP
-#define TURNS_CORE_INIT_HPP
-
-namespace turns::core
-{
-
- auto register_types() -> void;
-
-} // namespace turns::core
-
-#endif \ No newline at end of file
diff --git a/core/include/turns/core/participant.hpp b/core/include/turns/core/participant.hpp
deleted file mode 100644
index e6d9008..0000000
--- a/core/include/turns/core/participant.hpp
+++ /dev/null
@@ -1,82 +0,0 @@
-#ifndef TURNS_CORE_PARTICIPANT_HPP
-#define TURNS_CORE_PARTICIPANT_HPP
-
-#include "turns/core/disposition.hpp"
-
-#include <glibmm/object.h>
-#include <glibmm/property.h>
-#include <glibmm/refptr.h>
-#include <glibmm/ustring.h>
-
-#include <nlohmann/json_fwd.hpp>
-
-#include <compare>
-
-namespace turns::core
-{
- struct Participant : Glib::Object
- {
- auto static create(Glib::ustring name, float priority, Disposition disposition) -> Glib::RefPtr<Participant>;
- auto static create(nlohmann::json const & serialized) -> Glib::RefPtr<Participant>;
-
- Participant();
- Participant(Glib::ustring name, float priority, Disposition disposition);
-
- auto operator<=>(Participant const & other) const noexcept -> std::partial_ordering;
-
- [[nodiscard]] auto get_disposition() const -> Disposition;
- [[nodiscard]] auto get_is_active() const -> bool;
- [[nodiscard]] auto get_is_defeated() const -> bool;
- [[nodiscard]] auto get_name() const -> Glib::ustring;
- [[nodiscard]] auto get_priority() const -> float;
-
- auto set_disposition(Disposition value) -> void;
- auto set_is_active(bool value) -> void;
- auto set_is_defeated(bool value) -> void;
- auto set_name(Glib::ustring const & value) -> void;
- auto set_priority(float value) -> void;
-
- [[nodiscard]] auto property_disposition(this auto && self);
- [[nodiscard]] auto property_is_active(this auto && self);
- [[nodiscard]] auto property_is_defeated(this auto && self);
- [[nodiscard]] auto property_name(this auto && self);
- [[nodiscard]] auto property_priority(this auto && self);
-
- auto serialize() -> nlohmann::json;
-
- private:
- Glib::Property<core::Disposition> m_disposition{*this, "disposition", core::Disposition::Neutral};
- Glib::Property<bool> m_is_active{*this, "is-active", false};
- Glib::Property<bool> m_is_defeated{*this, "is-defeated", false};
- Glib::Property<Glib::ustring> m_name{*this, "name", ""};
- Glib::Property<float> m_priority{*this, "priority", 0.0f};
- };
-
- auto Participant::property_disposition(this auto && self)
- {
- return self.m_disposition.get_proxy();
- }
-
- auto Participant::property_is_active(this auto && self)
- {
- return self.m_is_active.get_proxy();
- }
-
- auto Participant::property_is_defeated(this auto && self)
- {
- return self.m_is_defeated.get_proxy();
- }
-
- auto Participant::property_name(this auto && self)
- {
- return self.m_name.get_proxy();
- }
-
- auto Participant::property_priority(this auto && self)
- {
- return self.m_priority.get_proxy();
- }
-
-} // namespace turns::core
-
-#endif \ No newline at end of file
diff --git a/core/src/disposition.cpp b/core/src/disposition.cpp
deleted file mode 100644
index 894baed..0000000
--- a/core/src/disposition.cpp
+++ /dev/null
@@ -1,51 +0,0 @@
-#include "turns/core/disposition.hpp"
-
-#include <glibmm/i18n.h>
-#include <glibmm/ustring.h>
-
-#include <glib-object.h>
-
-#include <array>
-#include <atomic>
-
-namespace turns::core
-{
-
- auto presentation_name_for(Disposition value) -> Glib::ustring
- {
- switch (value)
- {
- case Disposition::Neutral:
- return _("Neutral");
- case Disposition::Friendly:
- return _("Friendly");
- case Disposition::Hostile:
- return _("Hostile");
- case Disposition::Secret:
- return _("Secret");
- default:
- return _("Unknown disposition value");
- }
- }
-
-} // namespace turns::core
-
-namespace Glib
-{
- auto Value<turns::core::Disposition>::value_type() -> GType
- {
- auto static is_initialized = std::atomic_flag{false};
- auto static const values = std::array{
- GEnumValue{static_cast<int>(turns::core::Disposition::Neutral), "TURNS_DISPOSITION_NEUTRAL", "neutral" },
- GEnumValue{static_cast<int>(turns::core::Disposition::Friendly), "TURNS_DISPOSITION_FRIENDLY", "friendly"},
- GEnumValue{static_cast<int>(turns::core::Disposition::Hostile), "TURNS_DISPOSITION_HOSTILE", "hostile" },
- GEnumValue{static_cast<int>(turns::core::Disposition::Secret), "TURNS_DISPOSITION_SECRET", "secret" },
- GEnumValue{0, nullptr, nullptr },
- };
- if (!is_initialized.test_and_set())
- {
- gtype_ = g_enum_register_static("TurnsDisposition", values.data());
- }
- return gtype_;
- }
-} // namespace Glib \ No newline at end of file
diff --git a/core/src/init.cpp b/core/src/init.cpp
deleted file mode 100644
index 4f67817..0000000
--- a/core/src/init.cpp
+++ /dev/null
@@ -1,20 +0,0 @@
-#include "turns/core/init.hpp"
-
-#include "turns/core/disposition.hpp"
-#include "turns/core/participant.hpp"
-#include "turns/core/turn_order_model.hpp"
-
-#include <glib-object.h>
-
-namespace turns::core
-{
-
- auto register_types() -> void
- {
- static_cast<void>(Participant{});
- static_cast<void>(TurnOderModel{});
-
- g_type_ensure(Glib::Value<Disposition>::value_type());
- }
-
-} // namespace turns::core \ No newline at end of file
diff --git a/core/src/participant.cpp b/core/src/participant.cpp
deleted file mode 100644
index ff2c2fb..0000000
--- a/core/src/participant.cpp
+++ /dev/null
@@ -1,116 +0,0 @@
-#include "turns/core/participant.hpp"
-
-#include "turns/core/disposition.hpp"
-#include "turns/core/json_ext.hpp"
-
-#include <glibmm/object.h>
-#include <glibmm/objectbase.h>
-#include <glibmm/refptr.h>
-#include <glibmm/ustring.h>
-
-#include <nlohmann/json.hpp>
-
-#include <compare>
-#include <string>
-
-namespace turns::core
-{
- auto Participant::create(Glib::ustring name, float priority, core::Disposition disposition) -> Glib::RefPtr<Participant>
- {
- return Glib::make_refptr_for_instance(new Participant{name, priority, disposition});
- }
-
- auto Participant::create(nlohmann::json const & serialized) -> Glib::RefPtr<Participant>
- {
- auto disposition = serialized.value("disposition", Disposition::Neutral);
- auto priority = serialized.value("priority", 0.0f);
- auto name = serialized.value("name", std::string{});
-
- auto instance = create(name, priority, disposition);
- instance->property_is_active() = serialized.value("is-active", false);
- instance->property_is_defeated() = serialized.value("is-defeated", false);
- ;
-
- return instance;
- }
-
- Participant::Participant()
- : Glib::ObjectBase{"TurnsParticipant"}
- , Glib::Object{}
- {
- }
-
- Participant::Participant(Glib::ustring name, float priority, core::Disposition disposition)
- : Participant()
- {
- m_name = name;
- m_priority = priority;
- m_disposition = disposition;
- }
-
- auto Participant::operator<=>(Participant const & other) const noexcept -> std::partial_ordering
- {
- return m_priority <=> other.m_priority;
- }
-
- auto Participant::get_disposition() const -> Disposition
- {
- return m_disposition.get_value();
- }
-
- auto Participant::get_is_active() const -> bool
- {
- return m_is_active.get_value();
- }
-
- auto Participant::get_is_defeated() const -> bool
- {
- return m_is_defeated.get_value();
- }
-
- auto Participant::get_name() const -> Glib::ustring
- {
- return m_name.get_value();
- }
-
- auto Participant::get_priority() const -> float
- {
- return m_priority.get_value();
- }
-
- auto Participant::set_disposition(Disposition value) -> void
- {
- return m_disposition.set_value(value);
- }
-
- auto Participant::set_is_active(bool value) -> void
- {
- return m_is_active.set_value(value);
- }
-
- auto Participant::set_is_defeated(bool value) -> void
- {
- return m_is_defeated.set_value(value);
- }
-
- auto Participant::set_name(Glib::ustring const & value) -> void
- {
- return m_name.set_value(value);
- }
-
- auto Participant::set_priority(float value) -> void
- {
- return m_priority.set_value(value);
- }
-
- auto Participant::serialize() -> nlohmann::json
- {
- return nlohmann::json{
- {"disposition", m_disposition},
- {"is-active", m_is_active },
- {"is-defeated", m_is_defeated},
- {"name", m_name },
- {"priority", m_priority },
- };
- }
-} // namespace turns::core \ No newline at end of file
diff --git a/lib/CMakeLists.txt b/lib/CMakeLists.txt
index e5a4916..3342c30 100644
--- a/lib/CMakeLists.txt
+++ b/lib/CMakeLists.txt
@@ -4,12 +4,14 @@ set(HEADERS
"src/turns-disposition.h"
"src/turns-init.h"
"src/turns-participant.h"
+ "src/turns-turn-order.h"
"src/turns.h"
)
set(SOURCES
"src/turns-init.cpp"
"src/turns-participant.cpp"
+ "src/turns-turn-order.cpp"
)
add_library("lib"
@@ -67,15 +69,18 @@ set(CXX_HEADERS
"src/turnsmm/enums.hpp"
"src/turnsmm/init.hpp"
"src/turnsmm/participant.hpp"
+ "src/turnsmm/turn-order.hpp"
"src/turnsmm.hpp"
"src/turnsmm/private/participant_p.hpp"
+ "src/turnsmm/private/turn-order_p.hpp"
)
set(CXX_SOURCES
"src/turnsmm/enums.cpp"
"src/turnsmm/init.cpp"
"src/turnsmm/participant.cpp"
+ "src/turnsmm/turn-order.cpp"
)
add_library("libmm"
@@ -123,6 +128,7 @@ install(TARGETS "libmm"
add_executable("lib-tests"
"tests/runtime_init.cpp"
"tests/turns-participant.cpp"
+ "tests/turns-turn-order.cpp"
)
target_link_libraries("lib-tests" PRIVATE
@@ -142,6 +148,7 @@ catch_discover_tests("lib-tests")
add_executable("libmm-tests"
"tests/turnsmm/runtime_init.cpp"
"tests/turnsmm/participant.cpp"
+ "tests/turnsmm/turn-order.cpp"
)
target_link_libraries("libmm-tests" PRIVATE
diff --git a/lib/src/turns-init.cpp b/lib/src/turns-init.cpp
index 544dc14..6fbe837 100644
--- a/lib/src/turns-init.cpp
+++ b/lib/src/turns-init.cpp
@@ -2,6 +2,7 @@
#include "turns-enums.h"
#include "turns-participant.h"
+#include "turns-turn-order.h"
#include <glib-object.h>
#include <glib.h>
@@ -10,8 +11,9 @@ G_BEGIN_DECLS
auto turns_init() -> void
{
- g_type_ensure(TURNS_TYPE_PARTICIPANT);
g_type_ensure(TURNS_TYPE_DISPOSITION);
+ g_type_ensure(TURNS_TYPE_PARTICIPANT);
+ g_type_ensure(TURNS_TYPE_TURN_ORDER);
}
G_END_DECLS \ No newline at end of file
diff --git a/lib/src/turns-participant.h b/lib/src/turns-participant.h
index a0e0d98..3ddfaa6 100644
--- a/lib/src/turns-participant.h
+++ b/lib/src/turns-participant.h
@@ -20,7 +20,7 @@ G_DECLARE_FINAL_TYPE(TurnsParticipant, turns_participant, TURNS, PARTICIPANT, GO
* - @p priority is 0.0f
* - @p disposition is Disposition.Neutral.
*/
-TurnsParticipant * turns_participant_new() G_GNUC_WARN_UNUSED_RESULT;
+TurnsParticipant * turns_participant_new(void) G_GNUC_WARN_UNUSED_RESULT;
/**
* @brief Construct a new Participant with the given values.
diff --git a/lib/src/turns-turn-order.cpp b/lib/src/turns-turn-order.cpp
new file mode 100644
index 0000000..538ff11
--- /dev/null
+++ b/lib/src/turns-turn-order.cpp
@@ -0,0 +1,80 @@
+#include "turns-turn-order.h"
+
+#include <glib-object.h>
+#include <glib.h>
+
+#include <array>
+#include <cstddef>
+
+G_BEGIN_DECLS
+
+struct _TurnsTurnOrder
+{
+ GObject parent_instance;
+
+ gboolean running;
+};
+
+G_DEFINE_FINAL_TYPE(TurnsTurnOrder, turns_turn_order, G_TYPE_OBJECT);
+
+G_END_DECLS
+
+namespace
+{
+ enum struct property
+ {
+ Running = 1,
+ N_PROPERTIES,
+ };
+
+ auto static constinit properties = std::array<GParamSpec *, static_cast<std::size_t>(property::N_PROPERTIES)>{};
+
+ auto get_property(GObject * self, guint id, GValue * value, GParamSpec * specification) -> void
+ {
+ auto instance = TURNS_TURN_ORDER(self);
+
+ switch (static_cast<property>(id))
+ {
+ case property::Running:
+ return g_value_set_boolean(value, turns_turn_order_get_running(instance));
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID(self, id, specification);
+ }
+ }
+
+} // namespace
+
+G_BEGIN_DECLS
+
+static void turns_turn_order_class_init(TurnsTurnOrderClass * klass)
+{
+ auto object_class = G_OBJECT_CLASS(klass);
+
+ object_class->get_property = get_property;
+
+ properties[static_cast<std::size_t>(property::Running)] =
+ g_param_spec_boolean("running",
+ "Running",
+ "Whether or not the turn order is running (e.g. has been started)",
+ false,
+ static_cast<GParamFlags>(G_PARAM_CONSTRUCT | G_PARAM_STATIC_STRINGS | G_PARAM_READWRITE | G_PARAM_EXPLICIT_NOTIFY));
+
+ g_object_class_install_properties(object_class, properties.size(), properties.data());
+}
+
+static void turns_turn_order_init(TurnsTurnOrder *)
+{
+}
+
+TurnsTurnOrder * turns_turn_order_new()
+{
+ return TURNS_TURN_ORDER(g_object_new(TURNS_TYPE_TURN_ORDER, nullptr));
+}
+
+gboolean turns_turn_order_get_running(TurnsTurnOrder const * self)
+{
+ g_return_val_if_fail(TURNS_IS_TURN_ORDER(const_cast<TurnsTurnOrder *>(self)), false);
+ return self->running;
+}
+
+G_END_DECLS \ No newline at end of file
diff --git a/lib/src/turns-turn-order.h b/lib/src/turns-turn-order.h
new file mode 100644
index 0000000..2370445
--- /dev/null
+++ b/lib/src/turns-turn-order.h
@@ -0,0 +1,18 @@
+#ifndef TURNS_TURN_ORDER_H
+#define TURNS_TURN_ORDER_H
+
+#include <glib-object.h>
+#include <glib.h>
+
+G_BEGIN_DECLS
+
+#define TURNS_TYPE_TURN_ORDER turns_turn_order_get_type()
+G_DECLARE_FINAL_TYPE(TurnsTurnOrder, turns_turn_order, TURNS, TURN_ORDER, GObject)
+
+TurnsTurnOrder * turns_turn_order_new(void) G_GNUC_WARN_UNUSED_RESULT;
+
+gboolean turns_turn_order_get_running(TurnsTurnOrder const * self) G_GNUC_WARN_UNUSED_RESULT;
+
+G_END_DECLS
+
+#endif
diff --git a/lib/src/turnsmm/init.cpp b/lib/src/turnsmm/init.cpp
index 77c217b..3104b1d 100644
--- a/lib/src/turnsmm/init.cpp
+++ b/lib/src/turnsmm/init.cpp
@@ -1,9 +1,10 @@
#include "turnsmm/init.hpp"
#include "turns-init.h"
-#include "turnsmm/enums.hpp"
#include "turnsmm/participant.hpp"
#include "turnsmm/private/participant_p.hpp" // IWYU pragma: keep
+#include "turnsmm/private/turn-order_p.hpp" // IWYU pragma: keep
+#include "turnsmm/turn-order.hpp"
#include <glibmm/value.h>
#include <glibmm/wrap.h>
@@ -21,8 +22,10 @@ namespace Turns
turns_init();
WRAP_CLASS(Participant, participant);
+ WRAP_CLASS(TurnOrder, turn_order);
ENSURE_TYPE(Participant);
+ ENSURE_TYPE(TurnOrder);
}
} // namespace Turns \ No newline at end of file
diff --git a/lib/src/turnsmm/private/turn-order_p.hpp b/lib/src/turnsmm/private/turn-order_p.hpp
new file mode 100644
index 0000000..b128fd4
--- /dev/null
+++ b/lib/src/turnsmm/private/turn-order_p.hpp
@@ -0,0 +1,31 @@
+#ifndef TURNSMM_TURN_ORDER_P_HPP
+#define TURNSMM_TURN_ORDER_P_HPP
+
+#include "turns-turn-order.h"
+
+#include <glibmm/class.h>
+#include <glibmm/object.h>
+#include <glibmm/objectbase.h>
+
+#include <glib-object.h>
+
+namespace Turns
+{
+
+ class TurnOrder_Class : Glib::Class
+ {
+ public:
+ using BaseClassParent = GObjectClass;
+ using BaseClassType = TurnsTurnOrderClass;
+ using BaseObjectType = TurnsTurnOrder;
+ using CppClassParent = Glib::Object_Class;
+ using CppObjectType = class TURN_ORDER;
+
+ auto init() -> Glib::Class const &;
+ auto static class_init_function(void * gclass, void * data) -> void;
+ auto static wrap_new(GObject * object) -> Glib::ObjectBase *;
+ };
+
+} // namespace Turns
+
+#endif \ No newline at end of file
diff --git a/lib/src/turnsmm/turn-order.cpp b/lib/src/turnsmm/turn-order.cpp
new file mode 100644
index 0000000..8dbcd9c
--- /dev/null
+++ b/lib/src/turnsmm/turn-order.cpp
@@ -0,0 +1,92 @@
+#include "turnsmm/turn-order.hpp"
+
+#include "turns-turn-order.h"
+#include "turnsmm/private/turn-order_p.hpp"
+
+#include <glibmm/class.h>
+#include <glibmm/object.h>
+#include <glibmm/objectbase.h>
+#include <glibmm/private/object_p.h>
+#include <glibmm/propertyproxy.h>
+#include <glibmm/refptr.h>
+#include <glibmm/wrap.h>
+
+#include <glib-object.h>
+
+#include <bit>
+
+namespace Turns
+{
+
+ namespace
+ {
+ auto constinit _class = TurnOrder_Class{};
+ } // namespace
+
+ auto TurnOrder_Class::init() -> Glib::Class const &
+ {
+ if (!gtype_)
+ {
+ class_init_func_ = &class_init_function;
+ gtype_ = turns_turn_order_get_type();
+ }
+ return *this;
+ }
+
+ auto TurnOrder_Class::class_init_function(void * gclass, void * data) -> void
+ {
+ auto const klass = static_cast<BaseClassType *>(gclass);
+ CppClassParent::class_init_function(klass, data);
+ }
+
+ auto TurnOrder_Class::wrap_new(GObject * object) -> Glib::ObjectBase *
+ {
+ return new TurnOrder(TURNS_TURN_ORDER(object));
+ }
+
+ TurnOrder::TurnOrder()
+ : Glib::ObjectBase{nullptr}
+ , Glib::Object{Glib::ConstructParams{_class.init()}}
+ {
+ }
+
+ auto TurnOrder::gobj() noexcept -> BaseObjectType *
+ {
+ return std::bit_cast<BaseObjectType *>(gobject_);
+ }
+
+ auto TurnOrder::gobj() const -> BaseObjectType const *
+ {
+ return std::bit_cast<BaseObjectType const *>(gobject_);
+ }
+
+ auto TurnOrder::gobj_copy() noexcept -> BaseObjectType *
+ {
+ reference();
+ return gobj();
+ }
+
+ auto TurnOrder::get_running() const noexcept -> bool
+ {
+ return turns_turn_order_get_running(const_cast<BaseObjectType *>(unwrap(this)));
+ }
+
+ auto TurnOrder::property_running() const noexcept -> Glib::PropertyProxy_ReadOnly<bool>
+ {
+ return {this, "running"};
+ }
+
+ TurnOrder::TurnOrder(BaseObjectType * gobj)
+ : Glib::Object(G_OBJECT(gobj))
+ {
+ }
+
+} // namespace Turns
+
+namespace Glib
+{
+ auto wrap(TurnsTurnOrder * object, bool copy) -> Glib::RefPtr<Turns::TurnOrder>
+ {
+ return Glib::make_refptr_for_instance<Turns::TurnOrder>(dynamic_cast<Turns::TurnOrder *>(Glib::wrap_auto(G_OBJECT(object), copy)));
+ }
+} // namespace Glib \ No newline at end of file
diff --git a/lib/src/turnsmm/turn-order.hpp b/lib/src/turnsmm/turn-order.hpp
new file mode 100644
index 0000000..822e879
--- /dev/null
+++ b/lib/src/turnsmm/turn-order.hpp
@@ -0,0 +1,45 @@
+#ifndef TURNSMM_TURN_ORDER_HPP
+#define TURNSMM_TURN_ORDER_HPP
+
+#include "turns-turn-order.h"
+
+#include <glibmm/object.h>
+#include <glibmm/propertyproxy.h>
+#include <glibmm/refptr.h>
+#include <glibmm/ustring.h>
+
+namespace Turns
+{
+
+ class TurnOrder final : public Glib::Object
+ {
+ public:
+ using BaseClassType = TurnsTurnOrderClass;
+ using BaseObjectType = TurnsTurnOrder;
+ using CppClassType = class TurnOrder_Class;
+ using CppObjectType = TurnOrder;
+
+ TurnOrder();
+
+ [[nodiscard]] auto gobj() noexcept -> BaseObjectType *;
+ [[nodiscard]] auto gobj() const -> BaseObjectType const *;
+ [[nodiscard]] auto gobj_copy() noexcept -> BaseObjectType *;
+
+ [[nodiscard]] auto get_running() const noexcept -> bool;
+
+ [[nodiscard]] auto property_running() const noexcept -> Glib::PropertyProxy_ReadOnly<bool>;
+
+ protected:
+ friend TurnOrder_Class;
+
+ explicit TurnOrder(BaseObjectType * gobj);
+ };
+
+} // namespace Turns
+
+namespace Glib
+{
+ auto wrap(TurnsTurnOrder * object, bool copy = false) -> Glib::RefPtr<Turns::TurnOrder>;
+} // namespace Glib
+
+#endif \ No newline at end of file
diff --git a/lib/tests/turns-turn-order.cpp b/lib/tests/turns-turn-order.cpp
new file mode 100644
index 0000000..feb0aa1
--- /dev/null
+++ b/lib/tests/turns-turn-order.cpp
@@ -0,0 +1,16 @@
+#include "turns-turn-order.h"
+
+#include <catch2/catch_test_macros.hpp>
+
+SCENARIO("Creating a turn order", "[lib][object][lifetime]")
+{
+ GIVEN("A turn order constructed using turns_turn_order_new()")
+ {
+ g_autoptr(TurnsTurnOrder) instance = turns_turn_order_new();
+
+ THEN("it's running state is false")
+ {
+ REQUIRE_FALSE(turns_turn_order_get_running(instance));
+ }
+ }
+} \ No newline at end of file
diff --git a/lib/tests/turnsmm/turn-order.cpp b/lib/tests/turnsmm/turn-order.cpp
new file mode 100644
index 0000000..d6178ba
--- /dev/null
+++ b/lib/tests/turnsmm/turn-order.cpp
@@ -0,0 +1,16 @@
+#include "turnsmm/turn-order.hpp"
+
+#include <catch2/catch_test_macros.hpp>
+
+SCENARIO("Creating a turn order", "[lib][object][lifetime]")
+{
+ GIVEN("A turn order constructed using the default constructor")
+ {
+ auto instance = Turns::TurnOrder{};
+
+ THEN("it's running state is false")
+ {
+ REQUIRE_FALSE(instance.get_running());
+ }
+ }
+} \ No newline at end of file