From: Jay Freeman (saurik) Date: Thu, 3 Oct 2013 03:02:17 +0000 (-0700) Subject: Move CYArray* functions from Library to Execute. X-Git-Tag: v0.9.500~133 X-Git-Url: https://git.saurik.com/cycript.git/commitdiff_plain/55f12f6a8f897cf3e13f702a9f35d7faa23e597c?ds=inline Move CYArray* functions from Library to Execute. --- diff --git a/Execute.cpp b/Execute.cpp index 5fe0439..4fe2fe0 100644 --- a/Execute.cpp +++ b/Execute.cpp @@ -324,6 +324,26 @@ bool CYIsCallable(JSContextRef context, JSValueRef value) { return value != NULL && JSValueIsObject(context, value) && JSObjectIsFunction(context, (JSObjectRef) value); } +size_t CYArrayLength(JSContextRef context, JSObjectRef array) { + return CYCastDouble(context, CYGetProperty(context, array, length_s)); +} + +JSValueRef CYArrayGet(JSContextRef context, JSObjectRef array, size_t index) { + JSValueRef exception(NULL); + JSValueRef value(JSObjectGetPropertyAtIndex(context, array, index, &exception)); + CYThrow(context, exception); + return value; +} + +void CYArrayPush(JSContextRef context, JSObjectRef array, JSValueRef value) { + JSValueRef exception(NULL); + JSValueRef arguments[1]; + arguments[0] = value; + JSObjectRef Array(CYGetCachedObject(context, CYJSString("Array_prototype"))); + JSObjectCallAsFunction(context, CYCastJSObject(context, CYGetProperty(context, Array, push_s)), array, 1, arguments, &exception); + CYThrow(context, exception); +} + static JSValueRef System_print(JSContextRef context, JSObjectRef object, JSObjectRef _this, size_t count, const JSValueRef arguments[], JSValueRef *exception) { CYTry { if (count == 0) printf("\n"); diff --git a/Library.cpp b/Library.cpp index 1f61c0e..c64268c 100644 --- a/Library.cpp +++ b/Library.cpp @@ -36,7 +36,6 @@ #include "Error.hpp" #include "Execute.hpp" -#include "JavaScript.hpp" #include "Parser.hpp" #include "String.hpp" @@ -192,26 +191,6 @@ double CYCastDouble(const char *value) { return CYCastDouble(value, strlen(value)); } -size_t CYArrayLength(JSContextRef context, JSObjectRef array) { - return CYCastDouble(context, CYGetProperty(context, array, length_s)); -} - -JSValueRef CYArrayGet(JSContextRef context, JSObjectRef array, size_t index) { - JSValueRef exception(NULL); - JSValueRef value(JSObjectGetPropertyAtIndex(context, array, index, &exception)); - CYThrow(context, exception); - return value; -} - -void CYArrayPush(JSContextRef context, JSObjectRef array, JSValueRef value) { - JSValueRef exception(NULL); - JSValueRef arguments[1]; - arguments[0] = value; - JSObjectRef Array(CYGetCachedObject(context, CYJSString("Array_prototype"))); - JSObjectCallAsFunction(context, CYCastJSObject(context, CYGetProperty(context, Array, push_s)), array, 1, arguments, &exception); - CYThrow(context, exception); -} - extern "C" void CydgetMemoryParse(const uint16_t **data, size_t *size) { CYLocalPool local;