Project::OSiRiON - Git repositories
Project::OSiRiON
News . About . Screenshots . Downloads . Forum . Wiki . Tracker . Git
summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/core/slot.cc20
-rw-r--r--src/core/slot.h79
2 files changed, 87 insertions, 12 deletions
diff --git a/src/core/slot.cc b/src/core/slot.cc
index 1b3e648..89f885c 100644
--- a/src/core/slot.cc
+++ b/src/core/slot.cc
@@ -13,21 +13,31 @@ namespace core
Slot::Slot()
{
slot_item = 0;
+ slot_active = true;
+ slot_timestamp = 0;
}
-Slot::Slot(const math::Vector3f &location)
+Slot::Slot(const math::Vector3f & location) :
+ slot_location(location)
{
slot_item = 0;
- slot_location.assign(location);
+ slot_active = true;
+ slot_timestamp = 0;
+
}
-
Slot::~Slot()
{
slot_item = 0;
+ slot_active = false;
+ slot_timestamp = 0;
+}
+
+void Slot::set_item(Item *item)
+{
+ slot_item = item;
+ set_timestamp(game() ? game()->timestamp() : 1);
}
} // namespace core
-
-
diff --git a/src/core/slot.h b/src/core/slot.h
index e99f33c..d0f2fdc 100644
--- a/src/core/slot.h
+++ b/src/core/slot.h
@@ -12,37 +12,102 @@
#include "core/item.h"
+#include <string>
+
namespace core
{
/**
- * @brief A single equipment or weapon slots
+ * @brief A mount point for a weapon or a piece of equipment
* */
class Slot {
public:
+ /**
+ * @brief default constructor
+ * Creates an empty slot
+ * */
Slot();
- Slot(const math::Vector3f &location);
+ /**
+ * @brief creates and empty slot at a given location
+ * */
+ Slot(const math::Vector3f & location);
+
+ /**
+ * @brief default destructor
+ * */
~Slot();
- inline const math::Vector3f &location() {
+ /**
+ * @brief location of the slot within the parent model
+ * */
+ inline const math::Vector3f & location() const
+ {
return slot_location;
}
-
- inline void set_item(Item *item)
+ /**
+ * @brief axis indication the slot's orientation
+ * */
+ inline const math::Axis & axis() const
{
- slot_item = item;
+ return slot_axis;
}
+ /**
+ * @brief the name of the particlesystem used to render
+ * projectiles generated by this slot
+ * */
+
+
+ /* --- mutators -------------------------------------------- */
+
+ /**
+ * @brief set the slot's location
+ * */
inline void set_location(const math::Vector3f &location)
{
slot_location.assign(location);
}
+ /**
+ * @brief set the slot's orientation
+ */
+ inline void set_axis(const math::Axis & axis)
+ {
+ slot_axis.assign(axis);
+ }
+
+ /**
+ * @brief set the slot's timestamp
+ * The timestamp indicates when the slot's configuration was last changed.
+ * */
+ inline void set_timestamp(unsigned long timestamp)
+ {
+ slot_timestamp = timestamp;
+ }
+
+ /**
+ * @brief set the item this slot is holding
+ * */
+ inline void set_item(Item *item);
+
private:
math::Vector3f slot_location;
- Item *slot_item;
+ math::Axis slot_axis;
+
+ unsigned long slot_timestamp;
+ // FIXME consolidate into slot_flags
+ bool slot_active;
+
+ std::string slot_particlesystem_name;
+
+ // fire rate, in projectiles per second
+ float slot_fire_rate;
+ // fire range, in game units
+ float slot_fire_range;
+
+ Item *slot_item;
};
} // namespace core