zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

availability.h (14588B) - Raw


      1 /*
      2  * Copyright (c) 2008-2017 Apple Inc. All rights reserved.
      3  *
      4  * @APPLE_APACHE_LICENSE_HEADER_START@
      5  *
      6  * Licensed under the Apache License, Version 2.0 (the "License");
      7  * you may not use this file except in compliance with the License.
      8  * You may obtain a copy of the License at
      9  *
     10  *     http://www.apache.org/licenses/LICENSE-2.0
     11  *
     12  * Unless required by applicable law or agreed to in writing, software
     13  * distributed under the License is distributed on an "AS IS" BASIS,
     14  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
     15  * See the License for the specific language governing permissions and
     16  * limitations under the License.
     17  *
     18  * @APPLE_APACHE_LICENSE_HEADER_END@
     19  */
     20  
     21 #ifndef __OS_AVAILABILITY__
     22 #define __OS_AVAILABILITY__
     23 
     24 /* 
     25  * API_TO_BE_DEPRECATED is used as a version number in API that will be deprecated 
     26  * in an upcoming release. This soft deprecation is an intermediate step before formal 
     27  * deprecation to notify developers about the API before compiler warnings are generated.
     28  * You can find all places in your code that use soft deprecated API by redefining the 
     29  * value of this macro to your current minimum deployment target, for example:
     30  * (macOS)
     31  *   clang -DAPI_TO_BE_DEPRECATED=10.12 <other compiler flags>
     32  * (iOS)
     33  *   clang -DAPI_TO_BE_DEPRECATED=11.0 <other compiler flags>
     34  */
     35  
     36 #ifndef API_TO_BE_DEPRECATED
     37 #define API_TO_BE_DEPRECATED 100000
     38 #endif
     39 
     40 #ifndef API_TO_BE_DEPRECATED_MACOS
     41 #define API_TO_BE_DEPRECATED_MACOS 100000
     42 #endif
     43 
     44 #ifndef API_TO_BE_DEPRECATED_IOS
     45 #define API_TO_BE_DEPRECATED_IOS 100000
     46 #endif
     47 
     48 #ifndef API_TO_BE_DEPRECATED_TVOS
     49 #define API_TO_BE_DEPRECATED_TVOS 100000
     50 #endif
     51 
     52 #ifndef API_TO_BE_DEPRECATED_WATCHOS
     53 #define API_TO_BE_DEPRECATED_WATCHOS 100000
     54 #endif
     55 
     56 #ifndef __API_TO_BE_DEPRECATED_BRIDGEOS
     57 
     58 #endif
     59 
     60 #ifndef __API_TO_BE_DEPRECATED_MACCATALYST
     61 #define __API_TO_BE_DEPRECATED_MACCATALYST 100000
     62 #endif
     63 
     64 #ifndef API_TO_BE_DEPRECATED_DRIVERKIT
     65 #define API_TO_BE_DEPRECATED_DRIVERKIT 100000
     66 #endif
     67 
     68 #ifndef API_TO_BE_DEPRECATED_VISIONOS
     69 #define API_TO_BE_DEPRECATED_VISIONOS 100000
     70 #endif
     71 
     72 #ifndef __OPEN_SOURCE__
     73 
     74 #endif /* __OPEN_SOURCE__ */
     75 
     76 #include <AvailabilityInternal.h>
     77 #include <AvailabilityInternalLegacy.h>
     78 #if __has_include(<AvailabilityInternalPrivate.h>)
     79   #include <AvailabilityInternalPrivate.h>
     80 #endif
     81 
     82 
     83 
     84 #if defined(__has_feature) && defined(__has_attribute)
     85  #if __has_attribute(availability)
     86 
     87     /*
     88      * API Introductions
     89      *
     90      * Use to specify the release that a particular API became available.
     91      *
     92      * Platform names:
     93      *   macos, macOSApplicationExtension, macCatalyst, macCatalystApplicationExtension,
     94      *   ios, iOSApplicationExtension, tvos, tvOSApplicationExtension, watchos,
     95      *   watchOSApplicationExtension, driverkit, visionos, visionOSApplicationExtension
     96      *
     97      * Examples:
     98      *    API_AVAILABLE(macos(10.10))
     99      *    API_AVAILABLE(macos(10.9), ios(10.0))
    100      *    API_AVAILABLE(macos(10.4), ios(8.0), watchos(2.0), tvos(10.0))
    101      *    API_AVAILABLE(driverkit(19.0))
    102      */
    103 
    104     #define API_AVAILABLE(...) __API_AVAILABLE_GET_MACRO_93585900(__VA_ARGS__,__API_AVAILABLE15,__API_AVAILABLE14,__API_AVAILABLE13,__API_AVAILABLE12,__API_AVAILABLE11,__API_AVAILABLE10,__API_AVAILABLE9,__API_AVAILABLE8,__API_AVAILABLE7,__API_AVAILABLE6,__API_AVAILABLE5,__API_AVAILABLE4,__API_AVAILABLE3,__API_AVAILABLE2,__API_AVAILABLE1,__API_AVAILABLE0,0)(__VA_ARGS__)
    105     #define API_AVAILABLE_BEGIN(...) _Pragma("clang attribute push") __API_AVAILABLE_BEGIN_GET_MACRO_93585900(__VA_ARGS__,__API_AVAILABLE_BEGIN15,__API_AVAILABLE_BEGIN14,__API_AVAILABLE_BEGIN13,__API_AVAILABLE_BEGIN12,__API_AVAILABLE_BEGIN11,__API_AVAILABLE_BEGIN10,__API_AVAILABLE_BEGIN9,__API_AVAILABLE_BEGIN8,__API_AVAILABLE_BEGIN7,__API_AVAILABLE_BEGIN6,__API_AVAILABLE_BEGIN5,__API_AVAILABLE_BEGIN4,__API_AVAILABLE_BEGIN3,__API_AVAILABLE_BEGIN2,__API_AVAILABLE_BEGIN1,__API_AVAILABLE_BEGIN0,0)(__VA_ARGS__)
    106     #define API_AVAILABLE_END _Pragma("clang attribute pop")
    107 
    108     /*
    109      * API Deprecations
    110      *
    111      * Use to specify the release that a particular API became deprecated.
    112      *
    113      * Platform names:
    114      *   macos, macOSApplicationExtension, macCatalyst, macCatalystApplicationExtension,
    115      *   ios, iOSApplicationExtension, tvos, tvOSApplicationExtension, watchos,
    116      *   watchOSApplicationExtension, driverkit, visionos, visionOSApplicationExtension
    117      *
    118      * Examples:
    119      *
    120      *    API_DEPRECATED("Deprecated", macos(10.4, 10.8))
    121      *    API_DEPRECATED("Deprecated", macos(10.4, 10.8), ios(2.0, 3.0), watchos(2.0, 3.0), tvos(9.0, 10.0))
    122      *
    123      *    API_DEPRECATED_WITH_REPLACEMENT("-setName:", tvos(10.0, 10.4), ios(9.0, 10.0))
    124      *    API_DEPRECATED_WITH_REPLACEMENT("SomeClassName", macos(10.4, 10.6), watchos(2.0, 3.0))
    125      */
    126      
    127     #define API_DEPRECATED(...) __API_DEPRECATED_MSG_GET_MACRO_93585900(__VA_ARGS__,__API_DEPRECATED_MSG15,__API_DEPRECATED_MSG14,__API_DEPRECATED_MSG13,__API_DEPRECATED_MSG12,__API_DEPRECATED_MSG11,__API_DEPRECATED_MSG10,__API_DEPRECATED_MSG9,__API_DEPRECATED_MSG8,__API_DEPRECATED_MSG7,__API_DEPRECATED_MSG6,__API_DEPRECATED_MSG5,__API_DEPRECATED_MSG4,__API_DEPRECATED_MSG3,__API_DEPRECATED_MSG2,__API_DEPRECATED_MSG1,__API_DEPRECATED_MSG0,0,0)(__VA_ARGS__)
    128     #define API_DEPRECATED_WITH_REPLACEMENT(...) __API_DEPRECATED_REP_GET_MACRO_93585900(__VA_ARGS__,__API_DEPRECATED_REP15,__API_DEPRECATED_REP14,__API_DEPRECATED_REP13,__API_DEPRECATED_REP12,__API_DEPRECATED_REP11,__API_DEPRECATED_REP10,__API_DEPRECATED_REP9,__API_DEPRECATED_REP8,__API_DEPRECATED_REP7,__API_DEPRECATED_REP6,__API_DEPRECATED_REP5,__API_DEPRECATED_REP4,__API_DEPRECATED_REP3,__API_DEPRECATED_REP2,__API_DEPRECATED_REP1,__API_DEPRECATED_REP0,0,0)(__VA_ARGS__)
    129 
    130     #define API_DEPRECATED_BEGIN(...) _Pragma("clang attribute push") __API_DEPRECATED_BEGIN_GET_MACRO_93585900(__VA_ARGS__,__API_DEPRECATED_BEGIN15,__API_DEPRECATED_BEGIN14,__API_DEPRECATED_BEGIN13,__API_DEPRECATED_BEGIN12,__API_DEPRECATED_BEGIN11,__API_DEPRECATED_BEGIN10,__API_DEPRECATED_BEGIN9,__API_DEPRECATED_BEGIN8,__API_DEPRECATED_BEGIN7,__API_DEPRECATED_BEGIN6,__API_DEPRECATED_BEGIN5,__API_DEPRECATED_BEGIN4,__API_DEPRECATED_BEGIN3,__API_DEPRECATED_BEGIN2,__API_DEPRECATED_BEGIN1,__API_DEPRECATED_BEGIN0,0,0)(__VA_ARGS__)
    131     #define API_DEPRECATED_END _Pragma("clang attribute pop")
    132 
    133     #define API_DEPRECATED_WITH_REPLACEMENT_BEGIN(...) _Pragma("clang attribute push") __API_DEPRECATED_WITH_REPLACEMENT_BEGIN_GET_MACRO_93585900(__VA_ARGS__,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN15,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN14,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN13,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN12,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN11,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN10,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN9,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN8,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN7,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN6,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN5,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN4,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN3,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN2,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN1,__API_DEPRECATED_WITH_REPLACEMENT_BEGIN0,0,0)(__VA_ARGS__)
    134     #define API_DEPRECATED_WITH_REPLACEMENT_END _Pragma("clang attribute pop")
    135 
    136     /*
    137      * API Obsoletions
    138      *
    139      * Use to specify the release that a particular API became unavailable.
    140      *
    141      * Platform names:
    142      *   macos, macOSApplicationExtension, macCatalyst, macCatalystApplicationExtension,
    143      *   ios, iOSApplicationExtension, tvos, tvOSApplicationExtension, watchos,
    144      *   watchOSApplicationExtension, driverkit, visionos, visionOSApplicationExtension
    145      *
    146      * Examples:
    147      *
    148      *    API_OBSOLETED("No longer supported", macos(10.4, 10.8, 11.0))
    149      *    API_OBSOLETED("No longer supported", macos(10.4, 10.8, 11.0), ios(2.0, 3.0, 4.0), watchos(2.0, 3.0, 4.0), tvos(9.0, 10.0, 11.0))
    150      *
    151      *    API_OBSOLETED_WITH_REPLACEMENT("-setName:", tvos(10.0, 10.4, 12.0), ios(9.0, 10.0, 11.0))
    152      *    API_OBSOLETED_WITH_REPLACEMENT("SomeClassName", macos(10.4, 10.6, 11.0), watchos(2.0, 3.0, 4.0))
    153      */
    154     #define API_OBSOLETED(...) __API_OBSOLETED_MSG_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_MSG15,__API_OBSOLETED_MSG14,__API_OBSOLETED_MSG13,__API_OBSOLETED_MSG12,__API_OBSOLETED_MSG11,__API_OBSOLETED_MSG10,__API_OBSOLETED_MSG9,__API_OBSOLETED_MSG8,__API_OBSOLETED_MSG7,__API_OBSOLETED_MSG6,__API_OBSOLETED_MSG5,__API_OBSOLETED_MSG4,__API_OBSOLETED_MSG3,__API_OBSOLETED_MSG2,__API_OBSOLETED_MSG1,__API_OBSOLETED_MSG0,0,0)(__VA_ARGS__)
    155     #define API_OBSOLETED_WITH_REPLACEMENT(...) __API_OBSOLETED_REP_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_REP15,__API_OBSOLETED_REP14,__API_OBSOLETED_REP13,__API_OBSOLETED_REP12,__API_OBSOLETED_REP11,__API_OBSOLETED_REP10,__API_OBSOLETED_REP9,__API_OBSOLETED_REP8,__API_OBSOLETED_REP7,__API_OBSOLETED_REP6,__API_OBSOLETED_REP5,__API_OBSOLETED_REP4,__API_OBSOLETED_REP3,__API_OBSOLETED_REP2,__API_OBSOLETED_REP1,__API_OBSOLETED_REP0,0,0)(__VA_ARGS__)
    156 
    157     #define API_OBSOLETED_BEGIN(...) _Pragma("clang attribute push") __API_OBSOLETED_BEGIN_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_BEGIN15,__API_OBSOLETED_BEGIN14,__API_OBSOLETED_BEGIN13,__API_OBSOLETED_BEGIN12,__API_OBSOLETED_BEGIN11,__API_OBSOLETED_BEGIN10,__API_OBSOLETED_BEGIN9,__API_OBSOLETED_BEGIN8,__API_OBSOLETED_BEGIN7,__API_OBSOLETED_BEGIN6,__API_OBSOLETED_BEGIN5,__API_OBSOLETED_BEGIN4,__API_OBSOLETED_BEGIN3,__API_OBSOLETED_BEGIN2,__API_OBSOLETED_BEGIN1,__API_OBSOLETED_BEGIN0,0,0)(__VA_ARGS__)
    158     #define API_OBSOLETED_END _Pragma("clang attribute pop")
    159 
    160     #define API_OBSOLETED_WITH_REPLACEMENT_BEGIN(...) _Pragma("clang attribute push") __API_OBSOLETED_WITH_REPLACEMENT_BEGIN_GET_MACRO_93585900(__VA_ARGS__,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN15,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN14,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN13,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN12,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN11,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN10,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN9,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN8,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN7,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN6,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN5,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN4,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN3,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN2,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN1,__API_OBSOLETED_WITH_REPLACEMENT_BEGIN0,0,0)(__VA_ARGS__)
    161     #define API_OBSOLETED_WITH_REPLACEMENT_END _Pragma("clang attribute pop")
    162 
    163     /*
    164      * API Unavailability
    165      * Use to specify that an API is unavailable for a particular platform.
    166      *
    167      * Example:
    168      *    API_UNAVAILABLE(macos)
    169      *    API_UNAVAILABLE(watchos, tvos)
    170      */
    171 
    172     #define API_UNAVAILABLE(...) __API_UNAVAILABLE_GET_MACRO_93585900(__VA_ARGS__,__API_UNAVAILABLE15,__API_UNAVAILABLE14,__API_UNAVAILABLE13,__API_UNAVAILABLE12,__API_UNAVAILABLE11,__API_UNAVAILABLE10,__API_UNAVAILABLE9,__API_UNAVAILABLE8,__API_UNAVAILABLE7,__API_UNAVAILABLE6,__API_UNAVAILABLE5,__API_UNAVAILABLE4,__API_UNAVAILABLE3,__API_UNAVAILABLE2,__API_UNAVAILABLE1,__API_UNAVAILABLE0,0)(__VA_ARGS__)
    173 
    174     #define API_UNAVAILABLE_BEGIN(...) _Pragma("clang attribute push") __API_UNAVAILABLE_BEGIN_GET_MACRO_93585900(__VA_ARGS__,__API_UNAVAILABLE_BEGIN15,__API_UNAVAILABLE_BEGIN14,__API_UNAVAILABLE_BEGIN13,__API_UNAVAILABLE_BEGIN12,__API_UNAVAILABLE_BEGIN11,__API_UNAVAILABLE_BEGIN10,__API_UNAVAILABLE_BEGIN9,__API_UNAVAILABLE_BEGIN8,__API_UNAVAILABLE_BEGIN7,__API_UNAVAILABLE_BEGIN6,__API_UNAVAILABLE_BEGIN5,__API_UNAVAILABLE_BEGIN4,__API_UNAVAILABLE_BEGIN3,__API_UNAVAILABLE_BEGIN2,__API_UNAVAILABLE_BEGIN1,__API_UNAVAILABLE_BEGIN0,0)(__VA_ARGS__)
    175     #define API_UNAVAILABLE_END _Pragma("clang attribute pop")
    176  #endif /* __has_attribute(availability) */
    177 #endif /* #if defined(__has_feature) && defined(__has_attribute) */
    178 
    179 /* 
    180  * Evaluate to nothing for compilers that don't support clang language extensions.
    181  */
    182 
    183 #ifndef API_AVAILABLE
    184   #define API_AVAILABLE(...)
    185 #endif
    186 
    187 #ifndef API_AVAILABLE_BEGIN
    188   #define API_AVAILABLE_BEGIN(...)
    189 #endif
    190 
    191 #ifndef API_AVAILABLE_END
    192   #define API_AVAILABLE_END(...)
    193 #endif
    194 
    195 #ifndef API_DEPRECATED
    196   #define API_DEPRECATED(...)
    197 #endif
    198 
    199 #ifndef API_DEPRECATED_BEGIN
    200   #define API_DEPRECATED_BEGIN(...)
    201 #endif
    202 
    203 #ifndef API_DEPRECATED_END
    204   #define API_DEPRECATED_END(...)
    205 #endif
    206 
    207 #ifndef API_DEPRECATED_WITH_REPLACEMENT
    208   #define API_DEPRECATED_WITH_REPLACEMENT(...)
    209 #endif
    210 
    211 #ifndef API_DEPRECATED_WITH_REPLACEMENT_BEGIN
    212   #define API_DEPRECATED_WITH_REPLACEMENT_BEGIN(...)
    213 #endif
    214 
    215 #ifndef API_DEPRECATED_WITH_REPLACEMENT_END
    216   #define API_DEPRECATED_WITH_REPLACEMENT_END(...)
    217 #endif
    218 
    219 #ifndef API_OBSOLETED
    220   #define API_OBSOLETED(...)
    221 #endif
    222 
    223 #ifndef API_OBSOLETED_BEGIN
    224   #define API_OBSOLETED_BEGIN(...)
    225 #endif
    226 
    227 #ifndef API_OBSOLETED_END
    228   #define API_OBSOLETED_END(...)
    229 #endif
    230 
    231 #ifndef API_OBSOLETED_WITH_REPLACEMENT
    232   #define API_OBSOLETED_WITH_REPLACEMENT(...)
    233 #endif
    234 
    235 #ifndef API_OBSOLETED_WITH_REPLACEMENT_BEGIN
    236   #define API_OBSOLETED_WITH_REPLACEMENT_BEGIN(...)
    237 #endif
    238 
    239 #ifndef API_OBSOLETED_WITH_REPLACEMENT_END
    240   #define API_OBSOLETED_WITH_REPLACEMENT_END(...)
    241 #endif
    242 
    243 #ifndef API_UNAVAILABLE
    244   #define API_UNAVAILABLE(...)
    245 #endif
    246 
    247 #ifndef API_UNAVAILABLE_BEGIN
    248   #define API_UNAVAILABLE_BEGIN(...)
    249 #endif
    250 
    251 #ifndef API_UNAVAILABLE_END
    252   #define API_UNAVAILABLE_END(...)
    253 #endif
    254 
    255 #if __has_include(<AvailabilityProhibitedInternal.h>)
    256   #include <AvailabilityProhibitedInternal.h>
    257 #endif
    258 
    259 /*
    260  * If SPI decorations have not been defined elsewhere, disable them.
    261  */
    262 
    263 #ifndef SPI_AVAILABLE
    264   #define SPI_AVAILABLE(...)
    265 #endif
    266 
    267 #ifndef SPI_AVAILABLE_BEGIN
    268   #define SPI_AVAILABLE_BEGIN(...)
    269 #endif
    270 
    271 #ifndef SPI_AVAILABLE_END
    272   #define SPI_AVAILABLE_END(...)
    273 #endif
    274 
    275 #ifndef SPI_DEPRECATED
    276   #define SPI_DEPRECATED(...)
    277 #endif
    278 
    279 #ifndef SPI_DEPRECATED_WITH_REPLACEMENT
    280   #define SPI_DEPRECATED_WITH_REPLACEMENT(...)
    281 #endif
    282 
    283 #endif /* __OS_AVAILABILITY__ */
    284 
    285 #ifndef __OPEN_SOURCE__
    286 // This is explicitly outside the header guard
    287 #ifndef __AVAILABILITY_VERSIONS_VERSION_HASH
    288 #define __AVAILABILITY_VERSIONS_VERSION_HASH 93585900U
    289 #define __AVAILABILITY_VERSIONS_VERSION_STRING "Local"
    290 #define __AVAILABILITY_FILE "os/availability.h"
    291 #elif __AVAILABILITY_VERSIONS_VERSION_HASH != 93585900U
    292 #pragma GCC error "Already found AvailabilityVersions version " __AVAILABILITY_FILE " from " __AVAILABILITY_VERSIONS_VERSION_STRING ", which is incompatible with os/availability.h from Local. Mixing and matching Availability from different SDKs is not supported"
    293 #endif /* __AVAILABILITY_VERSIONS_VERSION_HASH */
    294 #endif /* __OPEN_SOURCE__ */