X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/20052ff75c224699725da0f8e096053009c62741..c9b965e40ad1ad73542865fb65990a8b59e3131b:/ObjectiveC/Internal.hpp?ds=inline diff --git a/ObjectiveC/Internal.hpp b/ObjectiveC/Internal.hpp index 9cffb48..8606d55 100644 --- a/ObjectiveC/Internal.hpp +++ b/ObjectiveC/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 {{{ */ @@ -27,22 +27,16 @@ #include "../Internal.hpp" struct Selector_privateData : - CYValue + CYValue { _finline Selector_privateData(SEL value) : CYValue(value) { } - - _finline SEL GetValue() const { - return reinterpret_cast(value_); - } - - virtual Type_privateData *GetType() const; }; struct Instance : - CYValue + CYValue { enum Flags { None = 0, @@ -52,69 +46,51 @@ struct Instance : Flags flags_; - _finline Instance(id value, Flags flags) : - CYValue(value), - flags_(flags) - { - } - + Instance(id value, Flags flags); virtual ~Instance(); - static JSObjectRef Make(JSContextRef context, id object, Flags flags = None); + JSValueRef GetPrototype(JSContextRef context) const; - _finline id GetValue() const { - return reinterpret_cast(value_); - } + static JSClassRef GetClass(id value, Flags flags); _finline bool IsUninitialized() const { return (flags_ & Uninitialized) != 0; } - - virtual Type_privateData *GetType() const; }; namespace cy { struct Super : - Instance + CYValue { Class class_; _finline Super(id value, Class _class) : - Instance(value, Instance::Permanent), + CYValue(value), class_(_class) { } - - static JSObjectRef Make(JSContextRef context, id object, Class _class); }; } struct Messages : - CYValue + CYValue { _finline Messages(Class value) : CYValue(value) { } - static JSObjectRef Make(JSContextRef context, Class _class); - - _finline Class GetValue() const { - return reinterpret_cast(value_); - } + JSValueRef GetPrototype(JSContextRef context) const; }; -struct Internal : - CYOwned +struct Interior : + CYValue { - _finline Internal(id value, JSContextRef context, JSObjectRef owner) : - CYOwned(value, context, owner) - { - } - - static JSObjectRef Make(JSContextRef context, id object, JSObjectRef owner); + CYProtect owner_; - _finline id GetValue() const { - return reinterpret_cast(value_); + _finline Interior(id value, JSContextRef context, JSObjectRef owner) : + CYValue(value), + owner_(context, owner) + { } };