Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
R
riscv-gcc-1
Overview
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
lvzhengyang
riscv-gcc-1
Commits
eca33b05
Commit
eca33b05
authored
Apr 12, 1993
by
Kresten Krab Thorup
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Stripped anything added by
kane@cc.purdue.edu which is not considered "minor changes" From-SVN: r4092
parent
ab65ae3c
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
0 additions
and
202 deletions
+0
-202
gcc/objc/objc-api.h
+0
-202
No files found.
gcc/objc/objc-api.h
View file @
eca33b05
...
...
@@ -31,13 +31,6 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
static
const
ARGSIZE
=
96
;
/* for `method_get_argsize()' */
/*
** Points to the function that the runtime system calls to handle
** an error. By default, it prints formatted error messages to the
** standard error stream and calls abort to produce a core file.
** The function is guaranteed to be passed a valid object and a
** non-NULL format string.
*/
extern
void
(
*
_objc_error
)(
id
object
,
const
char
*
format
,
va_list
args
);
/*
...
...
@@ -48,118 +41,30 @@ extern void (*_objc_error)(id object, const char *format, va_list args);
*/
extern
Class_t
(
*
_objc_lookup_class
)(
const
char
*
name
);
/*
** Points to the function that the runtime system calls to allocate
** memory for new instances. Called through class_create_instance(),
** this function should return a valid block of memory of at least
** class_get_instance_size() bytes, or nil upon failure. The
** function is guaranteed to be passed a valid class object.
*/
extern
id
(
*
_objc_object_alloc
)(
Class_t
class
);
/*
** Points to the function that the runtime system calls to create
** an exact copy of an object. Called through object_copy(), this
** function should return a new instance of object's class created
** by class_create_instance() which is bit-identical to object, or
** nil upon failure. The function is guaranteed to be passed a
** valid instance object.
*/
extern
id
(
*
_objc_object_copy
)(
id
object
);
/*
** Points to the function that the runtime system calls to free
** instances. Called through object_dispose(), this function
** should free the memory pointed to by object and return nil.
** This function is not responsible for freeing memory pointed
** to by any of the object's instance variables. The function
** is guaranteed to be passed a valid instance object.
*/
extern
id
(
*
_objc_object_dispose
)(
id
object
);
/*
** Searches for a class method specified by aSel, starting with the
** metaclass class and proceeding up the class hierarchy, until either
** the method is found or the root class has been examined. Returns
** a pointer to the method's Method structure if found. Returns the
** value METHOD_NULL if the method is not found, class is not a
** metaclass object, or aSel is not a valid selector.
*/
Method_t
class_get_class_method
(
MetaClass_t
class
,
SEL
aSel
);
/*
** Searches for an instance method specified by aSel, starting with
** the class class and proceeding up the class hierarchy, until either
** the method is found or the root class has been examined. Returns
** a pointer to the method's Method structure if found. Returns the
** value METHOD_NULL if the method is not found, class is not a class
** object, or aSel is not a valid selector.
*/
Method_t
class_get_instance_method
(
Class_t
class
,
SEL
aSel
);
/*
** Causes impostor to pose as its superclass. Messages sent to the
** superclass will actually be sent to the posing class. Instance
** variables may not be declared in the posing class. The posing
** class can add new methods to the class or override existing methods
** in the superclass. Returns non-nil on success. Returns nil if
** either of impostor or superclass are not class objects, impostor is
** not a subclass of superclass, or upon some other error.
*/
Class_t
class_pose_as
(
Class_t
impostor
,
Class_t
superclass
);
/*
** Returns the class object for the class named name. If name does not
** identify a known class, the hook _objc_lookup_class is called. If
** this fails, an error message is issued and the system aborts.
*/
Class_t
objc_get_class
(
const
char
*
name
);
/*
** Returns the class object for the class named name. If name does not
** identify a known class, the hook _objc_lookup_class is called. If
** this fails, nil is returned.
*/
Class_t
objc_lookup_class
(
const
char
*
name
);
/*
** Returns the method name associated with selector, or NULL
** if selector is not defined.
*/
const
char
*
sel_get_name
(
SEL
selector
);
/*
** Returns the selector associated with the method name name. If name
** has not been defined or name is NULL, 0 is returned.
*/
SEL
sel_get_uid
(
const
char
*
name
);
/*
** Registers a selector for name and returns the new selector. If
** name is NULL or the empty string (""), 0 is returned.
*/
SEL
sel_register_name
(
const
char
*
name
);
/*
** Indicate if aSel is a valid selector. This is not a safe
** operation, and it should really never be nessecary to use.
*/
BOOL
sel_is_mapped
(
SEL
aSel
);
/*******************************************************************/
/* */
/* Internal __inline functions */
/* */
/*******************************************************************/
/*
** Allocates memory for a new object of class class by calling the
** function specified by the variable _objc_object_alloc if non-zero,
** otherwise uses a default method. Then, initializes the object's
** isa instance variable to class, and returns the new object.
** Returns nil if the memory could not be allocated or class is not
** a class object.
*/
extern
inline
id
class_create_instance
(
Class_t
class
)
{
...
...
@@ -173,68 +78,42 @@ class_create_instance(Class_t class)
return
new
;
}
/*
** Returns name of the class class or empty string if class is not
** a class object. If class is Nil, the string "Nil" is returned.
*/
static
inline
const
char
*
class_get_class_name
(
Class_t
class
)
{
return
CLS_ISCLASS
(
class
)
?
class
->
name
:
((
class
==
Nil
)
?
"Nil"
:
0
);
}
/*
** Returns the size of an instance of class class in bytes, or 0 if
** class is not a class. The size of an instance is at least 4 bytes.
*/
static
inline
long
class_get_instance_size
(
Class_t
class
)
{
return
CLS_ISCLASS
(
class
)
?
class
->
instance_size
:
0
;
}
/*
** Returns a pointer to class's metaclass, or Nil if class is not a
** class.
*/
static
inline
MetaClass_t
class_get_meta_class
(
Class_t
class
)
{
return
CLS_ISCLASS
(
class
)
?
class
->
class_pointer
:
Nil
;
}
/*
** Returns a pointer to class's superclass, or Nil if class is not a
** class. Note that the superclass of Object is Nil.
*/
static
inline
Class_t
class_get_super_class
(
Class_t
class
)
{
return
CLS_ISCLASS
(
class
)
?
class
->
super_class
:
Nil
;
}
/*
** Returns the version number for the class, or -1 if class is not a
** class.
*/
static
inline
int
class_get_version
(
Class_t
class
)
{
return
CLS_ISCLASS
(
class
)
?
class
->
version
:-
1
;
}
/*
** Returns YES if class is a class, or NO if not.
*/
static
inline
BOOL
class_is_class
(
Class_t
class
)
{
return
CLS_ISCLASS
(
class
);
}
/*
** Returns YES if class is a metaclass, or NO if not.
*/
static
inline
BOOL
class_is_meta_class
(
Class_t
class
)
{
...
...
@@ -242,10 +121,6 @@ class_is_meta_class(Class_t class)
}
/*
** Sets the version number of class class. Does nothing if class is
** not a class.
*/
static
inline
void
class_set_version
(
Class_t
class
,
long
version
)
{
...
...
@@ -253,48 +128,20 @@ class_set_version(Class_t class, long version)
class
->
version
=
version
;
}
/*
** Returns the size in bytes of the argument frame to a method. Since
** at least two parameters (self and _cmd) are sent to each method, this
** value will be at least 8. If method is not a valid method, 0 is
** returned.
**
** Currently, the frame size info is only reliable on a NeXT, so until
** we get this fixed, we'll use a value which is most possibly large
** enough. You can possibly reduce this value (96) on anything but a
** Sparc if you don't return structs from the methods forwarded to.
*/
static
inline
unsigned
int
method_get_argsize
(
Method_t
method
)
{
return
ARGSIZE
;
/* This was a magic number (96)... */
}
/*
** Returns a pointer to the implementation of method method. If method
** is not a method, NULL is returned.
*/
static
inline
IMP
method_get_imp
(
Method_t
method
)
{
return
(
method
!=
METHOD_NULL
)
?
method
->
method_imp
:
(
IMP
)
0
;
}
/*
** Returns the implementation (pointer to function) of the method
** identified by a (class, selector) pair. Use this, and *not*
** objc_msg_lookup, since objc_msg_lookup may eventually return a
** pointer to an internal function which does lazy initialization...
*/
IMP
get_imp
(
Class_t
class
,
SEL
sel
);
/*
** Creates a new instance object that's an exact copy of object by
** calling the function pointed to by the variable _objc_object_copy if
** non-zero, otherwise uses a default method. Returns the new object.
** Returns nil if object is not an instance object, memory for the new
** object could not be allocated, or some other error occurred.
*/
extern
inline
id
object_copy
(
id
object
)
{
...
...
@@ -313,12 +160,6 @@ object_copy(id object)
}
}
/*
** Frees the memory occupied by object by calling the function pointed
** to by the variable _objc_object_dispose if non-zero, otherwise uses
** a default method. Always returns nil. If object is not an instance
** object, does nothing.
*/
extern
inline
id
object_dispose
(
id
object
)
{
...
...
@@ -332,13 +173,6 @@ object_dispose(id object)
return
nil
;
}
/*
** Returns the class of an object. If object is an instance, this is
** its class object. If object is a class object, returns object (this
** is arguably not correct, but is implemented this way for compatibility
** with NeXT (and Stepstone?)). If object is a metaclass object, or
** object is nil, returns Nil.
*/
static
inline
Class_t
object_get_class
(
id
object
)
{
...
...
@@ -351,11 +185,6 @@ object_get_class(id object)
:
Nil
);
}
/*
** Returns the name of the class of object. If object is an instace,
** this is the name of its class. If object is a class or a metaclass,
** returns its name. If object is nil, returns "Nil".
*/
static
inline
const
char
*
object_get_class_name
(
id
object
)
{
...
...
@@ -365,11 +194,6 @@ object_get_class_name(id object)
:
"Nil"
);
}
/*
** Returns the metaclass of an object. If object is an instance or a
** class, this is the metaclass object for it. If object is a metaclass
** object, or object is nil, returns Nil.
*/
static
inline
MetaClass_t
object_get_meta_class
(
id
object
)
{
...
...
@@ -381,11 +205,6 @@ object_get_meta_class(id object)
:
Nil
);
}
/*
** Returns the superclass of object. If object is an instance or
** a class, this is its superclass-object for it. If object is a
** metaclass-object or nil, this is Nil.
*/
static
inline
Class_t
object_get_super_class
(
id
object
)
{
...
...
@@ -397,44 +216,23 @@ object_get_super_class(id object)
:
Nil
);
}
/*
** YES if object is a class, NO if not.
*/
static
inline
BOOL
object_is_class
(
id
object
)
{
return
CLS_ISCLASS
((
Class_t
)
object
);
}
/*
** YES if object is an instance, NO if not.
*/
static
inline
BOOL
object_is_instance
(
id
object
)
{
return
(
object
!=
nil
)
&&
CLS_ISCLASS
(
object
->
class_pointer
);
}
/*
** YES if object is a metaclass, NO if not.
*/
static
inline
BOOL
object_is_meta_class
(
id
object
)
{
return
CLS_ISMETA
((
Class_t
)
object
);
}
/*
** Functions used for archiving. This is not documented yet!
*/
TypedStream
*
new_typed_stream
(
FILE
*
physical
);
void
free_typed_stream
(
TypedStream
*
stream
);
void
objc_write_object
(
TypedStream
*
stream
,
id
object
);
int
objc_read_object
(
TypedStream
*
stream
,
id
*
object
);
void
objc_write_type
(
TypedStream
*
stream
,
const
char
*
type
,
const
void
*
data
);
void
objc_read_type
(
TypedStream
*
stream
,
const
char
*
type
,
void
*
data
);
#endif
/* not __objc_api_INCLUDE_GNU */
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment