master
  1/*
  2 * Copyright (c) 1999-2006 Apple Inc.  All Rights Reserved.
  3 * 
  4 * @APPLE_LICENSE_HEADER_START@
  5 * 
  6 * This file contains Original Code and/or Modifications of Original Code
  7 * as defined in and that are subject to the Apple Public Source License
  8 * Version 2.0 (the 'License'). You may not use this file except in
  9 * compliance with the License. Please obtain a copy of the License at
 10 * http://www.opensource.apple.com/apsl/ and read it before using this
 11 * file.
 12 * 
 13 * The Original Code and all software distributed under the License are
 14 * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
 15 * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
 16 * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
 17 * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
 18 * Please see the License for the specific language governing rights and
 19 * limitations under the License.
 20 * 
 21 * @APPLE_LICENSE_HEADER_END@
 22 */
 23// Copyright 1988-1996 NeXT Software, Inc.
 24
 25#ifndef _OBJC_OBJC_API_H_
 26#define _OBJC_OBJC_API_H_
 27
 28#include <Availability.h>
 29#include <AvailabilityMacros.h>
 30#include <TargetConditionals.h>
 31#include <stddef.h>
 32#include <sys/types.h>
 33
 34#ifndef __has_feature
 35#   define __has_feature(x) 0
 36#endif
 37
 38#ifndef __has_extension
 39#   define __has_extension __has_feature
 40#endif
 41
 42#ifndef __has_attribute
 43#   define __has_attribute(x) 0
 44#endif
 45
 46#if !__has_feature(nullability)
 47#   ifndef _Nullable
 48#       define _Nullable
 49#   endif
 50#   ifndef _Nonnull
 51#       define _Nonnull
 52#   endif
 53#   ifndef _Null_unspecified
 54#       define _Null_unspecified
 55#   endif
 56#endif
 57
 58
 59
 60/*
 61 * OBJC_API_VERSION 0 or undef: Tiger and earlier API only
 62 * OBJC_API_VERSION 2: Leopard and later API available
 63 */
 64#if !defined(OBJC_API_VERSION)
 65#   if defined(__MAC_OS_X_VERSION_MIN_REQUIRED)  &&  __MAC_OS_X_VERSION_MIN_REQUIRED < __MAC_10_5
 66#       define OBJC_API_VERSION 0
 67#   else
 68#       define OBJC_API_VERSION 2
 69#   endif
 70#endif
 71
 72
 73/*
 74 * OBJC_NO_GC 1: GC is not supported
 75 * OBJC_NO_GC undef: GC is supported. This SDK no longer supports this mode.
 76 *
 77 * OBJC_NO_GC_API undef: Libraries must export any symbols that 
 78 *                       dual-mode code may links to.
 79 * OBJC_NO_GC_API 1: Libraries need not export GC-related symbols.
 80 */
 81#if defined(__OBJC_GC__)
 82#   error Objective-C garbage collection is not supported.
 83#elif TARGET_OS_OSX
 84    /* GC is unsupported. GC API symbols are exported. */
 85#   define OBJC_NO_GC 1
 86#   undef  OBJC_NO_GC_API
 87#else
 88    /* GC is unsupported. GC API symbols are not exported. */
 89#   define OBJC_NO_GC 1
 90#   define OBJC_NO_GC_API 1
 91#endif
 92
 93
 94/* NS_ENFORCE_NSOBJECT_DESIGNATED_INITIALIZER == 1 
 95 * marks -[NSObject init] as a designated initializer. */
 96#if !defined(NS_ENFORCE_NSOBJECT_DESIGNATED_INITIALIZER)
 97#   define NS_ENFORCE_NSOBJECT_DESIGNATED_INITIALIZER 1
 98#endif
 99
