X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/3c1c3635db4635a7aef0a5f625678378f48b6696..309b053540b80defe4313836161c68ea9112d56d:/Internal.hpp diff --git a/Internal.hpp b/Internal.hpp index eaf7150..e05fa0d 100644 --- a/Internal.hpp +++ b/Internal.hpp @@ -1,15 +1,57 @@ +/* Cycript - Inlining/Optimizing JavaScript Compiler + * Copyright (C) 2009 Jay Freeman (saurik) +*/ + +/* Modified BSD License {{{ */ +/* + * Redistribution and use in source and binary + * forms, with or without modification, are permitted + * provided that the following conditions are met: + * + * 1. Redistributions of source code must retain the + * above copyright notice, this list of conditions + * and the following disclaimer. + * 2. Redistributions in binary form must reproduce the + * above copyright notice, this list of conditions + * and the following disclaimer in the documentation + * and/or other materials provided with the + * distribution. + * 3. The name of the author may not be used to endorse + * or promote products derived from this software + * without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' + * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, + * BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF + * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE + * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE + * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR + * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF + * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR + * TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN + * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF + * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. +*/ +/* }}} */ + #ifndef CYCRIPT_INTERNAL_HPP #define CYCRIPT_INTERNAL_HPP #include "Pooling.hpp" #include +#include +#include #include #include #include -void Structor_(apr_pool_t *pool, const char *name, const char *types, sig::Type *&type); +JSGlobalContextRef CYGetJSContext(JSContextRef context); +void Structor_(apr_pool_t *pool, sig::Type *&type); struct Type_privateData : CYData @@ -27,9 +69,16 @@ struct Type_privateData : Type_privateData(apr_pool_t *pool, const char *type) : ffi_(NULL) { - if (pool != NULL) - pool_ = pool; + _assert(pool != NULL); + pool_ = pool; + sig::Signature signature; + sig::Parse(pool_, &signature, type, &Structor_); + type_ = signature.elements[0].type; + } + Type_privateData(const char *type) : + ffi_(NULL) + { sig::Signature signature; sig::Parse(pool_, &signature, type, &Structor_); type_ = signature.elements[0].type; @@ -97,15 +146,16 @@ struct CYOwned : CYValue { private: - JSContextRef context_; + JSGlobalContextRef context_; JSObjectRef owner_; public: CYOwned(void *value, JSContextRef context, JSObjectRef owner) : CYValue(value), - context_(context), + context_(CYGetJSContext(context)), owner_(owner) { + //XXX:JSGlobalContextRetain(context_); if (owner_ != NULL) JSValueProtect(context_, owner_); } @@ -113,6 +163,7 @@ struct CYOwned : virtual ~CYOwned() { if (owner_ != NULL) JSValueUnprotect(context_, owner_); + //XXX:JSGlobalContextRelease(context_); } JSObjectRef GetOwner() const { @@ -120,4 +171,48 @@ struct CYOwned : } }; +namespace cy { +struct Functor : + CYValue +{ + sig::Signature signature_; + ffi_cif cif_; + + Functor(const char *type, void (*value)()) : + CYValue(reinterpret_cast(value)) + { + sig::Parse(pool_, &signature_, type, &Structor_); + sig::sig_ffi_cif(pool_, &sig::ObjectiveC, &signature_, &cif_); + } + + void (*GetValue())() const { + return reinterpret_cast(value_); + } + + static JSStaticFunction const * const StaticFunctions; +}; } + +struct Closure_privateData : + cy::Functor +{ + JSGlobalContextRef context_; + JSObjectRef function_; + + Closure_privateData(JSContextRef context, JSObjectRef function, const char *type) : + cy::Functor(type, NULL), + context_(CYGetJSContext(context)), + function_(function) + { + //XXX:JSGlobalContextRetain(context_); + JSValueProtect(context_, function_); + } + + virtual ~Closure_privateData() { + JSValueUnprotect(context_, function_); + //XXX:JSGlobalContextRelease(context_); + } +}; + +Closure_privateData *CYMakeFunctor_(JSContextRef context, JSObjectRef function, const char *type, void (*callback)(ffi_cif *, void *, void **, void *)); + #endif/*CYCRIPT_INTERNAL_HPP*/