2004-07-20 21:30:35 +02:00
|
|
|
// Scheduler.h
|
|
|
|
//
|
|
|
|
// Mark Thompson mot20@cam.ac.uk / mark@wildfiregames.com
|
|
|
|
//
|
|
|
|
// Message scheduler
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef SCHEDULER_INCLUDED
|
|
|
|
#define SCHEDULER_INCLUDED
|
|
|
|
|
|
|
|
#include <queue>
|
2005-05-18 07:32:09 +02:00
|
|
|
#include <list>
|
2005-12-18 08:33:16 +01:00
|
|
|
#include <set>
|
2005-05-18 07:32:09 +02:00
|
|
|
|
2004-07-20 21:30:35 +02:00
|
|
|
#include "EntityMessage.h"
|
|
|
|
#include "EntityHandles.h"
|
|
|
|
#include "Singleton.h"
|
|
|
|
#include "CStr.h"
|
2005-04-15 06:23:33 +02:00
|
|
|
#include "scripting/ScriptableObject.h"
|
|
|
|
|
|
|
|
class CJSProgressTimer;
|
2004-07-20 21:30:35 +02:00
|
|
|
|
|
|
|
// Message, destination and delivery time information.
|
|
|
|
struct SDispatchObject
|
|
|
|
{
|
2005-12-18 08:33:16 +01:00
|
|
|
int id;
|
2004-07-20 21:30:35 +02:00
|
|
|
size_t deliveryTime;
|
|
|
|
bool isRecurrent; size_t delay;
|
2005-12-18 08:33:16 +01:00
|
|
|
SDispatchObject( int _id, const size_t _deliveryTime )
|
|
|
|
: id(_id), deliveryTime( _deliveryTime ), isRecurrent( false ) {}
|
|
|
|
SDispatchObject( int _id, const size_t _deliveryTime, const size_t _recurrence )
|
|
|
|
: id(_id), deliveryTime( _deliveryTime ), isRecurrent( true ), delay( _recurrence ) {}
|
2004-07-20 21:30:35 +02:00
|
|
|
inline bool operator<( const SDispatchObject& compare ) const
|
|
|
|
{
|
2004-07-20 23:12:28 +02:00
|
|
|
return( deliveryTime > compare.deliveryTime );
|
2004-07-20 21:30:35 +02:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
struct SDispatchObjectScript : public SDispatchObject
|
|
|
|
{
|
2004-09-03 16:08:12 +02:00
|
|
|
CStrW script;
|
2004-07-20 21:30:35 +02:00
|
|
|
JSObject* operateOn;
|
2005-12-18 08:33:16 +01:00
|
|
|
inline SDispatchObjectScript( int _id, const CStrW& _script,
|
|
|
|
const size_t _deliveryTime, JSObject* _operateOn = NULL )
|
|
|
|
: SDispatchObject( _id, _deliveryTime ), script( _script ), operateOn( _operateOn ) {}
|
|
|
|
inline SDispatchObjectScript( int _id, const CStrW& _script,
|
|
|
|
const size_t _deliveryTime, JSObject* _operateOn, const size_t recurrence )
|
|
|
|
: SDispatchObject( _id, _deliveryTime, recurrence ), script( _script ), operateOn( _operateOn ) {}
|
2004-07-20 21:30:35 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct SDispatchObjectFunction : public SDispatchObject
|
|
|
|
{
|
|
|
|
JSFunction* function;
|
|
|
|
JSObject* operateOn;
|
2005-12-18 08:33:16 +01:00
|
|
|
inline SDispatchObjectFunction( int _id, JSFunction* _function,
|
|
|
|
const size_t _deliveryTime, JSObject* _operateOn = NULL )
|
|
|
|
: SDispatchObject( _id, _deliveryTime ), function( _function ), operateOn( _operateOn ) {}
|
|
|
|
inline SDispatchObjectFunction( int _id, JSFunction* _function,
|
|
|
|
const size_t _deliveryTime, JSObject* _operateOn, const size_t recurrence )
|
|
|
|
: SDispatchObject( _id, _deliveryTime, recurrence ), function( _function ), operateOn( _operateOn ) {}
|
2004-07-20 21:30:35 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct CScheduler : public Singleton<CScheduler>
|
|
|
|
{
|
|
|
|
std::priority_queue<SDispatchObjectScript> timeScript, frameScript;
|
|
|
|
std::priority_queue<SDispatchObjectFunction> timeFunction, frameFunction;
|
2005-04-15 06:23:33 +02:00
|
|
|
std::list<CJSProgressTimer*> progressTimers;
|
2005-12-18 08:33:16 +01:00
|
|
|
int m_nextTaskId;
|
2004-07-20 21:30:35 +02:00
|
|
|
bool m_abortInterval;
|
2005-12-18 08:41:02 +01:00
|
|
|
STL_HASH_SET<int> tasksToCancel;
|
2004-07-20 21:30:35 +02:00
|
|
|
|
2005-12-18 08:33:16 +01:00
|
|
|
CScheduler();
|
|
|
|
int pushTime( size_t delay, const CStrW& fragment, JSObject* operateOn = NULL );
|
|
|
|
int pushFrame( size_t delay, const CStrW& fragment, JSObject* operateOn = NULL );
|
|
|
|
int pushInterval( size_t first, size_t interval, const CStrW& fragment, JSObject* operateOn = NULL, int id = 0 );
|
|
|
|
int pushTime( size_t delay, JSFunction* function, JSObject* operateOn = NULL );
|
|
|
|
int pushFrame( size_t delay, JSFunction* function, JSObject* operateOn = NULL );
|
|
|
|
int pushInterval( size_t first, size_t interval, JSFunction* function, JSObject* operateOn = NULL, int id = 0 );
|
2005-04-15 06:23:33 +02:00
|
|
|
void pushProgressTimer( CJSProgressTimer* progressTimer );
|
2005-12-18 08:33:16 +01:00
|
|
|
void cancelTask( int id );
|
2004-07-27 23:00:53 +02:00
|
|
|
void update(size_t elapsedSimulationTime);
|
2004-07-20 21:30:35 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#define g_Scheduler CScheduler::GetSingleton()
|
|
|
|
|
2005-04-15 06:23:33 +02:00
|
|
|
class CJSProgressTimer : public CJSObject<CJSProgressTimer>
|
|
|
|
{
|
2005-05-18 07:32:09 +02:00
|
|
|
friend struct CScheduler;
|
2005-04-15 06:23:33 +02:00
|
|
|
double m_Max, m_Current, m_Increment;
|
|
|
|
JSFunction* m_Callback;
|
|
|
|
JSObject* m_OperateOn;
|
|
|
|
CJSProgressTimer( double Max, double Increment, JSFunction* Callback, JSObject* OperateOn );
|
2005-08-09 17:55:44 +02:00
|
|
|
static JSBool Construct( JSContext* cx, JSObject* obj, uint argc, jsval* argv, jsval* rval );
|
2005-04-15 06:23:33 +02:00
|
|
|
public:
|
|
|
|
static void ScriptingInit();
|
|
|
|
};
|
|
|
|
|
2005-08-15 01:34:37 +02:00
|
|
|
// made visible to main.cpp's Frame() so that it can abort after 100 frames
|
|
|
|
// if g_FixedFrameTiming == true (allows measuring performance).
|
|
|
|
extern size_t frameCount;
|
|
|
|
|
2004-10-07 21:23:35 +02:00
|
|
|
extern const int ORDER_DELAY;
|
|
|
|
|
2004-07-27 23:00:53 +02:00
|
|
|
#endif
|