X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/0559abf83c4cc9bbd896b69dfaae1e8422521479..3e3acd8b6cb59a34b7819f6887e5386f6b8a30c6:/Internal.hpp diff --git a/Internal.hpp b/Internal.hpp index 0851dea..9228379 100644 --- a/Internal.hpp +++ b/Internal.hpp @@ -1,5 +1,5 @@ -/* Cycript - Optimizing JavaScript Compiler/Runtime - * Copyright (C) 2009-2015 Jay Freeman (saurik) +/* Cycript - The Truly Universal Scripting Language + * Copyright (C) 2009-2016 Jay Freeman (saurik) */ /* GNU Affero General Public License, Version 3 {{{ */ @@ -30,18 +30,43 @@ #include #include +#include "JavaScript.hpp" #include "Pooling.hpp" +#include "Utility.hpp" JSGlobalContextRef CYGetJSContext(JSContextRef context); sig::Type *Structor_(CYPool &pool, sig::Aggregate *aggregate); extern JSClassRef Functor_; -struct Type_privateData : +template +struct CYPrivate : CYData { static JSClassRef Class_; + _finline JSValueRef GetPrototype(JSContextRef context) const { + return NULL; + } + + template + _finline static JSClassRef GetClass(Args_ &&... args) { + return Class_; + } + + template + static JSObjectRef Make(JSContextRef context, Args_ &&... args) { + Internal_ *internal(new Internal_(cy::Forward(args)...)); + JSObjectRef object(JSObjectMake(context, Internal_::GetClass(cy::Forward(args)...), internal)); + if (JSValueRef prototype = internal->GetPrototype(context)) + CYSetPrototype(context, object, prototype); + return object; + } +}; + +struct Type_privateData : + CYPrivate +{ ffi_type *ffi_; sig::Type *type_; @@ -77,7 +102,7 @@ struct Type_privateData : signature.count = 1; ffi_cif cif; - sig::sig_ffi_cif(*pool_, &signature, &cif); + sig::sig_ffi_cif(*pool_, false, signature, &cif); ffi_ = new(*pool_) ffi_type; *ffi_ = *cif.rtype; @@ -87,16 +112,17 @@ struct Type_privateData : } }; +template struct CYValue : - CYData + CYPrivate { - void *value_; + Value_ value_; CYValue() { } - CYValue(const void *value) : - value_(const_cast(value)) + CYValue(const Value_ &value) : + value_(value) { } @@ -104,72 +130,75 @@ struct CYValue : value_(rhs.value_) { } - - virtual Type_privateData *GetType() const { - return NULL; - } }; -struct CYOwned : - CYValue -{ +template +JSClassRef CYPrivate::Class_; + +struct CYProtect { private: JSGlobalContextRef context_; - JSObjectRef owner_; + JSObjectRef object_; public: - CYOwned(void *value, JSContextRef context, JSObjectRef owner) : - CYValue(value), + CYProtect(JSContextRef context, JSObjectRef object) : context_(CYGetJSContext(context)), - owner_(owner) + object_(object) { //XXX:JSGlobalContextRetain(context_); - if (owner_ != NULL) - JSValueProtect(context_, owner_); + if (object_ != NULL) + JSValueProtect(context_, object_); } - virtual ~CYOwned() { - if (owner_ != NULL) - JSValueUnprotect(context_, owner_); + ~CYProtect() { + if (object_ != NULL) + JSValueUnprotect(context_, object_); //XXX:JSGlobalContextRelease(context_); } - JSObjectRef GetOwner() const { - return owner_; + operator bool() const { + return object_ != NULL; + } + + operator JSContextRef() const { + return context_; + } + + operator JSObjectRef() const { + return object_; } }; namespace cy { struct Functor : - CYValue + CYValue { private: void set() { - sig::sig_ffi_cif(*pool_, &signature_, &cif_); + sig::sig_ffi_cif(*pool_, variadic_ ? signature_.count : 0, signature_, &cif_); } public: + bool variadic_; sig::Signature signature_; ffi_cif cif_; - Functor(const sig::Signature &signature, void (*value)()) : - CYValue(reinterpret_cast(value)) + Functor(void (*value)(), bool variadic, const sig::Signature &signature) : + CYValue(value), + variadic_(variadic) { sig::Copy(*pool_, signature_, signature); set(); } - Functor(const char *encoding, void (*value)()) : - CYValue(reinterpret_cast(value)) + Functor(void (*value)(), const char *encoding) : + CYValue(value), + variadic_(false) { sig::Parse(*pool_, &signature_, encoding, &Structor_); set(); } - void (*GetValue() const)() { - return reinterpret_cast(value_); - } - static JSStaticFunction const * const StaticFunctions; static JSStaticValue const * const StaticValues; }; } @@ -177,23 +206,14 @@ struct Functor : struct Closure_privateData : cy::Functor { - JSGlobalContextRef context_; - JSObjectRef function_; + CYProtect function_; JSValueRef (*adapter_)(JSContextRef, size_t, JSValueRef[], JSObjectRef); 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), + cy::Functor(NULL, false, signature), + function_(context, function), adapter_(adapter) { - //XXX:JSGlobalContextRetain(context_); - JSValueProtect(context_, function_); - } - - virtual ~Closure_privateData() { - JSValueUnprotect(context_, function_); - //XXX:JSGlobalContextRelease(context_); } };