From ea92936c1fdd0f9277900c7a6be52705ddaa6b89 Mon Sep 17 00:00:00 2001 From: Rohan Kuruvilla Date: Wed, 31 Oct 2012 11:08:37 -0700 Subject: [PATCH] Adding bindings for CCBReader and other improvements. 1. Added additional CCBReader bindings, including callback support for animationCompleted 2. Improved design for JS CallbackWrappers 3. Added bindings for pDistance 4. Updating cocos2dx.ini --- .../javascript/bindings/ScriptingCore.cpp | 40 ++++---- .../javascript/bindings/cocos2d_specifics.cpp | 92 +++++++++++-------- .../javascript/bindings/cocos2d_specifics.hpp | 87 ++++++++++-------- .../bindings/js_bindings_ccbreader.cpp | 31 ++++++- tools/tojs/cocos2dx.ini | 3 +- 5 files changed, 159 insertions(+), 94 deletions(-) diff --git a/scripting/javascript/bindings/ScriptingCore.cpp b/scripting/javascript/bindings/ScriptingCore.cpp index d2b19da945..5a294deefe 100644 --- a/scripting/javascript/bindings/ScriptingCore.cpp +++ b/scripting/javascript/bindings/ScriptingCore.cpp @@ -597,7 +597,7 @@ JSBool ScriptingCore::removeRootJS(JSContext *cx, uint32_t argc, jsval *vp) void ScriptingCore::pauseSchedulesAndActions(CCNode *node) { - CCArray * arr = JSSchedule::getTargetForNativeNode(node); + CCArray * arr = JSScheduleWrapper::getTargetForNativeNode(node); if(! arr) return; for(unsigned int i = 0; i < arr->count(); ++i) { if(arr->objectAtIndex(i)) { @@ -609,7 +609,7 @@ void ScriptingCore::pauseSchedulesAndActions(CCNode *node) { void ScriptingCore::resumeSchedulesAndActions(CCNode *node) { - CCArray * arr = JSSchedule::getTargetForNativeNode(node); + CCArray * arr = JSScheduleWrapper::getTargetForNativeNode(node); if(!arr) return; for(unsigned int i = 0; i < arr->count(); ++i) { if(!arr->objectAtIndex(i)) continue; @@ -619,12 +619,12 @@ void ScriptingCore::resumeSchedulesAndActions(CCNode *node) { void ScriptingCore::cleanupSchedulesAndActions(CCNode *node) { - CCArray * arr = JSCallFunc::getTargetForNativeNode(node); + CCArray * arr = JSCallFuncWrapper::getTargetForNativeNode(node); if(arr) { arr->removeAllObjects(); } - arr = JSSchedule::getTargetForNativeNode(node); + arr = JSScheduleWrapper::getTargetForNativeNode(node); if(arr) { arr->removeAllObjects(); } @@ -1016,20 +1016,26 @@ CCArray* jsval_to_ccarray(JSContext* cx, jsval v) { jsval ccarray_to_jsval(JSContext* cx, CCArray *arr) { - - JSObject *jsretArr = JS_NewArrayObject(cx, 0, NULL); - - for(int i = 0; i < arr->count(); ++i) { - - CCObject *obj = arr->objectAtIndex(i); - js_proxy_t *proxy = js_get_or_create_proxy(cx, obj); - jsval arrElement = OBJECT_TO_JSVAL(proxy->obj); - - if(!JS_SetElement(cx, jsretArr, i, &arrElement)) { - break; + + JSObject *jsretArr = JS_NewArrayObject(cx, 0, NULL); + + for(int i = 0; i < arr->count(); ++i) { + jsval arrElement; + CCObject *obj = arr->objectAtIndex(i); + + CCString *testString = dynamic_cast(obj); + if(testString) { + arrElement = c_string_to_jsval(cx, testString->getCString()); + } else { + js_proxy_t *proxy = js_get_or_create_proxy(cx, obj); + arrElement = OBJECT_TO_JSVAL(proxy->obj); + } + + if(!JS_SetElement(cx, jsretArr, i, &arrElement)) { + break; + } } - } - return OBJECT_TO_JSVAL(jsretArr); + return OBJECT_TO_JSVAL(jsretArr); } jsval long_long_to_jsval(JSContext* cx, long long v) { diff --git a/scripting/javascript/bindings/cocos2d_specifics.cpp b/scripting/javascript/bindings/cocos2d_specifics.cpp index a06aa71f2a..e6d2f784fe 100644 --- a/scripting/javascript/bindings/cocos2d_specifics.cpp +++ b/scripting/javascript/bindings/cocos2d_specifics.cpp @@ -545,19 +545,19 @@ JSBool js_platform(JSContext *cx, uint32_t argc, jsval *vp) } -void JSCallFunc::setJSCallbackFunc(jsval func) { +void JSCallbackWrapper::setJSCallbackFunc(jsval func) { jsCallback = func; } -void JSCallFunc::setJSCallbackThis(jsval thisObj) { +void JSCallbackWrapper::setJSCallbackThis(jsval thisObj) { jsThisObj = thisObj; } -void JSCallFunc::setExtraDataField(jsval data) { +void JSCallbackWrapper::setJSExtraData(jsval data) { extraData = data; } -void JSCallFunc::setTargetForNativeNode(CCNode *pNode, JSCallFunc *target) { +void JSCallFuncWrapper::setTargetForNativeNode(CCNode *pNode, JSCallFuncWrapper *target) { callfuncTarget_proxy_t *t; HASH_FIND_PTR(_callfuncTarget_native_ht, &pNode, t); @@ -577,7 +577,7 @@ void JSCallFunc::setTargetForNativeNode(CCNode *pNode, JSCallFunc *target) { HASH_ADD_PTR(_callfuncTarget_native_ht, ptr, p); } -CCArray * JSCallFunc::getTargetForNativeNode(CCNode *pNode) { +CCArray * JSCallFuncWrapper::getTargetForNativeNode(CCNode *pNode) { schedTarget_proxy_t *t; HASH_FIND_PTR(_callfuncTarget_native_ht, &pNode, t); @@ -596,18 +596,18 @@ JSBool js_callFunc(JSContext *cx, uint32_t argc, jsval *vp) if (argc >= 1) { jsval *argv = JS_ARGV(cx, vp); - JSCallFunc *tmpCobj = new JSCallFunc(); + JSCallFuncWrapper *tmpCobj = new JSCallFuncWrapper(); tmpCobj->autorelease(); tmpCobj->setJSCallbackThis(argv[0]); if(argc >= 2) { tmpCobj->setJSCallbackFunc(argv[1]); } if(argc == 3) { - tmpCobj->setExtraDataField(argv[2]); + tmpCobj->setJSExtraData(argv[2]); } CCCallFunc *ret = (CCCallFunc *)CCCallFuncN::create((CCObject *)tmpCobj, - callfuncN_selector(JSCallFunc::callbackFunc)); + callfuncN_selector(JSCallFuncWrapper::callbackFunc)); js_proxy_t *proxy = js_get_or_create_proxy(cx, ret); JS_SET_RVAL(cx, vp, OBJECT_TO_JSVAL(proxy->obj)); @@ -624,7 +624,8 @@ JSBool js_callFunc(JSContext *cx, uint32_t argc, jsval *vp) } -void JSSchedule::setTargetForSchedule(jsval sched, JSSchedule *target) { + +void JSScheduleWrapper::setTargetForSchedule(jsval sched, JSScheduleWrapper *target) { do { schedFunc_proxy_t *p = (schedFunc_proxy_t *)malloc(sizeof(schedFunc_proxy_t)); assert(p); @@ -634,7 +635,7 @@ void JSSchedule::setTargetForSchedule(jsval sched, JSSchedule *target) { } while(0); } -JSSchedule * JSSchedule::getTargetForSchedule(jsval sched) { +JSScheduleWrapper * JSScheduleWrapper::getTargetForSchedule(jsval sched) { schedFunc_proxy_t *t; JSObject *o = JSVAL_TO_OBJECT(sched); HASH_FIND_PTR(_schedFunc_target_ht, &o, t); @@ -642,7 +643,7 @@ JSSchedule * JSSchedule::getTargetForSchedule(jsval sched) { } -void JSSchedule::setTargetForNativeNode(CCNode *pNode, JSSchedule *target) { +void JSScheduleWrapper::setTargetForNativeNode(CCNode *pNode, JSScheduleWrapper *target) { schedTarget_proxy_t *t; HASH_FIND_PTR(_schedTarget_native_ht, &pNode, t); @@ -662,7 +663,7 @@ void JSSchedule::setTargetForNativeNode(CCNode *pNode, JSSchedule *target) { HASH_ADD_PTR(_schedTarget_native_ht, ptr, p); } -CCArray * JSSchedule::getTargetForNativeNode(CCNode *pNode) { +CCArray * JSScheduleWrapper::getTargetForNativeNode(CCNode *pNode) { schedTarget_proxy_t *t; HASH_FIND_PTR(_schedTarget_native_ht, &pNode, t); @@ -673,15 +674,6 @@ CCArray * JSSchedule::getTargetForNativeNode(CCNode *pNode) { } -void JSSchedule::setJSScheduleFunc(jsval func) { - jsSchedule = func; -} - -void JSSchedule::setJSScheduleThis(jsval thisObj) { - jsThisObj = thisObj; -} - - JSBool js_CCNode_unschedule(JSContext *cx, uint32_t argc, jsval *vp) { @@ -698,9 +690,9 @@ JSBool js_CCNode_unschedule(JSContext *cx, uint32_t argc, jsval *vp) CCScheduler *sched = node->getScheduler(); - JSSchedule *tmpCobj = JSSchedule::getTargetForSchedule(argv[0]); + JSScheduleWrapper *tmpCobj = JSScheduleWrapper::getTargetForSchedule(argv[0]); - sched->unscheduleSelector(schedule_selector(JSSchedule::scheduleFunc), tmpCobj); + sched->unscheduleSelector(schedule_selector(JSScheduleWrapper::scheduleFunc), tmpCobj); JS_SET_RVAL(cx, vp, JSVAL_VOID); } @@ -722,7 +714,7 @@ JSBool js_CCNode_scheduleOnce(JSContext *cx, uint32_t argc, jsval *vp) CCScheduler *sched = node->getScheduler(); - JSSchedule *tmpCobj = new JSSchedule(); + JSScheduleWrapper *tmpCobj = new JSScheduleWrapper(); // @@ -734,16 +726,16 @@ JSBool js_CCNode_scheduleOnce(JSContext *cx, uint32_t argc, jsval *vp) return JS_FALSE; } - tmpCobj->setJSScheduleThis(OBJECT_TO_JSVAL(obj)); - tmpCobj->setJSScheduleFunc(argv[0]); + tmpCobj->setJSCallbackThis(OBJECT_TO_JSVAL(obj)); + tmpCobj->setJSCallbackFunc(argv[0]); - JSSchedule::setTargetForSchedule(argv[0], tmpCobj); - JSSchedule::setTargetForNativeNode(node, tmpCobj); + JSScheduleWrapper::setTargetForSchedule(argv[0], tmpCobj); + JSScheduleWrapper::setTargetForNativeNode(node, tmpCobj); if(argc == 1) { - sched->scheduleSelector(schedule_selector(JSSchedule::scheduleFunc), tmpCobj, 0, node->isRunning(), 0, 0); + sched->scheduleSelector(schedule_selector(JSScheduleWrapper::scheduleFunc), tmpCobj, 0, node->isRunning(), 0, 0); } else { - sched->scheduleSelector(schedule_selector(JSSchedule::scheduleFunc), tmpCobj, interval, node->isRunning(), 0, 0); + sched->scheduleSelector(schedule_selector(JSScheduleWrapper::scheduleFunc), tmpCobj, interval, node->isRunning(), 0, 0); } JS_SET_RVAL(cx, vp, JSVAL_VOID); @@ -770,7 +762,7 @@ JSBool js_CCNode_schedule(JSContext *cx, uint32_t argc, jsval *vp) CCScheduler *sched = node->getScheduler(); js_proxy_t *p = js_get_or_create_proxy(cx, sched); - JSSchedule *tmpCobj = new JSSchedule(); + JSScheduleWrapper *tmpCobj = new JSScheduleWrapper(); double interval; if( argc >= 2 ) { @@ -796,20 +788,20 @@ JSBool js_CCNode_schedule(JSContext *cx, uint32_t argc, jsval *vp) return JS_FALSE; } - tmpCobj->setJSScheduleThis(OBJECT_TO_JSVAL(obj)); - tmpCobj->setJSScheduleFunc(argv[0]); + tmpCobj->setJSCallbackThis(OBJECT_TO_JSVAL(obj)); + tmpCobj->setJSCallbackFunc(argv[0]); - JSSchedule::setTargetForSchedule(argv[0], tmpCobj); - JSSchedule::setTargetForNativeNode(node, tmpCobj); + JSScheduleWrapper::setTargetForSchedule(argv[0], tmpCobj); + JSScheduleWrapper::setTargetForNativeNode(node, tmpCobj); if(argc == 1) { - sched->scheduleSelector(schedule_selector(JSSchedule::scheduleFunc), tmpCobj, 0, node->isRunning()); + sched->scheduleSelector(schedule_selector(JSScheduleWrapper::scheduleFunc), tmpCobj, 0, node->isRunning()); } if(argc == 2) { - sched->scheduleSelector(schedule_selector(JSSchedule::scheduleFunc), tmpCobj, interval, node->isRunning()); + sched->scheduleSelector(schedule_selector(JSScheduleWrapper::scheduleFunc), tmpCobj, interval, node->isRunning()); } if(argc == 3) { - sched->scheduleSelector(schedule_selector(JSSchedule::scheduleFunc), tmpCobj, 0, node->isRunning(), repeat, 0); + sched->scheduleSelector(schedule_selector(JSScheduleWrapper::scheduleFunc), tmpCobj, 0, node->isRunning(), repeat, 0); } if (argc == 4) { - sched->scheduleSelector(schedule_selector(JSSchedule::scheduleFunc), tmpCobj, 0, node->isRunning(), repeat, delay); + sched->scheduleSelector(schedule_selector(JSScheduleWrapper::scheduleFunc), tmpCobj, 0, node->isRunning(), repeat, delay); } @@ -1143,6 +1135,27 @@ JSBool js_cocos2dx_ccpAdd(JSContext *cx, uint32_t argc, jsval *vp) return JS_FALSE; } +JSBool js_cocos2dx_ccpDistance(JSContext *cx, uint32_t argc, jsval *vp) +{ + jsval *argv = JS_ARGV(cx, vp); + + if (argc == 2) { + cocos2d::CCPoint arg0; + arg0 = jsval_to_ccpoint(cx, argv[0]); + cocos2d::CCPoint arg1; + arg1 = jsval_to_ccpoint(cx, argv[1]); + + float ret = ccpDistance(arg0, arg1); + + jsval jsret = DOUBLE_TO_JSVAL(ret); + JS_SET_RVAL(cx, vp, jsret); + return JS_TRUE; + } + + JS_ReportError(cx, "wrong number of arguments: %d, was expecting %d", argc, 1); + return JS_FALSE; +} + JSBool js_cocos2dx_ccpClamp(JSContext *cx, uint32_t argc, jsval *vp) { jsval *argv = JS_ARGV(cx, vp); @@ -1596,6 +1609,7 @@ void register_cocos2dx_js_extensions(JSContext* cx, JSObject* global) JS_DefineFunction(cx, tmpObj, "garbageCollect", js_forceGC, 1, JSPROP_READONLY | JSPROP_PERMANENT); JS_DefineFunction(cx, ns, "pAdd", js_cocos2dx_ccpAdd, 1, JSPROP_READONLY | JSPROP_PERMANENT); + JS_DefineFunction(cx, ns, "pDistance", js_cocos2dx_ccpDistance, 1, JSPROP_READONLY | JSPROP_PERMANENT); JS_DefineFunction(cx, ns, "pSub", js_cocos2dx_ccpSub, 0, JSPROP_READONLY | JSPROP_PERMANENT); JS_DefineFunction(cx, ns, "pNeg", js_cocos2dx_ccpNeg, 0, JSPROP_READONLY | JSPROP_PERMANENT); JS_DefineFunction(cx, ns, "pMult", js_cocos2dx_ccpMult, 0, JSPROP_READONLY | JSPROP_PERMANENT); diff --git a/scripting/javascript/bindings/cocos2d_specifics.hpp b/scripting/javascript/bindings/cocos2d_specifics.hpp index c8c6b8c13b..25f3d541f6 100644 --- a/scripting/javascript/bindings/cocos2d_specifics.hpp +++ b/scripting/javascript/bindings/cocos2d_specifics.hpp @@ -4,11 +4,11 @@ #include "jsapi.h" #include "ScriptingCore.h" -class JSSchedule; +class JSScheduleWrapper; typedef struct jsScheduleFunc_proxy { void * ptr; - JSSchedule *obj; + JSScheduleWrapper *obj; UT_hash_handle hh; } schedFunc_proxy_t; @@ -79,19 +79,48 @@ inline js_proxy_t *js_get_or_create_proxy(JSContext *cx, T *native_obj) { jsval anonEvaluate(JSContext *cx, JSObject *thisObj, const char* string); void register_cocos2dx_js_extensions(JSContext* cx, JSObject* obj); -class JSCallFunc: public CCObject { + +class JSCallbackWrapper: public CCObject { public: - JSCallFunc(jsval func): jsCallback(func) {} - JSCallFunc() {extraData = JSVAL_VOID;} - virtual ~JSCallFunc() { - return; - } - + JSCallbackWrapper() {} + virtual ~JSCallbackWrapper(void) {} void setJSCallbackFunc(jsval obj); void setJSCallbackThis(jsval thisObj); - void setExtraDataField(jsval data); - static void dumpNamedRoot(const char *name, void *addr, JSGCRootType type, void *data); - static void setTargetForNativeNode(CCNode *pNode, JSCallFunc *target); + void setJSExtraData(jsval data); + +protected: + jsval jsCallback; + jsval jsThisObj; + jsval extraData; +}; + + +class JSCCBAnimationWrapper: public JSCallbackWrapper { +public: + JSCCBAnimationWrapper() {} + virtual ~JSCCBAnimationWrapper() {} + + void animationCompleteCallback() const { + + JSContext *cx = ScriptingCore::getInstance()->getGlobalContext(); + jsval retval = JSVAL_NULL; + + if(!JSVAL_IS_VOID(jsCallback) && !JSVAL_IS_VOID(jsThisObj)) { + JS_CallFunctionValue(cx, JSVAL_TO_OBJECT(jsThisObj), jsCallback, 0, NULL, &retval); + } + } + +}; + + +class JSCallFuncWrapper: public JSCallbackWrapper { +public: + JSCallFuncWrapper() {} + virtual ~JSCallFuncWrapper(void) { + return; + } + + static void setTargetForNativeNode(CCNode *pNode, JSCallFuncWrapper *target); static CCArray * getTargetForNativeNode(CCNode *pNode); void callbackFunc(CCNode *node) const { @@ -115,35 +144,28 @@ public: JS_CallFunctionValue(cx, JSVAL_TO_OBJECT(jsThisObj), jsCallback, 2, valArr, &retval); } - JSCallFunc::setTargetForNativeNode(node, (JSCallFunc *)this); + JSCallFuncWrapper::setTargetForNativeNode(node, (JSCallFuncWrapper *)this); JS_RemoveValueRoot(cx, valArr); } -private: - jsval jsCallback; - jsval jsThisObj; - jsval extraData; + }; -class JSSchedule: public CCObject { +class JSScheduleWrapper: public JSCallbackWrapper { public: - JSSchedule(jsval func): jsSchedule(func) {} - JSSchedule() {jsSchedule = JSVAL_VOID; jsThisObj = JSVAL_VOID;} - virtual ~JSSchedule() { + JSScheduleWrapper() {} + virtual ~JSScheduleWrapper() { return; } - static void setTargetForSchedule(jsval sched, JSSchedule *target); - static JSSchedule * getTargetForSchedule(jsval sched); - static void setTargetForNativeNode(CCNode *pNode, JSSchedule *target); + static void setTargetForSchedule(jsval sched, JSScheduleWrapper *target); + static JSScheduleWrapper * getTargetForSchedule(jsval sched); + static void setTargetForNativeNode(CCNode *pNode, JSScheduleWrapper *target); static CCArray * getTargetForNativeNode(CCNode *pNode); - void setJSScheduleFunc(jsval obj); - void setJSScheduleThis(jsval thisObj); - void pause(); void scheduleFunc(float dt) const { @@ -156,20 +178,13 @@ public: return; } - if(!JSVAL_IS_VOID(jsSchedule) && !JSVAL_IS_VOID(jsThisObj)) { - ScriptingCore::dumpRoot(cx, 0, NULL); - JS_CallFunctionValue(cx, JSVAL_TO_OBJECT(jsThisObj), jsSchedule, 1, &data, &retval); + if(!JSVAL_IS_VOID(jsCallback) && !JSVAL_IS_VOID(jsThisObj)) { + JS_CallFunctionValue(cx, JSVAL_TO_OBJECT(jsThisObj), jsCallback, 1, &data, &retval); } JS_RemoveValueRoot(cx, &data); } - -private: - - jsval jsSchedule; - jsval jsThisObj; - }; diff --git a/scripting/javascript/bindings/js_bindings_ccbreader.cpp b/scripting/javascript/bindings/js_bindings_ccbreader.cpp index b4213e878b..7c248942e9 100644 --- a/scripting/javascript/bindings/js_bindings_ccbreader.cpp +++ b/scripting/javascript/bindings/js_bindings_ccbreader.cpp @@ -71,6 +71,34 @@ jsval CCBScriptCallbackProxy::getJSOwner() { return owner; } +JSBool js_cocos2dx_CCBAnimationManager_animationCompleteCallback(JSContext *cx, uint32_t argc, jsval *vp) +{ + if (argc >= 1) { + jsval *argv = JS_ARGV(cx, vp); + + JSObject *obj = JS_THIS_OBJECT(cx, vp); + js_proxy_t *proxy; + JS_GET_NATIVE_PROXY(proxy, obj); + cocos2d::extension::CCBAnimationManager *node = (cocos2d::extension::CCBAnimationManager *)(proxy ? proxy->ptr : NULL); + + JSCCBAnimationWrapper *tmpCobj = new JSCCBAnimationWrapper(); + tmpCobj->autorelease(); + + tmpCobj->setJSCallbackThis(argv[0]); + if(argc >= 2) { + tmpCobj->setJSCallbackFunc(argv[1]); + } + + node->setAnimationCompletedCallback(tmpCobj, callfunc_selector(JSCCBAnimationWrapper::animationCompleteCallback)); + + JS_SetReservedSlot(proxy->obj, 0, argv[0]); + JS_SetReservedSlot(proxy->obj, 1, argv[1]); + return JS_TRUE; + } + return JS_FALSE; +} + + JSBool js_cocos2dx_CCBReader_readNodeGraphFromFile(JSContext *cx, uint32_t argc, jsval *vp) { jsval *argv = JS_ARGV(cx, vp); @@ -255,7 +283,7 @@ JSBool js_CocosBuilder_create(JSContext *cx, uint32_t argc, jsval *vp) } extern JSObject* js_cocos2dx_CCBReader_prototype; - +extern JSObject* js_cocos2dx_CCBAnimationManager_prototype; void register_CCBuilderReader(JSContext *cx, JSObject *obj) { jsval nsval; @@ -275,5 +303,6 @@ void register_CCBuilderReader(JSContext *cx, JSObject *obj) { JS_DefineFunction(cx, tmpObj, "loadScene", js_cocos2dx_CCBReader_createSceneWithNodeGraphFromFile, 2, JSPROP_READONLY | JSPROP_PERMANENT); JS_DefineFunction(cx, js_cocos2dx_CCBReader_prototype, "load", js_cocos2dx_CCBReader_readNodeGraphFromFile, 2, JSPROP_READONLY | JSPROP_PERMANENT); + JS_DefineFunction(cx, js_cocos2dx_CCBAnimationManager_prototype, "setCompletedAnimationCallback", js_cocos2dx_CCBAnimationManager_animationCompleteCallback, 2, JSPROP_READONLY | JSPROP_PERMANENT); } diff --git a/tools/tojs/cocos2dx.ini b/tools/tojs/cocos2dx.ini index bd1a856a37..a5e3149923 100644 --- a/tools/tojs/cocos2dx.ini +++ b/tools/tojs/cocos2dx.ini @@ -91,7 +91,8 @@ skip = CCNode::[.*Transform convertToWindowSpace getChildren setPosition getGrid CCLayerMultiplex::[*], CCCatmullRom.*::[create actionWithDuration], CCBezier.*::[create actionWithDuration], - CCBReader::[^CCBReader$ addOwnerCallbackName isJSControlled readByte getCCBMemberVariableAssigner readFloat getCCBSelectorResolver toLowerCase lastPathComponent deletePathExtension endsWith concat getResolutionScale getAnimatedProperties readBool readInt addOwnerCallbackNode addDocumentCallbackName readCachedString readNodeGraphFromData addDocumentCallbackNode getLoadedSpriteSheet initWithData readFileWithCleanUp getOwner$ readNodeGraphFromFile createSceneWithNodeGraphFromFile], + CCBReader::[^CCBReader$ addOwnerCallbackName isJSControlled readByte getCCBMemberVariableAssigner readFloat getCCBSelectorResolver toLowerCase lastPathComponent deletePathExtension endsWith concat getResolutionScale getAnimatedProperties readBool readInt addOwnerCallbackNode addDocumentCallbackName readCachedString readNodeGraphFromData addDocumentCallbackNode getLoadedSpriteSheet initWithData readFileWithCleanUp getOwner$ readNodeGraphFromFile createSceneWithNodeGraphFromFile getAnimationManagers setAnimationManagers], + CCBAnimationManager::[setAnimationCompletedCallback], CCCardinalSpline.*::[create actionWithDuration setPoints], CCTextureCache::[addPVRTCImage], CC.*Loader$::[*],