X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/f95d2598051e347460e028286ff2d33e5825e548..64a505ff07b28093bb91a680f8a2c2292327e896:/Internal.hpp diff --git a/Internal.hpp b/Internal.hpp index e594e55..87ff055 100644 --- a/Internal.hpp +++ b/Internal.hpp @@ -1,5 +1,5 @@ /* Cycript - Optimizing JavaScript Compiler/Runtime - * Copyright (C) 2009-2014 Jay Freeman (saurik) + * Copyright (C) 2009-2015 Jay Freeman (saurik) */ /* GNU Affero General Public License, Version 3 {{{ */ @@ -35,7 +35,6 @@ JSGlobalContextRef CYGetJSContext(JSContextRef context); void Structor_(CYPool &pool, sig::Type *&type); -JSObjectRef CYMakeType(JSContextRef context, const char *type); JSObjectRef CYMakeType(JSContextRef context, sig::Type *type); extern JSClassRef Functor_; @@ -53,8 +52,7 @@ struct Type_privateData : sig::Copy(*pool_, *type_, *type); } - Type_privateData(CYPool &pool, const char *type) : - CYData(pool), + Type_privateData(const char *type) : ffi_(NULL) { sig::Signature signature; @@ -62,12 +60,13 @@ struct Type_privateData : type_ = signature.elements[0].type; } - Type_privateData(const char *type) : + Type_privateData(sig::Primitive primitive) : ffi_(NULL) { - sig::Signature signature; - sig::Parse(*pool_, &signature, type, &Structor_); - type_ = signature.elements[0].type; + sig::Type type; + memset(&type, 0, sizeof(type)); + type.primitive = primitive; + Set(&type); } Type_privateData(sig::Type *type) : @@ -198,11 +197,13 @@ struct Closure_privateData : { JSGlobalContextRef context_; JSObjectRef function_; + JSValueRef (*adapter_)(JSContextRef, size_t, JSValueRef[], JSObjectRef); - Closure_privateData(JSContextRef context, JSObjectRef function, const sig::Signature &signature) : + Closure_privateData(JSContextRef context, JSObjectRef function, JSValueRef (*adapter)(JSContextRef, size_t, JSValueRef[], JSObjectRef), const sig::Signature &signature) : cy::Functor(signature, NULL), context_(CYGetJSContext(context)), - function_(function) + function_(function), + adapter_(adapter) { //XXX:JSGlobalContextRetain(context_); JSValueProtect(context_, function_); @@ -214,7 +215,7 @@ struct Closure_privateData : } }; -Closure_privateData *CYMakeFunctor_(JSContextRef context, JSObjectRef function, const sig::Signature &signature, void (*callback)(ffi_cif *, void *, void **, void *)); +Closure_privateData *CYMakeFunctor_(JSContextRef context, JSObjectRef function, const sig::Signature &signature, JSValueRef (*adapter)(JSContextRef, size_t, JSValueRef[], JSObjectRef)); void CYExecuteClosure(ffi_cif *cif, void *result, void **arguments, void *arg, JSValueRef (*adapter)(JSContextRef, size_t, JSValueRef[], JSObjectRef)); #endif/*CYCRIPT_INTERNAL_HPP*/