2012-02-09 14:07:11 +08:00
|
|
|
/****************************************************************************
|
2012-09-24 21:22:20 +08:00
|
|
|
Copyright (c) 2010-2012 cocos2d-x.org
|
2012-09-02 00:38:57 +08:00
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
2012-02-09 14:07:11 +08:00
|
|
|
|
|
|
|
#ifndef __SCRIPT_SUPPORT_H__
|
|
|
|
#define __SCRIPT_SUPPORT_H__
|
|
|
|
|
2012-06-19 13:50:11 +08:00
|
|
|
#include "platform/CCCommon.h"
|
2012-11-14 06:58:11 +08:00
|
|
|
#include "CCAccelerometer.h"
|
2012-06-19 13:50:11 +08:00
|
|
|
#include "touch_dispatcher/CCTouch.h"
|
|
|
|
#include "cocoa/CCSet.h"
|
2012-12-02 15:17:34 +08:00
|
|
|
#include "CCAccelerometer.h"
|
2012-08-25 15:05:59 +08:00
|
|
|
#include <map>
|
|
|
|
#include <string>
|
|
|
|
#include <list>
|
2012-02-09 14:07:11 +08:00
|
|
|
|
|
|
|
typedef struct lua_State lua_State;
|
|
|
|
|
|
|
|
NS_CC_BEGIN
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
class Timer;
|
|
|
|
class Layer;
|
|
|
|
class MenuItem;
|
|
|
|
class NotificationCenter;
|
|
|
|
class CallFunc;
|
|
|
|
class Acceleration;
|
2012-09-11 14:02:33 +08:00
|
|
|
|
2012-08-31 21:23:23 +08:00
|
|
|
enum ccScriptType {
|
|
|
|
kScriptTypeNone = 0,
|
|
|
|
kScriptTypeLua,
|
|
|
|
kScriptTypeJavascript
|
|
|
|
};
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
class ScriptHandlerEntry : public Object
|
2012-08-28 12:08:15 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-06-20 14:13:12 +08:00
|
|
|
static ScriptHandlerEntry* create(int nHandler);
|
|
|
|
~ScriptHandlerEntry(void);
|
2012-08-28 12:08:15 +08:00
|
|
|
|
|
|
|
int getHandler(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _handler;
|
2012-08-28 12:08:15 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
int getEntryId(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _entryId;
|
2012-08-28 12:08:15 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
protected:
|
2013-06-20 14:13:12 +08:00
|
|
|
ScriptHandlerEntry(int nHandler)
|
2013-06-15 14:03:30 +08:00
|
|
|
: _handler(nHandler)
|
2012-08-28 12:08:15 +08:00
|
|
|
{
|
|
|
|
static int newEntryId = 0;
|
|
|
|
newEntryId++;
|
2013-06-15 14:03:30 +08:00
|
|
|
_entryId = newEntryId;
|
2012-08-28 12:08:15 +08:00
|
|
|
}
|
|
|
|
|
2013-06-15 14:03:30 +08:00
|
|
|
int _handler;
|
|
|
|
int _entryId;
|
2012-08-28 12:08:15 +08:00
|
|
|
};
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2012-06-20 18:09:11 +08:00
|
|
|
/**
|
|
|
|
* @addtogroup script_support
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
class SchedulerScriptHandlerEntry : public ScriptHandlerEntry
|
2012-02-09 14:07:11 +08:00
|
|
|
{
|
|
|
|
public:
|
|
|
|
// nHandler return by tolua_ref_function(), called from LuaCocos2d.cpp
|
2013-06-20 14:13:12 +08:00
|
|
|
static SchedulerScriptHandlerEntry* create(int nHandler, float fInterval, bool bPaused);
|
|
|
|
~SchedulerScriptHandlerEntry(void);
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
cocos2d::Timer* getTimer(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _timer;
|
2012-02-09 14:07:11 +08:00
|
|
|
}
|
|
|
|
|
2012-08-28 12:08:15 +08:00
|
|
|
bool isPaused(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _paused;
|
2012-02-09 14:07:11 +08:00
|
|
|
}
|
|
|
|
|
2012-08-28 12:08:15 +08:00
|
|
|
void markedForDeletion(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
_markedForDeletion = true;
|
2012-02-09 14:07:11 +08:00
|
|
|
}
|
|
|
|
|
2012-08-28 12:08:15 +08:00
|
|
|
bool isMarkedForDeletion(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _markedForDeletion;
|
2012-02-09 14:07:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2013-06-20 14:13:12 +08:00
|
|
|
SchedulerScriptHandlerEntry(int nHandler)
|
|
|
|
: ScriptHandlerEntry(nHandler)
|
2013-06-15 14:03:30 +08:00
|
|
|
, _timer(NULL)
|
|
|
|
, _paused(false)
|
|
|
|
, _markedForDeletion(false)
|
2012-08-28 12:08:15 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
bool init(float fInterval, bool bPaused);
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
cocos2d::Timer* _timer;
|
2013-06-15 14:03:30 +08:00
|
|
|
bool _paused;
|
|
|
|
bool _markedForDeletion;
|
2012-02-09 14:07:11 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2012-08-28 12:08:15 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
class TouchScriptHandlerEntry : public ScriptHandlerEntry
|
2012-02-09 14:07:11 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-06-20 14:13:12 +08:00
|
|
|
static TouchScriptHandlerEntry* create(int nHandler, bool bIsMultiTouches, int nPriority, bool bSwallowsTouches);
|
|
|
|
~TouchScriptHandlerEntry(void);
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2012-08-28 12:08:15 +08:00
|
|
|
bool isMultiTouches(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _isMultiTouches;
|
2012-02-09 14:07:11 +08:00
|
|
|
}
|
|
|
|
|
2012-08-28 12:08:15 +08:00
|
|
|
int getPriority(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _priority;
|
2012-02-09 14:07:11 +08:00
|
|
|
}
|
|
|
|
|
2012-08-28 12:08:15 +08:00
|
|
|
bool getSwallowsTouches(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _swallowsTouches;
|
2012-02-09 14:07:11 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
2013-06-20 14:13:12 +08:00
|
|
|
TouchScriptHandlerEntry(int nHandler)
|
|
|
|
: ScriptHandlerEntry(nHandler)
|
2013-06-15 14:03:30 +08:00
|
|
|
, _isMultiTouches(false)
|
|
|
|
, _priority(0)
|
|
|
|
, _swallowsTouches(false)
|
2012-08-28 12:08:15 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
bool init(bool bIsMultiTouches, int nPriority, bool bSwallowsTouches);
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2013-06-15 14:03:30 +08:00
|
|
|
bool _isMultiTouches;
|
|
|
|
int _priority;
|
|
|
|
bool _swallowsTouches;
|
2012-02-09 14:07:11 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
// Don't make ScriptEngineProtocol inherits from Object since setScriptEngine is invoked only once in AppDelegate.cpp,
|
2012-08-29 14:55:55 +08:00
|
|
|
// It will affect the lifecycle of ScriptCore instance, the autorelease pool will be destroyed before destructing ScriptCore.
|
|
|
|
// So a crash will appear on Win32 if you click the close button.
|
2013-06-20 14:13:12 +08:00
|
|
|
class CC_DLL ScriptEngineProtocol
|
2012-02-09 14:07:11 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual ~ScriptEngineProtocol() {};
|
2012-09-02 00:38:57 +08:00
|
|
|
|
2012-09-11 14:02:33 +08:00
|
|
|
/** Get script type */
|
2012-08-31 21:23:23 +08:00
|
|
|
virtual ccScriptType getScriptType() { return kScriptTypeNone; };
|
2012-09-10 18:38:18 +08:00
|
|
|
|
2012-09-11 14:02:33 +08:00
|
|
|
/** Remove script object. */
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual void removeScriptObjectByObject(Object* pObj) = 0;
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
/** Remove script function handler, only LuaEngine class need to implement this function. */
|
2012-09-11 14:02:33 +08:00
|
|
|
virtual void removeScriptHandler(int nHandler) {};
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
/** Reallocate script function handler, only LuaEngine class need to implement this function. */
|
2013-06-05 15:51:29 +08:00
|
|
|
virtual int reallocateScriptHandler(int nHandler) { return -1;}
|
2013-06-05 15:17:00 +08:00
|
|
|
|
2012-02-09 14:07:11 +08:00
|
|
|
/**
|
|
|
|
@brief Execute script code contained in the given string.
|
|
|
|
@param codes holding the valid script code that should be executed.
|
2012-09-17 15:02:24 +08:00
|
|
|
@return 0 if the string is executed correctly.
|
|
|
|
@return other if the string is executed wrongly.
|
2012-02-09 14:07:11 +08:00
|
|
|
*/
|
|
|
|
virtual int executeString(const char* codes) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
@brief Execute a script file.
|
|
|
|
@param filename String object holding the filename of the script file that is to be executed
|
|
|
|
*/
|
|
|
|
virtual int executeScriptFile(const char* filename) = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
@brief Execute a scripted global function.
|
|
|
|
@brief The function should not take any parameters and should return an integer.
|
|
|
|
@param functionName String object holding the name of the function, in the global script environment, that is to be executed.
|
|
|
|
@return The integer value returned from the script function.
|
|
|
|
*/
|
|
|
|
virtual int executeGlobalFunction(const char* functionName) = 0;
|
|
|
|
|
|
|
|
/**
|
2012-09-11 14:02:33 +08:00
|
|
|
@brief Execute a node event function
|
|
|
|
@param pNode which node produce this event
|
2013-06-20 14:13:12 +08:00
|
|
|
@param nAction kNodeOnEnter,kNodeOnExit,kMenuItemActivated,kNodeOnEnterTransitionDidFinish,kNodeOnExitTransitionDidStart
|
2012-02-09 14:07:11 +08:00
|
|
|
@return The integer value returned from the script function.
|
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeNodeEvent(Node* pNode, int nAction) = 0;
|
2012-09-11 14:02:33 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeMenuItemEvent(MenuItem* pMenuItem) = 0;
|
2012-09-11 14:02:33 +08:00
|
|
|
/** Execute a notification event function */
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeNotificationEvent(NotificationCenter* pNotificationCenter, const char* pszName) = 0;
|
2012-08-27 14:05:38 +08:00
|
|
|
|
2012-09-11 14:02:33 +08:00
|
|
|
/** execute a callfun event */
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeCallFuncActionEvent(CallFunc* pAction, Object* pTarget = NULL) = 0;
|
2012-09-11 14:02:33 +08:00
|
|
|
/** execute a schedule function */
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeSchedule(int nHandler, float dt, Node* pNode = NULL) = 0;
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2012-11-06 14:18:13 +08:00
|
|
|
/** functions for executing touch event */
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeLayerTouchesEvent(Layer* pLayer, int eventType, Set *pTouches) = 0;
|
|
|
|
virtual int executeLayerTouchEvent(Layer* pLayer, int eventType, Touch *pTouch) = 0;
|
2012-11-06 14:18:13 +08:00
|
|
|
|
2012-12-02 15:17:34 +08:00
|
|
|
/** functions for keypad event */
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeLayerKeypadEvent(Layer* pLayer, int eventType) = 0;
|
2012-12-02 15:17:34 +08:00
|
|
|
|
2012-11-06 14:18:13 +08:00
|
|
|
/** execute a accelerometer event */
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeAccelerometerEvent(Layer* pLayer, Acceleration* pAccelerationValue) = 0;
|
2013-02-02 02:05:52 +08:00
|
|
|
|
|
|
|
/** function for common event */
|
2013-06-20 14:13:12 +08:00
|
|
|
virtual int executeEvent(int nHandler, const char* pEventName, Object* pEventSource = NULL, const char* pEventSourceClassName = NULL) = 0;
|
2013-04-15 22:50:07 +08:00
|
|
|
|
|
|
|
/** called by CCAssert to allow scripting engine to handle failed assertions
|
|
|
|
* @return true if the assert was handled by the script engine, false otherwise.
|
|
|
|
*/
|
|
|
|
virtual bool handleAssert(const char *msg) = 0;
|
2012-02-09 14:07:11 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
2013-06-20 14:13:12 +08:00
|
|
|
ScriptEngineManager is a singleton which holds an object instance of ScriptEngineProtocl
|
2012-02-09 14:07:11 +08:00
|
|
|
It helps cocos2d-x and the user code to find back LuaEngine object
|
|
|
|
@since v0.99.5-x-0.8.5
|
|
|
|
*/
|
2013-06-20 14:13:12 +08:00
|
|
|
class CC_DLL ScriptEngineManager
|
2012-02-09 14:07:11 +08:00
|
|
|
{
|
|
|
|
public:
|
2013-06-20 14:13:12 +08:00
|
|
|
~ScriptEngineManager(void);
|
2012-02-09 14:07:11 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
ScriptEngineProtocol* getScriptEngine(void) {
|
2013-06-15 14:03:30 +08:00
|
|
|
return _scriptEngine;
|
2012-02-09 14:07:11 +08:00
|
|
|
}
|
2013-06-20 14:13:12 +08:00
|
|
|
void setScriptEngine(ScriptEngineProtocol *pScriptEngine);
|
2012-02-09 14:07:11 +08:00
|
|
|
void removeScriptEngine(void);
|
2012-09-02 00:38:57 +08:00
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
static ScriptEngineManager* sharedManager(void);
|
2012-02-09 14:07:11 +08:00
|
|
|
static void purgeSharedManager(void);
|
2012-09-02 00:38:57 +08:00
|
|
|
|
2012-02-09 14:07:11 +08:00
|
|
|
private:
|
2013-06-20 14:13:12 +08:00
|
|
|
ScriptEngineManager(void)
|
2013-06-15 14:03:30 +08:00
|
|
|
: _scriptEngine(NULL)
|
2012-02-09 14:07:11 +08:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
2013-06-20 14:13:12 +08:00
|
|
|
ScriptEngineProtocol *_scriptEngine;
|
2012-02-09 14:07:11 +08:00
|
|
|
};
|
|
|
|
|
2012-06-20 18:09:11 +08:00
|
|
|
// end of script_support group
|
|
|
|
/// @}
|
|
|
|
|
2012-02-09 14:07:11 +08:00
|
|
|
NS_CC_END
|
|
|
|
|
|
|
|
#endif // __SCRIPT_SUPPORT_H__
|