ObjFW
Loading...
Searching...
No Matches
ObjFWRT.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2008-2024 Jonathan Schleifer <js@nil.im>
3 *
4 * All rights reserved.
5 *
6 * This program is free software: you can redistribute it and/or modify it
7 * under the terms of the GNU Lesser General Public License version 3.0 only,
8 * as published by the Free Software Foundation.
9 *
10 * This program is distributed in the hope that it will be useful, but WITHOUT
11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License
13 * version 3.0 for more details.
14 *
15 * You should have received a copy of the GNU Lesser General Public License
16 * version 3.0 along with this program. If not, see
17 * <https://www.gnu.org/licenses/>.
18 */
19
20#ifndef OBJFWRT_OBJFWRT_H
21#define OBJFWRT_OBJFWRT_H
22
23#ifndef __STDC_LIMIT_MACROS
24# define __STDC_LIMIT_MACROS
25#endif
26#ifndef __STDC_CONSTANT_MACROS
27# define __STDC_CONSTANT_MACROS
28#endif
29
30#include <stdbool.h>
31#include <stddef.h>
32#include <stdint.h>
33
36#ifndef __has_feature
37# define __has_feature(x) 0
38#endif
39
40#ifndef __has_attribute
41# define __has_attribute(x) 0
42#endif
43
44#if !__has_feature(nullability)
45# ifndef _Nonnull
46# define _Nonnull
47# endif
48# ifndef _Nullable
49# define _Nullable
50# endif
51# ifndef _Null_unspecified
52# define _Null_unspecified
53# endif
54#endif
55
56#if !__has_feature(objc_arc) && !defined(__unsafe_unretained)
57# define __unsafe_unretained
58#endif
59
63#define Nil (Class _Null_unspecified)0
64
68#define nil (id _Null_unspecified)0
69
76#define YES true
77
84#define NO false
85
89typedef struct objc_class *Class;
90
94typedef struct objc_object *id;
95
102typedef const struct objc_selector *SEL;
103
109typedef const struct objc_method *Method;
110
114#if defined(__OBJC__) && !defined(DOXYGEN)
115@class Protocol;
116#else
117typedef const struct objc_protocol *Protocol;
118#endif
119
123typedef const struct objc_ivar *Ivar;
124
128typedef const struct objc_property *objc_property_t;
129
130#if !defined(__wii__) && !defined(__amigaos__)
137typedef bool BOOL;
138#endif
139
146typedef id _Nullable (*IMP)(id _Nonnull object, SEL _Nonnull selector, ...);
147
153typedef void (*objc_uncaught_exception_handler)(id _Nullable exception);
154
160typedef void (*objc_enumeration_mutation_handler)(id _Nonnull object);
161
169 id __unsafe_unretained _Nullable self;
173#ifdef __cplusplus
174 Class _Nonnull class_;
175#else
176 Class _Nonnull class;
177#endif
178};
179
195
196#ifdef __cplusplus
197extern "C" {
198#endif
205extern SEL _Nonnull sel_registerName(const char *_Nonnull name);
206
213extern const char *_Nonnull sel_getName(SEL _Nonnull selector);
214
225extern bool sel_isEqual(SEL _Nonnull selector1, SEL _Nonnull selector2);
226
235extern Class _Nonnull objc_allocateClassPair(Class _Nullable superclass,
236 const char *_Nonnull name, size_t extraBytes);
237
243extern void objc_registerClassPair(Class _Nonnull class_);
244
253extern unsigned int objc_getClassList(Class _Nonnull *_Nullable buffer,
254 unsigned int count);
255
267extern Class _Nonnull *_Nonnull objc_copyClassList(
268 unsigned int *_Nullable length);
269
276extern bool class_isMetaClass(Class _Nullable class_);
277
284extern const char *_Nullable class_getName(Class _Nullable class_);
285
292extern Class _Nullable class_getSuperclass(Class _Nullable class_);
293
300extern unsigned long class_getInstanceSize(Class _Nullable class_);
301
310extern bool class_respondsToSelector(Class _Nullable class_,
311 SEL _Nonnull selector);
312
321extern bool class_conformsToProtocol(Class _Nullable class_,
322 Protocol *_Nonnull protocol);
323
336extern IMP _Nullable class_getMethodImplementation(Class _Nullable class_,
337 SEL _Nonnull selector);
338
351extern IMP _Nullable class_getMethodImplementation_stret(Class _Nullable class_,
352 SEL _Nonnull selector);
353
361extern Method _Nullable class_getInstanceMethod(Class _Nullable class_,
362 SEL _Nonnull selector);
363
373extern bool class_addMethod(Class _Nonnull class_, SEL _Nonnull selector,
374 IMP _Nonnull implementation, const char *_Nullable typeEncoding);
375
386extern IMP _Nullable class_replaceMethod(Class _Nonnull class_,
387 SEL _Nonnull selector, IMP _Nonnull implementation,
388 const char *_Nullable typeEncoding);
389
396extern Class _Nullable object_getClass(id _Nullable object);
397
407extern Class _Nullable object_setClass(id _Nullable object,
408 Class _Nonnull class_);
409
416extern const char *_Nullable object_getClassName(id _Nullable object);
417
424extern const char *_Nonnull protocol_getName(Protocol *_Nonnull protocol);
425
433extern bool protocol_isEqual(Protocol *_Nonnull protocol1,
434 Protocol *_Nonnull protocol2);
435
443extern bool protocol_conformsToProtocol(Protocol *_Nonnull protocol1,
444 Protocol *_Nonnull protocol2);
445
455extern Method _Nullable *_Nullable class_copyMethodList(Class _Nullable class_,
456 unsigned int *_Nullable outCount);
457
464extern SEL _Nonnull method_getName(Method _Nonnull method);
465
472extern const char *_Nullable method_getTypeEncoding(Method _Nonnull method);
473
483extern Ivar _Nullable *_Nullable class_copyIvarList(Class _Nullable class_,
484 unsigned int *_Nullable outCount);
485
492extern const char *_Nonnull ivar_getName(Ivar _Nonnull ivar);
493
500extern const char *_Nonnull ivar_getTypeEncoding(Ivar _Nonnull ivar);
501
508extern ptrdiff_t ivar_getOffset(Ivar _Nonnull ivar);
509
519extern objc_property_t _Nullable *_Nullable class_copyPropertyList(
520 Class _Nullable class_, unsigned int *_Nullable outCount);
521
528extern const char *_Nonnull property_getName(objc_property_t _Nonnull property);
529
538extern char *_Nullable property_copyAttributeValue(
539 objc_property_t _Nonnull property, const char *_Nonnull name);
540
548extern void objc_deinit(void);
549
556extern _Nullable objc_uncaught_exception_handler
558 objc_uncaught_exception_handler _Nullable handler);
559
567extern void objc_setForwardHandler(IMP _Nullable forward,
568 IMP _Nullable stretForward);
569
576 objc_enumeration_mutation_handler _Nullable handler);
577
587extern id _Nullable objc_constructInstance(Class _Nullable class_,
588 void *_Nullable bytes);
589
596extern void *_Nullable objc_destructInstance(id _Nullable object);
597
605extern void *_Null_unspecified objc_autoreleasePoolPush(void);
606
614extern void objc_autoreleasePoolPop(void *_Null_unspecified pool);
615
625extern id _Nullable _objc_rootAutorelease(id _Nullable object);
626
633extern void objc_setTaggedPointerSecret(uintptr_t secret);
634
641extern int objc_registerTaggedPointerClass(Class _Nonnull class_);
642
649extern bool object_isTaggedPointer(id _Nullable object);
650
657extern uintptr_t object_getTaggedPointerValue(id _Nonnull object);
658
666extern id _Nullable objc_createTaggedPointer(int class_, uintptr_t value);
667
677extern void objc_setAssociatedObject(id _Nonnull object,
678 const void *_Nonnull key, id _Nullable value,
680
689extern id _Nullable objc_getAssociatedObject(id _Nonnull object,
690 const void *_Nonnull key);
691
697extern void objc_removeAssociatedObjects(id _Nonnull object);
698
699/*
700 * Used by the compiler, but can also be called manually.
701 *
702 * These declarations are also required to prevent Clang's implicit
703 * declarations which include __declspec(dllimport) on Windows.
704 */
705struct objc_module;
706extern void __objc_exec_class(struct objc_module *_Nonnull module);
707extern IMP _Nonnull objc_msg_lookup(id _Nullable object, SEL _Nonnull selector);
708extern IMP _Nonnull objc_msg_lookup_stret(id _Nullable object,
709 SEL _Nonnull selector);
710extern IMP _Nonnull objc_msg_lookup_super(struct objc_super *_Nonnull super,
711 SEL _Nonnull selector);
712extern IMP _Nonnull objc_msg_lookup_super_stret(
713 struct objc_super *_Nonnull super, SEL _Nonnull selector);
714extern Class _Nullable objc_lookUpClass(const char *_Nonnull name);
715extern Class _Nullable objc_getClass(const char *_Nonnull name);
716extern Class _Nonnull objc_getRequiredClass(const char *_Nonnull name);
717extern Class _Nullable objc_lookup_class(const char *_Nonnull name);
718extern Class _Nonnull objc_get_class(const char *_Nonnull name);
719extern void objc_exception_throw(id _Nullable object);
720extern int objc_sync_enter(id _Nullable object);
721extern int objc_sync_exit(id _Nullable object);
722extern id _Nullable objc_getProperty(id _Nonnull self, SEL _Nonnull _cmd,
723 ptrdiff_t offset, bool atomic);
724extern void objc_setProperty(id _Nonnull self, SEL _Nonnull _cmd,
725 ptrdiff_t offset, id _Nullable value, bool atomic, signed char copy);
726extern void objc_getPropertyStruct(void *_Nonnull dest,
727 const void *_Nonnull src, ptrdiff_t size, bool atomic, bool strong);
728extern void objc_setPropertyStruct(void *_Nonnull dest,
729 const void *_Nonnull src, ptrdiff_t size, bool atomic, bool strong);
730extern void objc_enumerationMutation(id _Nonnull object);
731#ifndef OBJC_NO_PERSONALITY_DECLARATION
732/*
733 * No objfw-defs.h or config.h is available for the installed runtime headers,
734 * so we don't know which exceptions we have.
735 */
736extern int __gnu_objc_personality_v0(int version, int actions,
737 uint64_t exClass, void *_Nonnull ex, void *_Nonnull ctx);
738extern int __gnu_objc_personality_sj0(int version, int actions,
739 uint64_t exClass, void *_Nonnull ex, void *_Nonnull ctx);
740#endif
741extern id _Nullable objc_retain(id _Nullable object);
742extern id _Nullable objc_retainBlock(id _Nullable block);
743extern id _Nullable objc_retainAutorelease(id _Nullable object);
744extern void objc_release(id _Nullable object);
745extern id _Nullable objc_autorelease(id _Nullable object);
746extern id _Nullable objc_autoreleaseReturnValue(id _Nullable object);
747extern id _Nullable objc_retainAutoreleaseReturnValue(id _Nullable object);
748extern id _Nullable objc_retainAutoreleasedReturnValue(id _Nullable object);
749extern id _Nullable objc_storeStrong(id _Nullable *_Nonnull object,
750 id _Nullable value);
751extern id _Nullable objc_storeWeak(id _Nullable *_Nonnull object,
752 id _Nullable value);
753extern id _Nullable objc_loadWeakRetained(id _Nullable *_Nonnull object);
754extern _Nullable id objc_initWeak(id _Nullable *_Nonnull object,
755 id _Nullable value);
756extern void objc_destroyWeak(id _Nullable *_Nonnull object);
757extern id _Nullable objc_loadWeak(id _Nullable *_Nonnull object);
758extern void objc_copyWeak(id _Nullable *_Nonnull dest,
759 id _Nullable *_Nonnull src);
760extern void objc_moveWeak(id _Nullable *_Nonnull dest,
761 id _Nullable *_Nonnull src);
762#ifdef __cplusplus
763}
764#endif
765
766#endif
Class class_getSuperclass(Class class_)
Returns the superclass of the specified class.
Definition class.m:679
void *_Null_unspecified objc_autoreleasePoolPush(void)
Creates a new autorelease pool and puts it on top of the stack of autorelease pools.
Definition autorelease.m:70
Class object_getClass(id object)
Returns the object's class.
Definition class.m:866
IMP class_getMethodImplementation_stret(Class class_, SEL selector)
Returns the class's method implementation for the specified selector.
Definition class.m:721
Ivar * class_copyIvarList(Class class_, unsigned int *outCount)
Copies the instance variable list of the specified class.
Definition ivar.m:26
SEL method_getName(Method method)
Returns the name of the specified method.
Definition method.m:75
const struct objc_property * objc_property_t
A property.
Definition ObjFWRT.h:128
Class * objc_copyClassList(unsigned int *length)
Copies the list of all classes known to the runtime.
Definition class.m:636
IMP class_replaceMethod(Class class_, SEL selector, IMP implementation, const char *typeEncoding)
Replaces or adds the specified method of the class.
Definition class.m:843
SEL sel_registerName(const char *name)
Registers a selector with the specified name with the runtime.
Definition selector.m:75
Method class_getInstanceMethod(Class class_, SEL selector)
Returns the class's instance method for the specified selector.
Definition class.m:798
id(* IMP)(id object, SEL selector,...)
A method implementation.
Definition ObjFWRT.h:146
const char * class_getName(Class class_)
Returns the name of the specified class.
Definition class.m:670
char * property_copyAttributeValue(objc_property_t property, const char *name)
Copies the specified attribute value.
Definition property.m:230
Class object_setClass(id object, Class class_)
Sets the object's class.
Definition class.m:882
void objc_deinit(void)
Deinitializes the Objective-C runtime.
Definition init.m:39
ptrdiff_t ivar_getOffset(Ivar ivar)
Returns the offset of the specified instance variable.
Definition ivar.m:78
uintptr_t object_getTaggedPointerValue(id object)
Returns the value of the specified tagged pointer.
Definition tagged-pointer.m:80
void objc_removeAssociatedObjects(id object)
Removes all associated objects for the specified object.
Definition association.m:228
unsigned int objc_getClassList(Class *buffer, unsigned int count)
Gets the list of all classes known to the runtime.
Definition class.m:590
void objc_setTaggedPointerSecret(uintptr_t secret)
Sets the tagged pointer secret.
Definition tagged-pointer.m:32
const struct objc_ivar * Ivar
An instance variable.
Definition ObjFWRT.h:123
bool class_conformsToProtocol(Class class_, Protocol *protocol)
Returns whether the specified class conforms to the specified protocol.
Definition protocol.m:60
const char * sel_getName(SEL selector)
Returns the name of the specified selector.
Definition selector.m:119
const char * protocol_getName(Protocol *protocol)
Returns the name of the specified protocol.
Definition protocol.m:31
const char * method_getTypeEncoding(Method method)
Returns the type encoding of the specified method.
Definition method.m:81
objc_uncaught_exception_handler objc_setUncaughtExceptionHandler(objc_uncaught_exception_handler handler)
Sets the handler for uncaught exceptions.
Definition exception.m:781
const char * ivar_getTypeEncoding(Ivar ivar)
Returns the type encoding of the specified instance variable.
Definition ivar.m:72
id _objc_rootAutorelease(id object)
Adds the specified object to the topmost autorelease pool.
Definition autorelease.m:123
void(* objc_uncaught_exception_handler)(id exception)
A handler for uncaught exceptions.
Definition ObjFWRT.h:153
id objc_constructInstance(Class class_, void *bytes)
Constructs an instance of the specified class in the specified array of bytes.
Definition instance.m:67
void objc_setAssociatedObject(id object, const void *key, id value, objc_associationPolicy policy)
Sets an associated object on the specified object for the specified key.
Definition association.m:116
void objc_setEnumerationMutationHandler(objc_enumeration_mutation_handler handler)
Sets the handler for mutations during enumeration.
Definition misc.m:56
bool protocol_isEqual(Protocol *protocol1, Protocol *protocol2)
Returns whether two protocols are equal.
Definition protocol.m:37
bool object_isTaggedPointer(id object)
Returns whether the specified object is a tagged pointer.
Definition tagged-pointer.m:58
objc_property_t * class_copyPropertyList(Class class_, unsigned int *outCount)
Copies the property list of the specified class.
Definition property.m:172
void(* objc_enumeration_mutation_handler)(id object)
A handler for mutation during enumeration.
Definition ObjFWRT.h:160
const char * ivar_getName(Ivar ivar)
Returns the name of the specified instance variable.
Definition ivar.m:66
bool protocol_conformsToProtocol(Protocol *protocol1, Protocol *protocol2)
Returns whether the first protocol conforms to the second protocol.
Definition protocol.m:44
bool BOOL
An Objective-C boolean. Either YES or NO.
Definition ObjFWRT.h:137
bool sel_isEqual(SEL selector1, SEL selector2)
Checks two selectors for equality.
Definition selector.m:131
id objc_getAssociatedObject(id object, const void *key)
Returns the associated object on the specified object for the specified key.
Definition association.m:186
unsigned long class_getInstanceSize(Class class_)
Returns the instance size of the specified class.
Definition class.m:688
const struct objc_method * Method
A method.
Definition ObjFWRT.h:109
const char * object_getClassName(id object)
Returns the object's class name.
Definition class.m:899
void objc_autoreleasePoolPop(void *_Null_unspecified pool)
Drains the specified autorelease pool and all pools on top of it and removes it from the stack of aut...
bool class_isMetaClass(Class class_)
Returns whether the specified class is a metaclass.
Definition class.m:661
const struct objc_selector * SEL
A selector.
Definition ObjFWRT.h:102
IMP class_getMethodImplementation(Class class_, SEL selector)
Returns the class's method implementation for the specified selector.
Definition class.m:697
void * objc_destructInstance(id object)
Destructs the specified object.
Definition instance.m:83
id objc_createTaggedPointer(int class_, uintptr_t value)
Creates a new tagged pointer.
Definition tagged-pointer.m:90
Method * class_copyMethodList(Class class_, unsigned int *outCount)
Copies the method list of the specified class.
Definition method.m:26
bool class_addMethod(Class class_, SEL selector, IMP implementation, const char *typeEncoding)
Adds the specified method to the class.
Definition class.m:824
bool class_respondsToSelector(Class class_, SEL selector)
Returns whether the specified class responds to the specified selector.
Definition lookup.m:126
const char * property_getName(objc_property_t property)
Returns the name of the specified property.
Definition property.m:224
Class objc_allocateClassPair(Class superclass, const char *name, size_t extraBytes)
Allocates a new class and its metaclass.
Definition class.m:476
int objc_registerTaggedPointerClass(Class class_)
Registers a class for tagged pointers.
Definition tagged-pointer.m:38
const struct objc_protocol * Protocol
A protocol.
Definition ObjFWRT.h:117
void objc_registerClassPair(Class class_)
Registers an already allocated class pair.
Definition class.m:513
objc_associationPolicy
A policy for object association, see objc_setAssociatedObject.
Definition ObjFWRT.h:183
@ OBJC_ASSOCIATION_RETAIN_NONATOMIC
Associate the object like a retained, nonatomic property.
Definition ObjFWRT.h:187
@ OBJC_ASSOCIATION_COPY
Associate the object like a copied property.
Definition ObjFWRT.h:193
@ OBJC_ASSOCIATION_RETAIN
Associate the object like a retained property.
Definition ObjFWRT.h:189
@ OBJC_ASSOCIATION_ASSIGN
Associate the object like an assigned property.
Definition ObjFWRT.h:185
@ OBJC_ASSOCIATION_COPY_NONATOMIC
Associate the object like a copied, nonatomic property.
Definition ObjFWRT.h:191
void objc_setForwardHandler(IMP forward, IMP stretForward)
Sets the forwarding handler for unimplemented methods.
Definition lookup.m:119
A pointer to a class.
Definition private.h:37
A pointer to any object.
Definition private.h:66
A struct representing a call to super.
Definition ObjFWRT.h:165
id __unsafe_unretained self
The object on which to perform the super call.
Definition ObjFWRT.h:169