aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorrichiesams2013-08-24 00:00:30 -0500
committerrichiesams2013-08-24 00:23:40 -0500
commit7095e613d59630ec03dbf8a17e18ae9b4aabf289 (patch)
treec2ca8592c005c890fcf38d7d62e519fca0fcfb77
parent2431f60c02197585bd252393a013f8e50a2ae30a (diff)
downloadscummvm-rg350-7095e613d59630ec03dbf8a17e18ae9b4aabf289.tar.gz
scummvm-rg350-7095e613d59630ec03dbf8a17e18ae9b4aabf289.tar.bz2
scummvm-rg350-7095e613d59630ec03dbf8a17e18ae9b4aabf289.zip
ZVISION: Keep a member variable ZVision pointer instead of passing it in every process()
-rw-r--r--engines/zvision/action_node.cpp9
-rw-r--r--engines/zvision/action_node.h20
2 files changed, 18 insertions, 11 deletions
diff --git a/engines/zvision/action_node.cpp b/engines/zvision/action_node.cpp
index 1a51690b3f..f51801a75d 100644
--- a/engines/zvision/action_node.cpp
+++ b/engines/zvision/action_node.cpp
@@ -28,14 +28,15 @@
namespace ZVision {
-NodeTimer::NodeTimer(uint32 key, uint timeInSeconds)
- : _key(key), _timeLeft(timeInSeconds * 1000) {}
+TimerNode::TimerNode(ZVision *engine, uint32 key, uint timeInSeconds)
+ : _engine(engine), _key(key), _timeLeft(timeInSeconds * 1000) {
+}
-bool NodeTimer::process(ZVision *engine, uint32 deltaTimeInMillis) {
+bool TimerNode::process(uint32 deltaTimeInMillis) {
_timeLeft -= deltaTimeInMillis;
if (_timeLeft <= 0) {
- engine->getScriptManager()->setStateValue(_key, 0);
+ _engine->getScriptManager()->setStateValue(_key, 0);
return true;
}
diff --git a/engines/zvision/action_node.h b/engines/zvision/action_node.h
index 5b4430c3a4..9a5ca0be0b 100644
--- a/engines/zvision/action_node.h
+++ b/engines/zvision/action_node.h
@@ -32,23 +32,29 @@ class ZVision;
class ActionNode {
public:
virtual ~ActionNode() {}
- virtual bool process(ZVision *engine, uint32 deltaTimeInMillis) = 0;
+ /**
+ * Processes the node given the deltaTime since last frame
+ *
+ * @param deltaTimeInMillis The number of milliseconds that have passed since last frame
+ * @return If true, the node can be deleted after process() finishes
+ */
+ virtual bool process(uint32 deltaTimeInMillis) = 0;
};
-class NodeTimer : public ActionNode {
+class TimerNode : public ActionNode {
public:
- NodeTimer(uint32 key, uint timeInSeconds);
+ TimerNode(ZVision *engine, uint32 key, uint timeInSeconds);
/**
* Decrement the timer by the delta time. If the timer is finished, set the status
* in _globalState and let this node be deleted
*
- * @param engine Pointer to the ZVision instance
- * @param deltaTimeInMillis Amount of time that has passed since the last frame
- * @return Node should be deleted after this (true) or kept (false)
+ * @param deltaTimeInMillis The number of milliseconds that have passed since last frame
+ * @return If true, the node can be deleted after process() finishes
*/
- bool process(ZVision *engine, uint32 deltaTimeInMillis);
+ bool process(uint32 deltaTimeInMillis);
private:
+ ZVision *_engine;
uint32 _key;
uint32 _timeLeft;
};