X-Git-Url: https://git.saurik.com/cycript.git/blobdiff_plain/8d7447c170dd11c91d0a07768f32a2699177fa54..5b4dabb2071e2e09cd70a156beed03b12bec477a:/sig/types.hpp diff --git a/sig/types.hpp b/sig/types.hpp index e6240a1..d32d1da 100644 --- a/sig/types.hpp +++ b/sig/types.hpp @@ -1,68 +1,45 @@ -/* Cycript - Optimizing JavaScript Compiler/Runtime - * Copyright (C) 2009-2012 Jay Freeman (saurik) +/* Cycript - The Truly Universal Scripting Language + * Copyright (C) 2009-2016 Jay Freeman (saurik) */ -/* GNU Lesser General Public License, Version 3 {{{ */ +/* GNU Affero General Public License, Version 3 {{{ */ /* - * Cycript is free software: you can redistribute it and/or modify it under - * the terms of the GNU Lesser General Public License as published by the - * Free Software Foundation, either version 3 of the License, or (at your - * option) any later version. - * - * Cycript is distributed in the hope that it will be useful, but WITHOUT - * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or - * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public - * License for more details. - * - * You should have received a copy of the GNU Lesser General Public License - * along with Cycript. If not, see . + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU Affero General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU Affero General Public License for more details. + + * You should have received a copy of the GNU Affero General Public License + * along with this program. If not, see . **/ /* }}} */ #ifndef SIG_TYPES_H #define SIG_TYPES_H -#include "Standard.hpp" +#include +#include -namespace sig { +#include -enum Primitive { - typename_P = '#', - union_P = '(', - string_P = '*', - selector_P = ':', - block_P = '?', - object_P = 'W', - boolean_P = 'B', - uchar_P = 'C', - uint_P = 'I', - ulong_P = 'L', - ulonglong_P = 'Q', - ushort_P = 'S', - array_P = '[', - pointer_P = '^', - bit_P = 'b', - char_P = 'c', - double_P = 'd', - float_P = 'f', - int_P = 'i', - long_P = 'l', - longlong_P = 'q', - short_P = 's', - void_P = 'v', - struct_P = '{' -}; +#ifdef HAVE_FFI_FFI_H +#include +#else +#include +#endif -struct Element { - char *name; - struct Type *type; - size_t offset; -}; +#include "Standard.hpp" -struct Signature { - struct Element *elements; - size_t count; -}; +class CYPool; +struct CYType; +struct CYTypedParameter; + +namespace sig { #define JOC_TYPE_INOUT (1 << 0) #define JOC_TYPE_IN (1 << 1) @@ -73,26 +50,306 @@ struct Signature { #define JOC_TYPE_ONEWAY (1 << 6) struct Type { - enum Primitive primitive; - char *name; uint8_t flags; - union { - struct { - struct Type *type; - size_t size; - } data; + Type() : + flags(0) + { + } + + virtual Type *Copy(CYPool &pool, const char *rename = NULL) const = 0; + virtual const char *GetName() const; + + virtual const char *Encode(CYPool &pool) const = 0; + virtual CYType *Decode(CYPool &pool) const = 0; - struct Signature signature; - } data; + virtual ffi_type *GetFFI(CYPool &pool) const = 0; + virtual void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const = 0; + virtual JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize = false, JSObjectRef owner = NULL) const = 0; }; -struct Type *joc_parse_type(char **name, char eos, bool variable, bool signature); -void joc_parse_signature(struct Signature *signature, char **name, char eos, bool variable); +template +struct Primitive : + Type +{ + Primitive *Copy(CYPool &pool, const char *name) const { + return new(pool) Primitive(); + } -_finline bool IsAggregate(Primitive primitive) { - return primitive == struct_P || primitive == union_P; -} + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +struct Element { + const char *name; + Type *type; + size_t offset; +}; + +struct Signature { + Element *elements; + size_t count; +}; + +struct Void : + Type +{ + Void *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +struct Unknown : + Type +{ + Unknown *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +struct String : + Type +{ + String *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +#ifdef CY_OBJECTIVEC +struct Meta : + Type +{ + Meta *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +struct Selector : + Type +{ + Selector *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; +#endif + +struct Bits : + Type +{ + size_t size; + + Bits(size_t size) : + size(size) + { + } + + Bits *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +struct Pointer : + Type +{ + Type &type; + + Pointer(Type &type) : + type(type) + { + } + + Pointer *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +struct Array : + Type +{ + Type &type; + size_t size; + + Array(Type &type, size_t size = _not(size_t)) : + type(type), + size(size) + { + } + + Array *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +#ifdef CY_OBJECTIVEC +struct Object : + Type +{ + const char *name; + + Object(const char *name = NULL) : + name(name) + { + } + + Object *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; +#endif + +struct Constant { + const char *name; + double value; +}; + +struct Enum : + Type +{ + Type &type; + unsigned count; + const char *name; + + Constant *constants; + + Enum(Type &type, unsigned count, const char *name = NULL) : + type(type), + count(count), + name(name), + constants(NULL) + { + } + + Enum *Copy(CYPool &pool, const char *rename = NULL) const override; + const char *GetName() const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +struct Aggregate : + Type +{ + bool overlap; + const char *name; + Signature signature; + + Aggregate(bool overlap, const char *name = NULL) : + overlap(overlap), + name(name) + { + } + + Aggregate *Copy(CYPool &pool, const char *rename = NULL) const override; + const char *GetName() const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +struct Callable : + Type +{ + Signature signature; + + CYType *Decode(CYPool &pool) const override; + virtual CYType *Modify(CYPool &pool, CYType *result, CYTypedParameter *parameters) const = 0; +}; + +struct Function : + Callable +{ + bool variadic; + + Function(bool variadic) : + variadic(variadic) + { + } + + Function *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Modify(CYPool &pool, CYType *result, CYTypedParameter *parameters) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; + +#ifdef CY_OBJECTIVEC +struct Block : + Callable +{ + Block *Copy(CYPool &pool, const char *rename = NULL) const override; + + const char *Encode(CYPool &pool) const override; + CYType *Decode(CYPool &pool) const override; + CYType *Modify(CYPool &pool, CYType *result, CYTypedParameter *parameters) const override; + + ffi_type *GetFFI(CYPool &pool) const override; + void PoolFFI(CYPool *pool, JSContextRef context, ffi_type *ffi, void *data, JSValueRef value) const override; + JSValueRef FromFFI(JSContextRef context, ffi_type *ffi, void *data, bool initialize, JSObjectRef owner) const override; +}; +#endif + +Type *joc_parse_type(char **name, char eos, bool variable, bool signature); +void joc_parse_signature(Signature *signature, char **name, char eos, bool variable); }