]> git.saurik.com Git - cycript.git/blobdiff - ObjectiveC/Internal.hpp
Unix domain sockets are often walled by sandboxes.
[cycript.git] / ObjectiveC / Internal.hpp
index b731dbb5c144b80f3ca77f36447cb5a4a6ed5875..79f455b240613e622786bd75656803b820da6763 100644 (file)
@@ -1,5 +1,5 @@
-/* Cycript - Optimizing JavaScript Compiler/Runtime
- * Copyright (C) 2009-2014  Jay Freeman (saurik)
+/* Cycript - The Truly Universal Scripting Language
+ * Copyright (C) 2009-2016  Jay Freeman (saurik)
 */
 
 /* GNU Affero General Public License, Version 3 {{{ */
 #ifndef CYCRIPT_OBJECTIVEC_INTERNAL_HPP
 #define CYCRIPT_OBJECTIVEC_INTERNAL_HPP
 
-#include <Internal.hpp>
 #include <objc/objc.h>
 
+#include "../Internal.hpp"
+
 struct Selector_privateData :
-    CYValue
+    CYRoot
 {
+    SEL value_;
+
     _finline Selector_privateData(SEL value) :
-        CYValue(value)
+        value_(value)
     {
     }
-
-    _finline SEL GetValue() const {
-        return reinterpret_cast<SEL>(value_);
-    }
-
-    virtual Type_privateData *GetType() const;
 };
 
 struct Instance :
-    CYValue
+    CYRoot
 {
-    enum Flags {
-        None          = 0,
-        Permanent     = (1 << 0),
-        Uninitialized = (1 << 1),
-    };
+    typedef unsigned Flags;
+    static const Flags None = 0;
+    static const Flags Permanent = 1 << 0;
+    static const Flags Uninitialized = 1 << 1;
 
+    id value_;
     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<id>(value_);
+    static JSClassRef GetClass(id value, Flags flags);
+
+    _finline bool IsPermanent() const {
+        return (flags_ & Permanent) != 0;
     }
 
     _finline bool IsUninitialized() const {
         return (flags_ & Uninitialized) != 0;
     }
+};
 
-    virtual Type_privateData *GetType() const;
+struct Block :
+    Instance
+{
+    using Instance::Instance;
+};
+
+struct Constructor :
+    Instance
+{
+    using Instance::Instance;
 };
 
 namespace cy {
 struct Super :
-    Instance
+    CYRoot
 {
+    id value_;
     Class class_;
 
     _finline Super(id value, Class _class) :
-        Instance(value, Instance::Permanent),
+        value_(value),
         class_(_class)
     {
     }
-
-    static JSObjectRef Make(JSContextRef context, id object, Class _class);
 }; }
 
+struct Prototype :
+    CYRoot
+{
+};
+
 struct Messages :
-    CYValue
+    CYRoot
 {
+    static constexpr const char *const Cache_ = "p";
+
+    Class value_;
+
     _finline Messages(Class value) :
-        CYValue(value)
+        value_(value)
     {
     }
 
-    static JSObjectRef Make(JSContextRef context, Class _class);
-
-    _finline Class GetValue() const {
-        return reinterpret_cast<Class>(value_);
-    }
+    JSValueRef GetPrototype(JSContextRef context) const;
 };
 
-struct Internal :
-    CYOwned
+struct Interior :
+    CYRoot
 {
-    _finline Internal(id value, JSContextRef context, JSObjectRef owner) :
-        CYOwned(value, context, owner)
-    {
-    }
-
-    static JSObjectRef Make(JSContextRef context, id object, JSObjectRef owner);
+    id value_;
+    CYProtect owner_;
 
-    _finline id GetValue() const {
-        return reinterpret_cast<id>(value_);
+    _finline Interior(id value, JSContextRef context, JSObjectRef owner) :
+        value_(value),
+        owner_(context, owner)
+    {
     }
 };