100/* The arm64 ABI requires proper casting to ensure arguments are passed
101 *  * correctly.  */
102#if defined(__arm64__) && !__swift__
103#   undef OBJC_OLD_DISPATCH_PROTOTYPES
104#   define OBJC_OLD_DISPATCH_PROTOTYPES 0
105#endif
106
107/* OBJC_OLD_DISPATCH_PROTOTYPES == 0 enforces the rule that the dispatch 
108 * functions must be cast to an appropriate function pointer type. */
109#if !defined(OBJC_OLD_DISPATCH_PROTOTYPES)
110#   if __swift__
111        // Existing Swift code expects IMP to be Comparable.
112        // Variadic IMP is comparable via OpaquePointer; non-variadic IMP isn't.
113#       define OBJC_OLD_DISPATCH_PROTOTYPES 1
114#   else
115#       define OBJC_OLD_DISPATCH_PROTOTYPES 0
116#   endif
117#endif
118
119
120/* OBJC_AVAILABLE: shorthand for all-OS availability */
121
122#   if !defined(OBJC_AVAILABLE)
123#       define OBJC_AVAILABLE(x, i, t, w, b)                            \
124            __OSX_AVAILABLE(x)  __IOS_AVAILABLE(i)  __TVOS_AVAILABLE(t) \
125            __WATCHOS_AVAILABLE(w)
126#   endif
127
128
129
130/* OBJC_OSX_DEPRECATED_OTHERS_UNAVAILABLE: Deprecated on OS X,
131 * unavailable everywhere else. */
132
133#   if !defined(OBJC_OSX_DEPRECATED_OTHERS_UNAVAILABLE)
134#       define OBJC_OSX_DEPRECATED_OTHERS_UNAVAILABLE(_start, _dep, _msg) \
135            __OSX_DEPRECATED(_start, _dep, _msg)                          \
136            __IOS_UNAVAILABLE __TVOS_UNAVAILABLE                          \
137            __WATCHOS_UNAVAILABLE
138#   endif
139
140
141
142/* OBJC_OSX_AVAILABLE_OTHERS_UNAVAILABLE: Available on OS X,
143 * unavailable everywhere else. */
144
145#   if !defined(OBJC_OSX_AVAILABLE_OTHERS_UNAVAILABLE)
146#       define OBJC_OSX_AVAILABLE_OTHERS_UNAVAILABLE(vers) \
147            __OSX_AVAILABLE(vers)                          \
148            __IOS_UNAVAILABLE __TVOS_UNAVAILABLE           \
149            __WATCHOS_UNAVAILABLE
150#    endif
151
152
153
154/* OBJC_ISA_AVAILABILITY: `isa` will be deprecated or unavailable 
155 * in the future */
156#if !defined(OBJC_ISA_AVAILABILITY)
157#   define OBJC_ISA_AVAILABILITY  __attribute__((deprecated))
158#endif
159
160/* OBJC_UNAVAILABLE: unavailable, with a message where supported */
161#if !defined(OBJC_UNAVAILABLE)
162#   if __has_extension(attribute_unavailable_with_message)
163#       define OBJC_UNAVAILABLE(_msg) __attribute__((unavailable(_msg)))
164#   else
165#       define OBJC_UNAVAILABLE(_msg) __attribute__((unavailable))
166#   endif
167#endif
168
169/* OBJC_DEPRECATED: deprecated, with a message where supported */
170#if !defined(OBJC_DEPRECATED)
171#   if __has_extension(attribute_deprecated_with_message)
172#       define OBJC_DEPRECATED(_msg) __attribute__((deprecated(_msg)))
173#   else
174#       define OBJC_DEPRECATED(_msg) __attribute__((deprecated))
175#   endif
176#endif
177
178/* OBJC_ARC_UNAVAILABLE: unavailable with -fobjc-arc */
179#if !defined(OBJC_ARC_UNAVAILABLE)
180#   if __has_feature(objc_arc)
181#       define OBJC_ARC_UNAVAILABLE OBJC_UNAVAILABLE("not available in automatic reference counting mode")
182#   else
183#       define OBJC_ARC_UNAVAILABLE
184#   endif
185#endif
186
187/* OBJC_SWIFT_UNAVAILABLE: unavailable in Swift */
188#if !defined(OBJC_SWIFT_UNAVAILABLE)
189#   if __has_feature(attribute_availability_swift)
190#       define OBJC_SWIFT_UNAVAILABLE(_msg) __attribute__((availability(swift, unavailable, message=_msg)))
191#   else
192#       define OBJC_SWIFT_UNAVAILABLE(_msg)
193#   endif
194#endif
195
196/* OBJC_ARM64_UNAVAILABLE: unavailable on arm64 (i.e. stret dispatch) */
197#if !defined(OBJC_ARM64_UNAVAILABLE)
198#   if defined(__arm64__)
199#       define OBJC_ARM64_UNAVAILABLE OBJC_UNAVAILABLE("not available in arm64")
200#   else
201#       define OBJC_ARM64_UNAVAILABLE 
202#   endif
203#endif
204
205/* OBJC_GC_UNAVAILABLE: unavailable with -fobjc-gc or -fobjc-gc-only */
206#if !defined(OBJC_GC_UNAVAILABLE)
207#   define OBJC_GC_UNAVAILABLE
208#endif
209
210#if !defined(OBJC_EXTERN)
211#   if defined(__cplusplus)
212#       define OBJC_EXTERN extern "C" 
213#   else
214#       define OBJC_EXTERN extern
215#   endif
216#endif
217
218#if !defined(OBJC_VISIBLE)
219#       define OBJC_VISIBLE  __attribute__((visibility("default")))
220#endif
221
222#if !defined(OBJC_EXPORT)
223#   define OBJC_EXPORT  OBJC_EXTERN OBJC_VISIBLE
224#endif
225
226#if !defined(OBJC_IMPORT)
227#   define OBJC_IMPORT extern
228#endif
229
230#if !defined(OBJC_ROOT_CLASS)
231#   if __has_attribute(objc_root_class)
232#       define OBJC_ROOT_CLASS __attribute__((objc_root_class))
233#   else
234#       define OBJC_ROOT_CLASS
235#   endif
236#endif
237
238#ifndef __DARWIN_NULL
239#define __DARWIN_NULL NULL
240#endif
241
242#if !defined(OBJC_INLINE)
243#   define OBJC_INLINE __inline
244#endif
245
246// Declares an enum type or option bits type as appropriate for each language.
247#if (__cplusplus && __cplusplus >= 201103L && (__has_extension(cxx_strong_enums) || __has_feature(objc_fixed_enum))) || (!__cplusplus && __has_feature(objc_fixed_enum))
248#define OBJC_ENUM(_type, _name) enum _name : _type _name; enum _name : _type
249#if (__cplusplus)
250#define OBJC_OPTIONS(_type, _name) _type _name; enum : _type
251#else
252#define OBJC_OPTIONS(_type, _name) enum _name : _type _name; enum _name : _type
253#endif
254#else
255#define OBJC_ENUM(_type, _name) _type _name; enum
256#define OBJC_OPTIONS(_type, _name) _type _name; enum
257#endif
258
259#if !defined(OBJC_RETURNS_RETAINED)
260#   if __OBJC__ && __has_attribute(ns_returns_retained)
261#       define OBJC_RETURNS_RETAINED __attribute__((ns_returns_retained))
262#   else
263#       define OBJC_RETURNS_RETAINED
264#   endif
265#endif
266
267/* OBJC_COLD: very rarely called, e.g. on error path */
268#if !defined(OBJC_COLD)
269#   if __OBJC__ && __has_attribute(cold)
270#       define OBJC_COLD __attribute__((cold))
271#   else
272#       define OBJC_COLD
273#   endif
274#endif
275
276/* OBJC_NORETURN: does not return normally, but may throw */
277#if !defined(OBJC_NORETURN)
278#   if __OBJC__ && __has_attribute(noreturn)
279#       define OBJC_NORETURN __attribute__((noreturn))
280#   else
281#       define OBJC_NORETURN
282#   endif
283#endif
284
285/* OBJC_NOESCAPE: marks a block as nonescaping */
286#if !defined(OBJC_NOESCAPE)
287#   if __has_attribute(noescape)
288#       define OBJC_NOESCAPE __attribute__((noescape))
289#   else
290#       define OBJC_NOESCAPE
291#   endif
292#endif
293
294/* OBJC_REFINED_FOR_SWIFT: hide the definition from Swift as we have a
295   better one in the overlay */
296#if !defined(OBJC_REFINED_FOR_SWIFT)
297#   if __has_attribute(swift_private)
298#       define OBJC_REFINED_FOR_SWIFT __attribute__((swift_private))
299#   else
300#       define OBJC_REFINED_FOR_SWIFT
301#   endif
302#endif
303
304#if __has_attribute(not_tail_called)
305#   define OBJC_NOT_TAIL_CALLED __attribute__((not_tail_called))
306#else
307#   define OBJC_NOT_TAIL_CALLED
308#endif
309
310#endif