You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
210 lines
7.1 KiB
Objective-C
210 lines
7.1 KiB
Objective-C
/* Basic data types for Objective C.
|
|
Copyright (C) 1993, 1995, 1996, 2004, 2009 Free Software Foundation, Inc.
|
|
|
|
This file is part of GCC.
|
|
|
|
GCC is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License as published by
|
|
the Free Software Foundation; either version 3, or (at your option)
|
|
any later version.
|
|
|
|
GCC 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 General Public License for more details.
|
|
|
|
Under Section 7 of GPL version 3, you are granted additional
|
|
permissions described in the GCC Runtime Library Exception, version
|
|
3.1, as published by the Free Software Foundation.
|
|
|
|
You should have received a copy of the GNU General Public License and
|
|
a copy of the GCC Runtime Library Exception along with this program;
|
|
see the files COPYING3 and COPYING.RUNTIME respectively. If not, see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
|
|
#ifndef __objc_INCLUDE_GNU
|
|
#define __objc_INCLUDE_GNU
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
#include <stddef.h>
|
|
|
|
/*
|
|
** Definition of the boolean type.
|
|
*/
|
|
#ifdef __vxworks
|
|
typedef int BOOL;
|
|
#else
|
|
typedef unsigned char BOOL;
|
|
#endif
|
|
#define YES (BOOL)1
|
|
#define NO (BOOL)0
|
|
|
|
/*
|
|
** Definition of a selector. Selectors themselves are not unique, but
|
|
** the sel_id is a unique identifier.
|
|
*/
|
|
typedef const struct objc_selector
|
|
{
|
|
void *sel_id;
|
|
const char *sel_types;
|
|
} *SEL;
|
|
|
|
inline static BOOL
|
|
sel_eq (SEL s1, SEL s2)
|
|
{
|
|
if (s1 == 0 || s2 == 0)
|
|
return s1 == s2;
|
|
else
|
|
return s1->sel_id == s2->sel_id;
|
|
}
|
|
|
|
|
|
/*
|
|
** ObjC uses this typedef for untyped instances.
|
|
*/
|
|
typedef struct objc_object {
|
|
struct objc_class* class_pointer;
|
|
} *id;
|
|
|
|
/*
|
|
** Definition of method type. When retrieving the implementation of a
|
|
** method, this is type of the pointer returned. The idea of the
|
|
** definition of IMP is to represent a 'pointer to a general function
|
|
** taking an id, a SEL, followed by other unspecified arguments'. You
|
|
** must always cast an IMP to a pointer to a function taking the
|
|
** appropriate, specific types for that function, before calling it -
|
|
** to make sure the appropriate arguments are passed to it. The code
|
|
** generated by the compiler to perform method calls automatically
|
|
** does this cast inside method calls.
|
|
*/
|
|
typedef id (*IMP)(id, SEL, ...);
|
|
|
|
/*
|
|
** More simple types...
|
|
*/
|
|
#define nil (id)0 /* id of Nil instance */
|
|
#define Nil (Class)0 /* id of Nil class */
|
|
typedef char *STR; /* String alias */
|
|
|
|
/*
|
|
** The compiler generates one of these structures for each class.
|
|
**
|
|
** This structure is the definition for classes.
|
|
**
|
|
** This structure is generated by the compiler in the executable and used by
|
|
** the run-time during normal messaging operations. Therefore some members
|
|
** change type. The compiler generates "char* const" and places a string in
|
|
** the following member variables: super_class.
|
|
*/
|
|
typedef struct objc_class *MetaClass;
|
|
typedef struct objc_class *Class;
|
|
struct objc_class {
|
|
MetaClass class_pointer; /* Pointer to the class's
|
|
meta class. */
|
|
struct objc_class* super_class; /* Pointer to the super
|
|
class. NULL for class
|
|
Object. */
|
|
const char* name; /* Name of the class. */
|
|
long version; /* Unknown. */
|
|
unsigned long info; /* Bit mask. See class masks
|
|
defined above. */
|
|
long instance_size; /* Size in bytes of the class.
|
|
The sum of the class
|
|
definition and all super
|
|
class definitions. */
|
|
struct objc_ivar_list* ivars; /* Pointer to a structure that
|
|
describes the instance
|
|
variables in the class
|
|
definition. NULL indicates
|
|
no instance variables. Does
|
|
not include super class
|
|
variables. */
|
|
struct objc_method_list* methods; /* Linked list of instance
|
|
methods defined for the
|
|
class. */
|
|
struct sarray * dtable; /* Pointer to instance
|
|
method dispatch table. */
|
|
struct objc_class* subclass_list; /* Subclasses */
|
|
struct objc_class* sibling_class;
|
|
|
|
struct objc_protocol_list *protocols; /* Protocols conformed to */
|
|
void* gc_object_type;
|
|
/**
|
|
* New ABI. The following fields are only available with classes compiled to
|
|
* support the new ABI. You may test whether any given class supports this
|
|
* ABI by using the CLS_ISNEW_ABI() macro.
|
|
*/
|
|
|
|
/**
|
|
* The version of the ABI used for this class. This is currently always zero.
|
|
*/
|
|
long abi_version;
|
|
|
|
/**
|
|
* Array of pointers to variables where the runtime will store the ivar
|
|
* offset. These may be used for faster access to non-fragile ivars if all
|
|
* of the code is compiled for the new ABI. Each of these pointers should
|
|
* have the mangled name __objc_ivar_offset_value_{class name}.{ivar name}
|
|
*
|
|
* When using the compatible non-fragile ABI, this faster form should only be
|
|
* used for classes declared in the same compilation unit.
|
|
*
|
|
* The compiler should also emit symbols of the form
|
|
* __objc_ivar_offset_{class name}.{ivar name} which are pointers to the
|
|
* offset values. These should be emitted as weak symbols in every module
|
|
* where they are used. The legacy-compatible ABI uses these with a double
|
|
* layer of indirection.
|
|
*/
|
|
int **ivar_offsets;
|
|
/**
|
|
* List of declared properties on this class (NULL if none). This contains
|
|
* the accessor methods for each property.
|
|
*/
|
|
struct objc_property_list *properties;
|
|
};
|
|
|
|
#ifndef __OBJC__
|
|
typedef struct objc_protocol {
|
|
struct objc_class* class_pointer;
|
|
char *protocol_name;
|
|
struct objc_protocol_list *protocol_list;
|
|
struct objc_method_description_list *instance_methods, *class_methods;
|
|
} Protocol;
|
|
|
|
struct objc_protocol2
|
|
{
|
|
struct objc_class* class_pointer;
|
|
char *protocol_name;
|
|
struct objc_protocol_list *protocol_list;
|
|
struct objc_method_description_list *instance_methods, *class_methods;
|
|
// New ABI
|
|
struct objc_method_description_list *optional_instance_methods, *optional_class_methods;
|
|
struct objc_property_list *properties, *optional_properties;
|
|
};
|
|
|
|
|
|
|
|
#else /* __OBJC__ */
|
|
@class Protocol;
|
|
#endif
|
|
|
|
typedef void* retval_t; /* return value */
|
|
typedef void(*apply_t)(void); /* function pointer */
|
|
typedef union arglist {
|
|
char *arg_ptr;
|
|
char arg_regs[sizeof (char*)];
|
|
} *arglist_t; /* argument frame */
|
|
|
|
|
|
IMP objc_msg_lookup(id receiver, SEL op);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* not __objc_INCLUDE_GNU */
|