X-Git-Url: https://git.stderr.nl/gitweb?a=blobdiff_plain;f=ABM2%2FEngine%2FKernel.h;h=5e0df13539fb802f2215616a8bf78651ee347d6b;hb=c100d6f67b06abb348319e277a66b6b7ab0c4bd5;hp=3eda3db6a5c011a9915e9d8b95c6a6865736ef9b;hpb=887e744e425c6c25fcfdbad863d3c9287ad91d93;p=matthijs%2FABM2.git diff --git a/ABM2/Engine/Kernel.h b/ABM2/Engine/Kernel.h index 3eda3db..5e0df13 100755 --- a/ABM2/Engine/Kernel.h +++ b/ABM2/Engine/Kernel.h @@ -32,7 +32,7 @@ public: void RemoveTask(const CMMPointer &t); void KillAllTasks(); - void setSpriteManager(CSpriteManager*) {this->sm = sm;} + void setSpriteManager(CSpriteManager* sm) {this->sm = sm;} CSpriteManager* getSpriteManager() {return this->sm;} protected: std::list< CMMPointer > taskList; @@ -43,15 +43,25 @@ protected: class ITask : public IMMObject { public: - ITask(){canKill=false;priority=5000;} + /** Keeps a normal pointer to the kernel, to prevent pointer loops */ + ITask(CKernel* kernel){this->kernel = kernel, this->canKill=false;this->priority=5000;} virtual bool Start()=0; virtual void OnSuspend(){}; virtual void Update()=0; virtual void OnResume(){}; virtual void Stop()=0; + + bool canKill; long priority; +protected: + /** + * Returns a pointer to the current kernel + */ + CKernel *getKernel() {return this->kernel;} +private: + CKernel* kernel; }; #endif // !defined(AFX_KERNEL_H__4E822B7D_1078_4F70_BC8F_3BB4F83ED0AF__INCLUDED_)