Skip to content

CoreGraphics macOS xcode9 beta1

Miguel de Icaza edited this page Jul 19, 2017 · 2 revisions

#CoreGraphics.framework

https://github.com/xamarin/xamarin-macios/pull/2181

diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGBase.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGBase.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGBase.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGBase.h	2017-05-23 18:42:06.000000000 -0400
@@ -291,6 +291,12 @@
 #   define cg_nullable __nullable
 #endif
 
-
+#if __has_feature(nullability_on_arrays)
+# define CG_NONNULL_ARRAY __nonnull
+# define CG_NULLABLE_ARRAY __nullable
+#else
+# define CG_NONNULL_ARRAY
+# define CG_NULLABLE_ARRAY
+#endif
 
 #endif /* CGBASE_H_ */
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColor.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColor.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColor.h	2016-09-29 00:51:33.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColor.h	2017-05-25 04:48:03.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGColor *CGColorRef;
+typedef struct CF_BRIDGED_TYPE(id) CGColor *CGColorRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreGraphics/CGColorSpace.h>
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColorConversionInfo.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColorConversionInfo.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColorConversionInfo.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColorConversionInfo.h	2017-05-23 18:42:06.000000000 -0400
@@ -41,9 +41,15 @@
   (CFDictionaryRef __nullable options, cg_nullable CGColorSpaceRef, CGColorConversionInfoTransformType, CGColorRenderingIntent, ...)
   CG_AVAILABLE_STARTING(__MAC_10_12, __IPHONE_10_0);
 
+CG_EXTERN CGColorConversionInfoRef __nullable CGColorConversionInfoCreateFromListWithArguments
+  (CFDictionaryRef __nullable options, cg_nullable CGColorSpaceRef, CGColorConversionInfoTransformType, CGColorRenderingIntent, va_list)
+  CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
 /* CFBooleanRef which can be used as option to create CGColorConversionInfoRef, when Black Point Compensation is desired */
 CG_EXTERN const CFStringRef kCGColorConversionBlackPointCompensation CG_AVAILABLE_STARTING(__MAC_10_12, __IPHONE_10_0);
 
+CG_EXTERN const CFStringRef kCGColorConversionTRCSize CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
 CF_ASSUME_NONNULL_END
 
 CF_IMPLICIT_BRIDGING_DISABLED
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColorSpace.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColorSpace.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColorSpace.h	2016-08-06 02:28:19.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGColorSpace.h	2017-05-20 01:58:09.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGColorSpace *CGColorSpaceRef;
+typedef struct CF_BRIDGED_TYPE(id) CGColorSpace *CGColorSpaceRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreGraphics/CGDataProvider.h>
@@ -169,10 +169,12 @@
    numbers specifying the tristimulus value, in the CIE 1931 XYZ-space, of
    the diffuse white point. `blackPoint' is an array of 3 numbers specifying
    the tristimulus value, in CIE 1931 XYZ-space, of the diffuse black point.
-   `gamma' defines the gamma for the gray component. */
+   `gamma' defines the gamma for the gray component. Specifying `blackPoint'
+   is not required and in such a case `blackPoint' will be assumed to be 
+   [0.0, 0.0, 0.0]. */
 
 CG_EXTERN CGColorSpaceRef __nullable CGColorSpaceCreateCalibratedGray(const CGFloat
-  whitePoint[3], const CGFloat blackPoint[3], CGFloat gamma)
+  whitePoint[CG_NONNULL_ARRAY 3], const CGFloat blackPoint[__nullable 3], CGFloat gamma)
   CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_2_0);
 
 /* Create a calibrated RGB color space. `whitePoint' is an array of 3
@@ -182,28 +184,36 @@
    `gamma' is an array of 3 numbers specifying the gamma for the red, green,
    and blue components of the color space. `matrix' is an array of 9 numbers
    specifying the linear interpretation of the gamma-modified RGB values of
-   the color space with respect to the final XYZ representation. */
+   the color space with respect to the final XYZ representation. 
+   Not all parameters need to be specified. If `blackPoint' is NULL it will be
+   assumed to be [0.0, 0.0, 0.0]. If `gamma' is NULL it will be assumed to be
+   linear for all components. If `matrix' is NULL it will be assumed to be identity. */
 
 CG_EXTERN CGColorSpaceRef __nullable CGColorSpaceCreateCalibratedRGB(const CGFloat
-  whitePoint[3], const CGFloat blackPoint[3], const CGFloat gamma[3],
-  const CGFloat matrix[9]) CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_2_0);
+  whitePoint[CG_NONNULL_ARRAY 3], const CGFloat blackPoint[__nullable 3],
+  const CGFloat gamma[__nullable 3], const CGFloat matrix[__nullable 9])
+  CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_2_0);
     
 /* Create an L*a*b* color space. `whitePoint' is an array of 3 numbers
    specifying the tristimulus value, in the CIE 1931 XYZ-space, of the
    diffuse white point. `blackPoint' is an array of 3 numbers specifying the
    tristimulus value, in CIE 1931 XYZ-space, of the diffuse black point.
    `range' is an array of four numbers specifying the range of valid values
-   for the a* and b* components of the color space. */
+   for the a* and b* components of the color space. Not all parameters need to be
+   specified. If `blackPoint'in NULL it will be assumed to be [0.0, 0.0, 0.0].
+   If `range' is NULL it will be assumed to be [-100, 100, -100, 100]. */
 
-CG_EXTERN CGColorSpaceRef __nullable CGColorSpaceCreateLab(const CGFloat whitePoint[3],
-  const CGFloat blackPoint[3], const CGFloat range[4])
+CG_EXTERN CGColorSpaceRef __nullable CGColorSpaceCreateLab(const CGFloat whitePoint[CG_NONNULL_ARRAY 3],
+  const CGFloat blackPoint[__nullable 3], const CGFloat range[__nullable 4])
   CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_2_0);
 
-/* Create an ICC-based color space using the ICC profile specified by
-   `data'. */
+/* Create an ICC-based color space using the ICC profile raw data specified by
+   `data' which can be either CFDataRef or CGDataProviderRef */
 
-CG_EXTERN CGColorSpaceRef __nullable CGColorSpaceCreateWithICCProfile(CFDataRef cg_nullable data)
-  CG_AVAILABLE_STARTING(__MAC_10_5, __IPHONE_2_0);
+CG_EXTERN CGColorSpaceRef CGColorSpaceCreateWithICCData(CFTypeRef cg_nullable data)
+  CG_AVAILABLE_STARTING(__MAC_10_12, __IPHONE_10_0);
+
+#define CGColorSpaceCreateWithICCProfile CGColorSpaceCreateWithICCData
 
 /* Create an ICC-based color space. `nComponents' specifies the number of
    color components in the color space defined by the ICC profile data. This
@@ -315,16 +325,14 @@
 CG_EXTERN void CGColorSpaceGetColorTable(CGColorSpaceRef cg_nullable space,
   uint8_t * cg_nullable table) CG_AVAILABLE_STARTING(__MAC_10_5, __IPHONE_2_0);
 
-/* Return a copy of the ICC profile of `space', or NULL if the color space
+/* Return a copy of the ICC profile data of `space', or NULL if the color space
    doesn't have an ICC profile. */
 
-CG_EXTERN CFDataRef __nullable CGColorSpaceCopyICCProfile(CGColorSpaceRef cg_nullable space);
-//__CG_DEPRECATED_WITH_MSG("Don't this function; call "
-//                         "`CGColorSpaceCopyICCData' instead.");
-
 CG_EXTERN CFDataRef __nullable CGColorSpaceCopyICCData(CGColorSpaceRef cg_nullable space)
 CG_AVAILABLE_STARTING(__MAC_10_12, __IPHONE_10_0);
 
+#define CGColorSpaceCopyICCProfile CGColorSpaceCopyICCData
+
 /* Return true if gamut of the RGB color space is greater than 85% of NTSC gamut */
 
 CG_EXTERN bool CGColorSpaceIsWideGamutRGB(CGColorSpaceRef)
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGContext.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGContext.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGContext.h	2016-09-29 00:51:33.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGContext.h	2017-05-23 18:42:06.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGContext *CGContextRef;
+typedef struct CF_BRIDGED_TYPE(id) CGContext *CGContextRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreGraphics/CGAffineTransform.h>
@@ -465,6 +465,10 @@
 CG_EXTERN void CGContextEOClip(CGContextRef cg_nullable c)
     CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_2_0);
 
+/* Reset the current clip of `c' to the default value. */
+
+CG_EXTERN void CGContextResetClip(CGContextRef c);
+
 /* Add `mask' transformed to `rect' to the clipping area of `context'. The
    mask, which may be either an image mask or an image, is mapped into the
    specified rectangle and intersected with the current clipping area of the
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDataConsumer.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDataConsumer.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDataConsumer.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDataConsumer.h	2017-05-23 18:42:06.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGDataConsumer *CGDataConsumerRef;
+typedef struct CF_BRIDGED_TYPE(id) CGDataConsumer *CGDataConsumerRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreFoundation/CFURL.h>
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDataProvider.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDataProvider.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDataProvider.h	2016-09-29 00:51:34.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDataProvider.h	2017-05-20 02:06:07.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGDataProvider *CGDataProviderRef;
+typedef struct CF_BRIDGED_TYPE(id) CGDataProvider *CGDataProviderRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreFoundation/CFURL.h>
@@ -84,9 +84,13 @@
 /* Callbacks for directly accessing data.
    `version' is the version of this structure. It should be set to 0.
    `getBytePointer', if non-NULL, is called to return a pointer to the
-     provider's entire block of data.
+     provider's entire block of data. This callback may be called multiple
+     times in proper sequence with `releaseBytePointer'. Data block does not
+     need to be available until this callback is invoked.
    `releaseBytePointer', if non-NULL, is called to release a pointer to the
-     provider's entire block of data.
+     provider's entire block of data. This callback may be called multiple
+     times in proper sequence with `getBytePointer'. If possible, data should
+     be purged with this callback and refilled with `getBytePointer'.
    `getBytesAtPosition', if non-NULL, is called to copy `count' bytes at
      offset `position' from the provider's data to `buffer'. It should
      return the number of bytes copied, or 0 if there's no more data.
@@ -94,7 +98,10 @@
      the provider is freed.
 
    At least one of `getBytePointer' or `getBytesAtPosition' must be
-   non-NULL. */
+   non-NULL. 
+ 
+   If both `getBytePointer' are present `getBytesAtPosition', the latter one 
+   may be ignored. */
 
 struct CGDataProviderDirectCallbacks {
     unsigned int version;
@@ -180,6 +187,9 @@
     CGDataProviderRef cg_nullable provider)
     CG_AVAILABLE_STARTING(__MAC_10_3, __IPHONE_2_0);
 
+CG_EXTERN void* __nullable CGDataProviderGetInfo(CGDataProviderRef cg_nullable provider)
+    CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
 CF_ASSUME_NONNULL_END
 
 CF_IMPLICIT_BRIDGING_DISABLED
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDirectDisplay.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDirectDisplay.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDirectDisplay.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDirectDisplay.h	2017-05-23 18:42:06.000000000 -0400
@@ -12,13 +12,15 @@
 #include <CoreGraphics/CGContext.h>
 #include <CoreGraphics/CGError.h>
 #include <CoreGraphics/CGGeometry.h>
+#include <CoreGraphics/CGWindow.h>
+#include <CoreGraphics/CGWindowLevel.h>
 #include <mach/boolean.h>
 
 typedef uint32_t CGDirectDisplayID;
 typedef uint32_t CGOpenGLDisplayMask;
 typedef double CGRefreshRate;
 
-typedef struct CGDisplayMode *CGDisplayModeRef;
+typedef struct CF_BRIDGED_TYPE(id) CGDisplayMode *CGDisplayModeRef;
 
 #define kCGNullDirectDisplay ((CGDirectDisplayID)0)
 #define kCGDirectMainDisplay CGMainDisplayID()
@@ -366,13 +368,13 @@
 /* Returns window ID of the shield window for the captured display `display',
    or NULL if the display is not not shielded. */
 
-CG_EXTERN uint32_t CGShieldingWindowID(CGDirectDisplayID display)
+CG_EXTERN CGWindowID CGShieldingWindowID(CGDirectDisplayID display)
     CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_NA);
 
 /* Returns the window level of the shield window for the captured display
    `display'. */
 
-CG_EXTERN int32_t CGShieldingWindowLevel(void)
+CG_EXTERN CGWindowLevel CGShieldingWindowLevel(void)
     CG_AVAILABLE_STARTING(__MAC_10_0, __IPHONE_NA);
 
 /* Return an image containing the contents of the display identified by
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDisplayStream.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDisplayStream.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDisplayStream.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGDisplayStream.h	2017-05-23 18:42:06.000000000 -0400
@@ -25,7 +25,7 @@
  scaling and color space conversion services, as well as allow capturing sub regions of the display.   Callbacks can be targetted
  at either a traditional CFRunLoop, or at a dispatch queue.
 */
-typedef struct CGDisplayStream *CGDisplayStreamRef;
+typedef struct CF_BRIDGED_TYPE(id) CGDisplayStream *CGDisplayStreamRef;
 
 /*!
  @typedef CGDisplayStreamUpdateRef
@@ -35,7 +35,7 @@
  regions were merely copied from one place to another.   A routine is provided to merge two update refs together in cases
  where apps need to coalesce the values because they decided to skip processing for one or more frames.
 */
-typedef const struct CGDisplayStreamUpdate *CGDisplayStreamUpdateRef;
+typedef const struct CF_BRIDGED_TYPE(id) CGDisplayStreamUpdate *CGDisplayStreamUpdateRef;
 
 /*!
  @enum CGDisplayStreamUpdateRectType
@@ -57,7 +57,7 @@
  @abstract Provides information about incoming frame updates
  @const kCGDisplayStreamFrameStatusFrameComplete A new frame has been generated by the Window Server for a particular display at time displayTime
  @const kCGDisplayStreamFrameStatusFrameIdle The Window Server did not generate a new frame for displayTime
- @const kCGDisplayStreamFrameStatusFrameBlank As of displayTime, the display is has gone blank
+ @const kCGDisplayStreamFrameStatusFrameBlank As of displayTime, the display has gone blank
  @const kCGDisplayStreamFrameStatusStopped The display stream has stopped and no more calls will be made to the handler until the stream is started.
 */
 typedef CF_ENUM(int32_t, CGDisplayStreamFrameStatus){
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGEvent.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGEvent.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGEvent.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGEvent.h	2017-05-23 18:42:06.000000000 -0400
@@ -357,6 +357,7 @@
    instantiated for the specified process, and the event passes through any
    such taps. */
 
+/* DEPRECATED; use CGEventPostToPid instead. */
 CG_EXTERN void CGEventPostToPSN(void * __nullable processSerialNumber,
     CGEventRef __nullable event)
     CG_AVAILABLE_STARTING(__MAC_10_4, __IPHONE_NA);
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGEventTypes.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGEventTypes.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGEventTypes.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGEventTypes.h	2017-05-23 18:42:06.000000000 -0400
@@ -32,7 +32,7 @@
    This opaque type is derived from `CFType' and inherits the properties
    that all Core Foundation types have in common. */
 
-typedef struct __CGEvent *CGEventRef;
+typedef struct CF_BRIDGED_TYPE(id) __CGEvent *CGEventRef;
 
 /* Constants that specify buttons on a one, two, or three-button mouse. */
 typedef CF_ENUM(uint32_t, CGMouseButton) {
@@ -460,7 +460,7 @@
 typedef struct __CGEventTapInformation CGEventTapInformation;
 
 /* An opaque type that represents the source of a Quartz event. */
-typedef struct __CGEventSource *CGEventSourceRef;
+typedef struct CF_BRIDGED_TYPE(id) __CGEventSource *CGEventSourceRef;
 
 /* Constants that specify the possible source states of an event source. */
 typedef CF_ENUM(int32_t, CGEventSourceStateID) {
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGFont.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGFont.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGFont.h	2016-09-12 22:40:16.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGFont.h	2017-05-25 04:48:03.000000000 -0400
@@ -11,7 +11,7 @@
 
 /* The type used to represent a CoreGraphics font. */
 
-typedef struct CGFont *CGFontRef;
+typedef struct CF_BRIDGED_TYPE(id) CGFont *CGFontRef;
 
 /* A type to represent indexes in a CGFontRef. */
 
@@ -69,7 +69,7 @@
 /* Return the font defined by the data provided by `provider', or NULL if
    the font can't be created. */
 
-CG_EXTERN CGFontRef cg_nullable CGFontCreateWithDataProvider(
+CG_EXTERN CGFontRef __nullable CGFontCreateWithDataProvider(
     CGDataProviderRef cg_nullable provider)
     CG_AVAILABLE_STARTING(__MAC_10_5, __IPHONE_2_0);
 
@@ -245,14 +245,14 @@
 CG_EXTERN CFDataRef __nullable CGFontCreatePostScriptSubset(
     CGFontRef cg_nullable font, CFStringRef cg_nullable subsetName,
     CGFontPostScriptFormat format, const CGGlyph * __nullable glyphs,
-    size_t count, const CGGlyph encoding[256])
+    size_t count, const CGGlyph encoding[CG_NONNULL_ARRAY 256])
     CG_AVAILABLE_STARTING(__MAC_10_4, __IPHONE_2_0);
 
 /* Return a PostScript encoding of `font' containing glyphs in
    `encoding'. */
 
 CG_EXTERN CFDataRef __nullable CGFontCreatePostScriptEncoding(
-    CGFontRef cg_nullable font, const CGGlyph encoding[256])
+    CGFontRef cg_nullable font, const CGGlyph encoding[CG_NONNULL_ARRAY 256])
     CG_AVAILABLE_STARTING(__MAC_10_4, __IPHONE_2_0);
 
 /* Return an array of font table tags in `font'. Each entry in the array is
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGFunction.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGFunction.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGFunction.h	2016-09-29 00:51:33.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGFunction.h	2017-05-25 04:14:35.000000000 -0400
@@ -5,11 +5,13 @@
 #ifndef CGFUNCTION_H_
 #define CGFUNCTION_H_
 
+#include <CoreFoundation/CFBase.h>
+
 /* A CGFunction is a general floating-point function evaluator which uses a
    user-specified callback to map an arbitrary number of inputs to an
    arbitrary number of outputs. */
 
-typedef struct CGFunction *CGFunctionRef;
+typedef struct CF_BRIDGED_TYPE(id) CGFunction *CGFunctionRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreFoundation/CFBase.h>
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGGradient.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGGradient.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGGradient.h	2016-09-12 22:40:16.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGGradient.h	2017-05-20 01:42:24.000000000 -0400
@@ -5,13 +5,12 @@
 #ifndef CGGRADIENT_H_
 #define CGGRADIENT_H_
 
-typedef struct CGGradient *CGGradientRef;
-
-
 #include <CoreFoundation/CFBase.h>
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
+typedef struct CF_BRIDGED_TYPE(id) CGGradient *CGGradientRef;
+
 typedef CF_OPTIONS (uint32_t, CGGradientDrawingOptions) {
   kCGGradientDrawsBeforeStartLocation = (1 << 0),
   kCGGradientDrawsAfterEndLocation = (1 << 1)
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGImage.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGImage.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGImage.h	2016-08-06 02:29:26.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGImage.h	2017-05-25 04:14:34.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGImage *CGImageRef;
+typedef struct CF_BRIDGED_TYPE(id) CGImage *CGImageRef;
 
 #include <CoreGraphics/CGColorSpace.h>
 #include <CoreGraphics/CGDataProvider.h>
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGLayer.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGLayer.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGLayer.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGLayer.h	2017-05-23 18:42:06.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGLayer *CGLayerRef;
+typedef struct CF_BRIDGED_TYPE(id) CGLayer *CGLayerRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreGraphics/CGContext.h>
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFContext.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFContext.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFContext.h	2016-08-06 02:28:20.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFContext.h	2017-05-20 01:44:32.000000000 -0400
@@ -291,6 +291,17 @@
 CG_EXTERN const CFStringRef  kCGPDFContextOutputIntents
   CG_AVAILABLE_STARTING(__MAC_10_4, __IPHONE_NA);
 
+/* The document's access permissions, expressed as a CFNumber. The number is
+   defined by ORing together the desired CGPDFAccessPermissions values. */
+
+CG_EXTERN const CFStringRef  kCGPDFContextAccessPermissions
+  CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
+/* Set the outline in the PDF created by a CGPDFContext (no effect in other types of CGContexts). */
+
+CG_EXTERN void CGPDFContextSetOutline(CGContextRef context, __nullable CFDictionaryRef outline)
+  CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
 CF_ASSUME_NONNULL_END
 
 CF_IMPLICIT_BRIDGING_DISABLED
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFDocument.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFDocument.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFDocument.h	2016-09-29 00:51:34.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFDocument.h	2017-05-25 04:14:35.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGPDFDocument *CGPDFDocumentRef;
+typedef struct CF_BRIDGED_TYPE(id) CGPDFDocument *CGPDFDocumentRef;
 
 #include <CoreGraphics/CGDataProvider.h> 
 #include <CoreGraphics/CGGeometry.h> 
@@ -20,6 +20,70 @@
 
 CF_ASSUME_NONNULL_BEGIN
 
+// To get access permissions from a CGPDFDocument, call CGPDFDocumentGetAccessPermissions. Setting permissions
+// can only be done using the kCGPDFContextAccessPermissions property in the auxiliary info dictionary passed
+// in to CGPDFContextCreate.
+//
+// Some PDF access permissions are non-strict supersets of other permissions. Granting access to a superset
+// permission also grants access to permission(s) it is a superset of. These permissions are as follows:
+//
+// * Granting kCGPDFAllowsHighQualityPrinting also grants kCGPDFAllowsLowQualityPrinting
+// * Granting kCGPDFAllowsDocumentChanges also grants kCGPDFAllowsCommenting and kCGPDFAllowsFormFieldEntry
+// * Granting kCGPDFAllowsContentCopying also grants kCGPDFAllowsContentAccessibility
+// * Granting kCGPDFAllowsCommenting also grants kCGPDFAllowsFormFieldEntry
+//
+// These relationships don't come from the PDF spec. There is nothing in the spec that says you always get
+// low-quality printing if you've already got high-quality printing. They are just two different bits with
+// no explicit dependencies. However, in practice, the software that most people use to edit PDF permissions
+// only allows creation of PDFs that follow these conventions.
+//
+// In the interest of consistency with how these bits are used in practice, kCGPDFContextAccessPermissions
+// enforces the superset model of PDF permissions. For example, if you try to grant high-quality printing but
+// not low-quality printing, the low-quality bit will get turned on anyway. This does not apply to how permissions
+// are read, however. It's very likely that there exist PDFs that don't follow these conventions. For that reason,
+// when checking permissions, always check for the narrowest one that applies. For example, if you're interested
+// in form field entry, always test for kCGPDFAllowsFormFieldEntry specifically. You can't assume that you have it
+// just because you also have kCGPDFAllowsCommenting or kCGPDFAllowsDocumentChanges.
+
+typedef CF_OPTIONS(uint32_t, CGPDFAccessPermissions) {
+    kCGPDFAllowsLowQualityPrinting    = (1 << 0),   // Print at up to 150 DPI
+    kCGPDFAllowsHighQualityPrinting   = (1 << 1),   // Print at any DPI
+    kCGPDFAllowsDocumentChanges       = (1 << 2),   // Modify the document contents except for page management
+    kCGPDFAllowsDocumentAssembly      = (1 << 3),   // Page management: insert, delete, and rotate pages
+    kCGPDFAllowsContentCopying        = (1 << 4),   // Extract content (text, images, etc.)
+    kCGPDFAllowsContentAccessibility  = (1 << 5),   // Extract content, but only for the purpose of accessibility
+    kCGPDFAllowsCommenting            = (1 << 6),   // Create or modify annotations, including form field entries
+    kCGPDFAllowsFormFieldEntry        = (1 << 7)    // Modify form field entries
+};
+
+/* CFDictionary keys for use with CGPDFDocumentGetOutline and CGPDFContextSetOutline. */
+
+// Outlines don't contain a single root node, however we have to represent outlines as trees with a single root.
+// The root CFDictionary will only have one key (kCGPDFOutlineChildren), and it is not considered part of the
+// outline itself. All CFDictionaries below the root must have at least two keys: kCGPDFOutlineTitle and
+// kCGPDFOutlineDestination. If they have any children, they must have kCGPDFOutlineChildren as well. Finally,
+// kCGPDFOutlineDestinationRect can optionally be present to associate an area of the destination page.
+
+/* Key:   kCGPDFOutlineTitle */
+/* Value: CFString */
+CG_EXTERN const CFStringRef kCGPDFOutlineTitle
+    CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
+/* Key:   kCGPDFOutlineChildren */
+/* Value: CFArray of CFDictionaries */
+CG_EXTERN const CFStringRef kCGPDFOutlineChildren
+    CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
+/* Key:   kCGPDFOutlineDestination */
+/* Value: CFNumber (for a one-indexed page number) or CFURL */
+CG_EXTERN const CFStringRef kCGPDFOutlineDestination
+    CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
+/* Key:   kCGPDFOutlineDestinationRect */
+/* Value: CFDictionary from CGRectCreateDictionaryRepresentation. Only valid when the destination is a page number. */
+CG_EXTERN const CFStringRef kCGPDFOutlineDestinationRect
+    CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
 /* Create a PDF document, using `provider' to obtain the document's data. */
 
 CG_EXTERN CGPDFDocumentRef __nullable CGPDFDocumentCreateWithProvider(
@@ -126,6 +190,16 @@
 CG_EXTERN CFTypeID CGPDFDocumentGetTypeID(void)
     CG_AVAILABLE_STARTING(__MAC_10_2, __IPHONE_2_0);
 
+/* Return the document outline in the form of a CFDictionary tree containing the kCGPDFOutline keys. */
+
+CG_EXTERN __nullable CFDictionaryRef CGPDFDocumentGetOutline(CGPDFDocumentRef document)
+    CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
+/* Return the document access permissions. */
+
+CG_EXTERN CGPDFAccessPermissions CGPDFDocumentGetAccessPermissions(CGPDFDocumentRef document)
+    CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
 /* The following functions are deprecated in favor of the CGPDFPage API. */
 
 /* DEPRECATED; return the media box of page number `page' in `document'.
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFPage.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFPage.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFPage.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPDFPage.h	2017-05-23 18:42:06.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGPDFPage *CGPDFPageRef;
+typedef struct CF_BRIDGED_TYPE(id) CGPDFPage *CGPDFPageRef;
 
 #include <CoreGraphics/CGAffineTransform.h> 
 #include <CoreGraphics/CGPDFDictionary.h> 
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPSConverter.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPSConverter.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPSConverter.h	2016-05-03 18:21:22.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPSConverter.h	2017-05-23 18:42:06.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGPSConverter *CGPSConverterRef;
+typedef struct CF_BRIDGED_TYPE(id) CGPSConverter *CGPSConverterRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreGraphics/CGDataConsumer.h>
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPath.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPath.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPath.h	2016-08-06 02:28:20.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPath.h	2017-05-25 04:48:03.000000000 -0400
@@ -9,8 +9,8 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGPath *CGMutablePathRef;
-typedef const struct CGPath *CGPathRef;
+typedef struct CF_BRIDGED_TYPE(id) CGPath *CGMutablePathRef;
+typedef const struct CF_BRIDGED_TYPE(id) CGPath *CGPathRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreGraphics/CGAffineTransform.h>
@@ -388,6 +388,11 @@
     CGPathApplierFunction cg_nullable function)
     CG_AVAILABLE_STARTING(__MAC_10_2, __IPHONE_2_0);
 
+typedef void (^CGPathApplyBlock)(const CGPathElement * element);
+
+CG_EXTERN void CGPathApplyWithBlock(CGPathRef path, CGPathApplyBlock CF_NOESCAPE block)
+    CG_AVAILABLE_STARTING(__MAC_10_13, __IPHONE_11_0);
+
 CF_ASSUME_NONNULL_END
 
 CF_IMPLICIT_BRIDGING_DISABLED
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPattern.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPattern.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPattern.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGPattern.h	2017-05-23 18:42:06.000000000 -0400
@@ -5,11 +5,12 @@
 #ifndef CGPATTERN_H_
 #define CGPATTERN_H_
 
-typedef struct CGPattern *CGPatternRef;
+#include <CoreFoundation/CFBase.h>
+
+typedef struct CF_BRIDGED_TYPE(id) CGPattern *CGPatternRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreGraphics/CGContext.h>
-#include <CoreFoundation/CFBase.h>
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGShading.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGShading.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGShading.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGShading.h	2017-05-23 18:42:06.000000000 -0400
@@ -9,7 +9,7 @@
 #include <CoreFoundation/CFAvailability.h>
 #include <stdint.h>
 
-typedef struct CGShading *CGShadingRef;
+typedef struct CF_BRIDGED_TYPE(id) CGShading *CGShadingRef;
 
 #include <CoreGraphics/CGBase.h>
 #include <CoreGraphics/CGColorSpace.h>
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGWindowLevel.h /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGWindowLevel.h
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGWindowLevel.h	2016-10-06 22:34:48.000000000 -0400
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CGWindowLevel.h	2017-05-23 18:42:06.000000000 -0400
@@ -54,49 +54,30 @@
 
 /* The number of window levels reserved by Apple for internal use. */
 #define kCGNumReservedWindowLevels	(16)
+#define kCGNumReservedBaseWindowLevels (5)
 
 /* Definitions of older constant values. */
-#define kCGBaseWindowLevel						\
-  CGWindowLevelForKey(kCGBaseWindowLevelKey)
-#define kCGMinimumWindowLevel						\
-  CGWindowLevelForKey(kCGMinimumWindowLevelKey)
-#define kCGDesktopWindowLevel						\
-  CGWindowLevelForKey(kCGDesktopWindowLevelKey)
-#define kCGDesktopIconWindowLevel					\
-  CGWindowLevelForKey(kCGDesktopIconWindowLevelKey)
-#define kCGBackstopMenuLevel						\
-  CGWindowLevelForKey(kCGBackstopMenuLevelKey)
-#define kCGNormalWindowLevel						\
-  CGWindowLevelForKey(kCGNormalWindowLevelKey)
-#define kCGFloatingWindowLevel						\
-  CGWindowLevelForKey(kCGFloatingWindowLevelKey)
-#define kCGTornOffMenuWindowLevel					\
-  CGWindowLevelForKey(kCGTornOffMenuWindowLevelKey)
-#define kCGDockWindowLevel						\
-  CGWindowLevelForKey(kCGDockWindowLevelKey)
-#define kCGMainMenuWindowLevel						\
-  CGWindowLevelForKey(kCGMainMenuWindowLevelKey)
-#define kCGStatusWindowLevel						\
-  CGWindowLevelForKey(kCGStatusWindowLevelKey)
-#define kCGModalPanelWindowLevel					\
-  CGWindowLevelForKey(kCGModalPanelWindowLevelKey)
-#define kCGPopUpMenuWindowLevel						\
-  CGWindowLevelForKey(kCGPopUpMenuWindowLevelKey)
-#define kCGDraggingWindowLevel						\
-  CGWindowLevelForKey(kCGDraggingWindowLevelKey)
-#define kCGScreenSaverWindowLevel					\
-  CGWindowLevelForKey(kCGScreenSaverWindowLevelKey)
-#define kCGCursorWindowLevel						\
-  CGWindowLevelForKey(kCGCursorWindowLevelKey)
-#define kCGOverlayWindowLevel						\
-  CGWindowLevelForKey(kCGOverlayWindowLevelKey)
-#define kCGHelpWindowLevel						\
-  CGWindowLevelForKey(kCGHelpWindowLevelKey)
-#define kCGUtilityWindowLevel						\
-  CGWindowLevelForKey(kCGUtilityWindowLevelKey)
-#define kCGAssistiveTechHighWindowLevel					\
-  CGWindowLevelForKey(kCGAssistiveTechHighWindowLevelKey)
-#define kCGMaximumWindowLevel						\
-  CGWindowLevelForKey(kCGMaximumWindowLevelKey)
+#define kCGBaseWindowLevel              ((CGWindowLevel)INT32_MIN)
+#define kCGMinimumWindowLevel           ((CGWindowLevel)(kCGBaseWindowLevel + kCGNumReservedBaseWindowLevels))
+#define kCGMaximumWindowLevel           ((CGWindowLevel)(INT32_MAX - kCGNumReservedWindowLevels))
+
+#define kCGDesktopWindowLevel           ((CGWindowLevel)(kCGMinimumWindowLevel + 20))
+#define kCGDesktopIconWindowLevel       ((CGWindowLevel)(kCGDesktopWindowLevel + 20))
+#define kCGBackstopMenuLevel            ((CGWindowLevel)-20)
+#define kCGNormalWindowLevel            ((CGWindowLevel)0)
+#define kCGFloatingWindowLevel          ((CGWindowLevel)3)
+#define kCGTornOffMenuWindowLevel       ((CGWindowLevel)3)
+#define kCGModalPanelWindowLevel        ((CGWindowLevel)8)
+#define kCGUtilityWindowLevel           ((CGWindowLevel)19)
+#define kCGDockWindowLevel              ((CGWindowLevel)20)
+#define kCGMainMenuWindowLevel          ((CGWindowLevel)24)
+#define kCGStatusWindowLevel            ((CGWindowLevel)25)
+#define kCGPopUpMenuWindowLevel         ((CGWindowLevel)101)
+#define kCGOverlayWindowLevel           ((CGWindowLevel)102)
+#define kCGHelpWindowLevel              ((CGWindowLevel)200)
+#define kCGDraggingWindowLevel          ((CGWindowLevel)500)
+#define kCGScreenSaverWindowLevel       ((CGWindowLevel)1000)
+#define kCGAssistiveTechHighWindowLevel ((CGWindowLevel)1500)
+#define kCGCursorWindowLevel            ((CGWindowLevel)(kCGMaximumWindowLevel - 1))
 
 #endif /* CGWINDOWLEVEL_H_ */
diff -ruN /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CoreGraphics.apinotes /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CoreGraphics.apinotes
--- /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.12.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CoreGraphics.apinotes	1969-12-31 19:00:00.000000000 -0500
+++ /Applications/Xcode9-beta1.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.13.sdk/System/Library/Frameworks/CoreGraphics.framework/Headers/CoreGraphics.apinotes	2017-05-25 04:48:03.000000000 -0400
@@ -0,0 +1,775 @@
+---
+Name: CoreGraphics
+SwiftInferImportAsMember: true
+
+#
+# Global functions
+#
+Functions:
+# The below are inline functions that are irrelevant due to memberwise inits
+- Name: CGPointMake
+  Availability: nonswift
+- Name: CGSizeMake
+  Availability: nonswift
+- Name: CGVectorMake
+  Availability: nonswift
+- Name: CGRectMake
+  Availability: nonswift
+- Name: CGAffineTransformMake
+  Availability: nonswift
+# The below are fixups that inference didnt quite do what we wanted, and are
+# pulled over from what used to be in the overlays
+- Name: CGRectIsNull
+  SwiftName: "getter:CGRect.isNull(self:)"
+- Name: CGRectIsEmpty
+  SwiftName: "getter:CGRect.isEmpty(self:)"
+- Name: CGRectIsInfinite
+  SwiftName: "getter:CGRect.isInfinite(self:)"
+- Name: CGRectStandardize
+  SwiftName: "getter:CGRect.standardized(self:)"
+- Name: CGRectIntegral
+  SwiftName: "getter:CGRect.integral(self:)"
+- Name: CGRectInset
+  SwiftName: "CGRect.insetBy(self:dx:dy:)"
+- Name: CGRectOffset
+  SwiftName: "CGRect.offsetBy(self:dx:dy:)"
+- Name: CGRectUnion
+  SwiftName: "CGRect.union(self:_:)"
+- Name: CGRectIntersection
+  SwiftName: "CGRect.intersection(self:_:)"
+- Name: CGRectContainsRect
+  SwiftName: "CGRect.contains(self:_:)"
+- Name: CGRectContainsPoint
+  SwiftName: "CGRect.contains(self:_:)"
+- Name: CGRectIntersectsRect
+  SwiftName: "CGRect.intersects(self:_:)"
+# The below are not available in Swift
+# FIXME: empty-argument-label pattern is currently failing SILGen
+- Name: CGColorSpaceCreateDeviceGray
+  SwiftName: CGColorSpaceCreateDeviceGray()
+- Name: CGColorSpaceCreateDeviceRGB
+  SwiftName: CGColorSpaceCreateDeviceRGB()
+- Name: CGColorSpaceCreateDeviceCMYK
+  SwiftName: CGColorSpaceCreateDeviceCMYK()
+# TODO: make these unavailable, but theyre needed for pre-iOS 9
+# - Name: CGColorSpaceCreateDeviceGray
+#   Availability: nonswift
+# - Name: CGColorSpaceCreateDeviceRGB
+#   Availability: nonswift
+# - Name: CGColorSpaceCreateDeviceCMYK
+#   Availability: nonswift
+- Name: CGColorConversionInfoCreateFromListWithArguments
+  Availability: nonswift
+
+# The below are attempts at providing better names than inference
+# CGAffineTransform
+- Name: CGAffineTransformMakeTranslation
+  SwiftName: CGAffineTransform.init(translationX:y:)
+- Name: CGAffineTransformMakeScale
+  SwiftName: CGAffineTransform.init(scaleX:y:)
+- Name: CGAffineTransformMakeRotation
+  SwiftName: CGAffineTransform.init(rotationAngle:)
+- Name: CGAffineTransformIsIdentity
+  SwiftName: getter:CGAffineTransform.isIdentity(self:)
+- Name: CGAffineTransformTranslate
+  SwiftName: CGAffineTransform.translatedBy(self:x:y:)
+- Name: CGAffineTransformScale
+  SwiftName: CGAffineTransform.scaledBy(self:x:y:)
+- Name: CGAffineTransformRotate
+  SwiftName: CGAffineTransform.rotated(self:by:)
+- Name: CGAffineTransformConcat
+  SwiftName: CGAffineTransform.concatenating(self:_:)
+- Name: CGAffineTransformInvert
+  SwiftName: CGAffineTransform.inverted(self:)
+- Name: CGPointApplyAffineTransform
+  SwiftName: CGPoint.applying(self:_:)
+- Name: CGSizeApplyAffineTransform
+  SwiftName: CGSize.applying(self:_:)
+- Name: CGRectApplyAffineTransform
+  SwiftName: CGRect.applying(self:_:)
+# These are hidden so we can improve them further in the SDK overlay
+- Name: CGAffineTransformEqualToTransform
+  # replaced by Equatable / ==
+  SwiftName: CGAffineTransform.__equalTo(self:_:)
+  SwiftPrivate: true
+
+# CGBitmapContext
+- Name: CGBitmapContextCreateWithData
+  SwiftName: CGContext.init(data:width:height:bitsPerComponent:bytesPerRow:space:bitmapInfo:releaseCallback:releaseInfo:)
+- Name: CGBitmapContextCreate
+  SwiftName: CGContext.init(data:width:height:bitsPerComponent:bytesPerRow:space:bitmapInfo:)
+- Name: CGBitmapContextGetData
+  SwiftName: getter:CGContext.data(self:)
+- Name: CGBitmapContextGetWidth
+  SwiftName: getter:CGContext.width(self:)
+- Name: CGBitmapContextGetHeight
+  SwiftName: getter:CGContext.height(self:)
+- Name: CGBitmapContextGetBitsPerComponent
+  SwiftName: getter:CGContext.bitsPerComponent(self:)
+- Name: CGBitmapContextGetBitsPerPixel
+  SwiftName: getter:CGContext.bitsPerPixel(self:)
+- Name: CGBitmapContextGetBytesPerRow
+  SwiftName: getter:CGContext.bytesPerRow(self:)
+- Name: CGBitmapContextGetColorSpace
+  SwiftName: getter:CGContext.colorSpace(self:)
+- Name: CGBitmapContextGetAlphaInfo
+  SwiftName: getter:CGContext.alphaInfo(self:)
+- Name: CGBitmapContextCreateImage
+  SwiftName: CGContext.makeImage(self:)
+
+# CGColor
+#
+- Name: CGColorCreate
+  SwiftName: CGColor.init(colorSpace:components:)
+- Name: CGColorCreateGenericGray
+  SwiftName: CGColor.init(gray:alpha:)
+- Name: CGColorCreateGenericRGB
+  SwiftName: CGColor.init(red:green:blue:alpha:)
+- Name: CGColorCreateCMYK
+  SwiftName: CGColor.init(cyan:magenta:yellow:black:alpha:)
+- Name: CGColorCreateWithPattern
+  SwiftName: CGColor.init(patternSpace:pattern:components:)
+- Name: CGColorCreateCopy
+  SwiftName: CGColor.copy(self:)
+- Name: CGColorCreateCopyWithAlpha
+  SwiftName: CGColor.copy(self:alpha:)
+- Name: CGColorCreateCopyByMatchingToColorSpace
+  SwiftName: CGColor.converted(to:intent:self:options:)
+# Replaced by actual constant colors in the overlay
+- Name: CGColorGetConstantColor
+  SwiftName: CGColor.__constantColor(for:)
+  SwiftPrivate: true
+# Replaced by == operator in the overlay
+- Name: CGColorEqualToColor
+  SwiftName: CGColor.__equalTo(self:_:)
+  SwiftPrivate: true
+# Replaced in the overlay: var components: [CGFloat]?
+- Name: CGColorGetComponents
+  SwiftName: getter:CGColor.__unsafeComponents(self:)
+  SwiftPrivate: true
+
+
+# CGColorSpace
+#
+# These are cases where we want better names than ImportAsMember inference gets
+- Name: CGColorSpaceCreateWithICCProfile
+  SwiftName: CGColorSpace.init(iccProfileData:)
+- Name: CGColorSpaceCreateWithPlatformColorSpace
+  SwiftName: CGColorSpace.init(platformColorSpaceRef:)
+- Name: CGColorSpaceCreateWithName
+  SwiftName: CGColorSpace.init(name:)
+- Name: CGColorSpaceCopyName
+  SwiftName: getter:CGColorSpace.name(self:)
+- Name: CGColorSpaceCopyICCProfile
+  SwiftName: getter:CGColorSpace.iccData(self:)
+- Name: CGColorSpaceIsWideGamutRGB
+  SwiftName: getter:CGColorSpace.isWideGamutRGB(self:)
+- Name: CGColorSpaceSupportsOutput
+  SwiftName: getter:CGColorSpace.supportsOutput(self:)
+# These are hidden so we can improve them further in the SDK overlay
+- Name: CGColorSpaceGetColorTableCount
+  # merged count and pointer to single array property
+  SwiftName: getter:CGColorSpace.__colorTableCount(self:)
+  SwiftPrivate: true
+- Name: CGColorSpaceGetColorTable
+  # merged count and pointer to single array property
+  SwiftName: CGColorSpace.__unsafeGetColorTable(self:_:)
+  SwiftPrivate: true
+
+# CGContext
+#
+# These are cases where we want better names than ImportAsMember inference gets
+- Name: CGConttextSaveGState
+  SwiftName: CGContext.saveGraphicsState(self:)
+- Name: CGConttextRestoreGState
+  SwiftName: CGContext.restoreGraphicsState(self:)
+- Name: CGContextConcatCTM
+  SwiftName: CGContext.concatenate(self:_:)
+- Name: CGContextScaleCTM
+  SwiftName: CGContext.scaleBy(self:x:y:)
+- Name: CGContextTranslateCTM
+  SwiftName: CGContext.translateBy(self:x:y:)
+- Name: CGContextRotateCTM
+  SwiftName: CGContext.rotate(self:by:)
+- Name: CGContextSetLineWidth
+  SwiftName: CGContext.setLineWidth(self:_:)
+- Name: CGContextSetMiterLimit
+  SwiftName: CGContext.setMiterLimit(self:_:)
+- Name: CGContextSetFlatness
+  SwiftName: CGContext.setFlatness(self:_:)
+- Name: CGContextSetAlpha
+  SwiftName: CGContext.setAlpha(self:_:)
+- Name: CGContextAddEllipseInRect
+  SwiftName: CGContext.addEllipse(self:in:)
+- Name: CGContextIsPathEmpty
+  SwiftName: getter:CGContext.isPathEmpty(self:)
+- Name: CGContextGetPathCurrentPoint
+  SwiftName: getter:CGContext.currentPointOfPath(self:)
+- Name: CGContextGetPathBoundingBox
+  SwiftName: getter:CGContext.boundingBoxOfPath(self:)
+- Name: CGContextCopyPath
+  SwiftName: getter:CGContext.path(self:)
+- Name: CGContextPathContainsPoint
+  SwiftName: CGContext.pathContains(self:_:mode:)
+- Name: CGContextDrawPath
+  SwiftName: CGContext.drawPath(self:using:)
+- Name: CGContextFillRect
+  SwiftName: CGContext.fill(self:_:)
+- Name: CGContextStrokeRect
+  SwiftName: CGContext.stroke(self:_:)
+- Name: CGContextStrokeRectWithWidth
+  SwiftName: CGContext.stroke(self:_:width:)
+- Name: CGContextClearRect
+  SwiftName: CGContext.clear(self:_:)
+- Name: CGContextFillEllipseInRect
+  SwiftName: CGContext.fillEllipse(self:in:)
+- Name: CGContextStrokeEllipseInRect
+  SwiftName: CGContext.strokeEllipse(self:in:)
+- Name: CGContextGetClipBoundingBox
+  SwiftName: getter:CGContext.boundingBoxOfClipPath(self:)
+- Name: CGContextClipToRect
+  SwiftName: CGContext.clip(self:to:)
+- Name: CGContextClipToMask
+  SwiftName: CGContext.clip(self:to:mask:)
+- Name: CGContextSetFillColor
+  SwiftName: CGContext.setFillColor(self:_:)
+- Name: CGContextSetFillColorWithColor
+  SwiftName: CGContext.setFillColor(self:_:)
+- Name: CGContextSetFillPattern
+  SwiftName: CGContext.setFillPattern(self:_:colorComponents:)
+- Name: CGContextSetStrokePattern
+  SwiftName: CGContext.setStrokePattern(self:_:colorComponents:)
+- Name: CGContextSetPatternPhase
+  SwiftName: CGContext.setPatternPhase(self:_:)
+- Name: CGContextSetGrayFillColor
+  SwiftName: CGContext.setFillColor(self:gray:alpha:)
+- Name: CGContextSetGrayStrokeColor
+  SwiftName: CGContext.setStrokeColor(self:gray:alpha:)
+- Name: CGContextSetRGBFillColor
+  SwiftName: CGContext.setFillColor(self:red:green:blue:alpha:)
+- Name: CGContextSetRGBStrokeColor
+  SwiftName: CGContext.setStrokeColor(self:red:green:blue:alpha:)
+- Name: CGContextSetStrokeColor
+  SwiftName: CGContext.setStrokeColor(self:_:)
+- Name: CGContextSetStrokeColorWithColor
+  SwiftName: CGContext.setStrokeColor(self:_:)
+- Name: CGContextSetCMYKFillColor
+  SwiftName: CGContext.setFillColor(self:cyan:magenta:yellow:black:alpha:)
+- Name: CGContextSetCMYKStrokeColor
+  SwiftName: CGContext.setStrokeColor(self:cyan:magenta:yellow:black:alpha:)
+- Name: CGContextSetShadowWithColor
+  SwiftName: CGContext.setShadow(self:offset:blur:color:)
+# - Name: CGContextSetShadow
+#   SwiftName: CGContext.setShadow(self:offset:blur:)
+- Name: CGContextSetCharacterSpacing
+  SwiftName: CGContext.setCharacterSpacing(self:_:)
+- Name: CGContextSetFontSize
+  SwiftName: CGContext.setFontSize(self:_:)
+# - Name: CGContextBeginPage
+#   SwiftName: CGContext.beginPage(self:mediaBox:)
+- Name: CGContextSetShouldAntialias
+  SwiftName: CGContext.setShouldAntialias(self:_:)
+- Name: CGContextSetAllowsAntialiasing
+  SwiftName: CGContext.setAllowsAntialiasing(self:_:)
+- Name: CGContextSetShouldSmoothFonts
+  SwiftName: CGContext.setShouldSmoothFonts(self:_:)
+- Name: CGContextSetAllowsFontSmoothing
+  SwiftName: CGContext.setAllowsFontSmoothing(self:_:)
+- Name: CGContextSetShouldSubpixelPositionFonts
+  SwiftName: CGContext.setShouldSubpixelPositionFonts(self:_:)
+- Name: CGContextSetAllowsFontSubpixelPositioning
+  SwiftName: CGContext.setAllowsFontSubpixelPositioning(self:_:)
+- Name: CGContextSetShouldSubpixelQuantizeFonts
+  SwiftName: CGContext.setShouldSubpixelQuantizeFonts(self:_:)
+- Name: CGContextSetAllowsFontSubpixelQuantization
+  SwiftName: CGContext.setAllowsFontSubpixelQuantization(self:_:)
+- Name: CGContextBeginTransparencyLayer
+  SwiftName: CGContext.beginTransparencyLayer(self:auxiliaryInfo:)
+- Name: CGContextBeginTransparencyLayerWithRect
+  SwiftName: CGContext.beginTransparencyLayer(self:in:auxiliaryInfo:)
+- Name: CGContextConvertPointToDeviceSpace
+  SwiftName: CGContext.convertToDeviceSpace(self:_:)
+- Name: CGContextConvertPointToUserSpace
+  SwiftName: CGContext.convertToUserSpace(self:_:)
+- Name: CGContextConvertSizeToDeviceSpace
+  SwiftName: CGContext.convertToDeviceSpace(self:_:)
+- Name: CGContextConvertSizeToUserSpace
+  SwiftName: CGContext.convertToUserSpace(self:_:)
+- Name: CGContextConvertRectToDeviceSpace
+  SwiftName: CGContext.convertToDeviceSpace(self:_:)
+- Name: CGContextConvertRectToUserSpace
+  SwiftName: CGContext.convertToUserSpace(self:_:)
+# These are hidden so we can improve them further in the SDK overlay
+- Name: CGContextSetLineDash
+  # replaced by setLineDash(phase:lengths:) --  array instead of pointer/count
+  SwiftName: CGContext.__setLineDash(self:phase:lengths:count:)
+  SwiftPrivate: true
+- Name: CGContextMoveToPoint
+  # replaced by move(to: CGPoint)
+  SwiftName: CGContext.__moveTo(self:x:y:)
+  SwiftPrivate: true
+- Name: CGContextAddLineToPoint
+  # replaced by addLine(to: CGPoint)
+  SwiftName: CGContext.__addLineTo(self:x:y:)
+  SwiftPrivate: true
+- Name: CGContextAddCurveToPoint
+  # replaced by addCurve(to:control1:control2:)
+  SwiftName: CGContext.__addCurveTo(self:cp1x:cp1y:cp2x:cp2y:endingAtX:y:)
+  SwiftPrivate: true
+- Name: CGContextAddQuadCurveToPoint
+  # replaced by addQuadCurve(to:control:)
+  SwiftName: CGContext.__addQuadCurveTo(self:cpx:cpy:endingAtX:y:)
+  SwiftPrivate: true
+- Name: CGContextAddRects
+  # replaced by addRects(_:) -- array instead of pointer/count
+  SwiftName: CGContext.__addRects(self:_:count:)
+  SwiftPrivate: true
+- Name: CGContextAddLines
+  # replaced by addLines(between:) -- array instead of pointer/count
+  SwiftName: CGContext.__addLines(self:between:count:)
+  SwiftPrivate: true
+- Name: CGContextAddArc
+  # replaced by addArc(center:radius:startAngle:endAngle:clockwise:) -- CW is Bool, not Int32
+  SwiftName: CGContext.__addArc(self:centerX:y:radius:startAngle:endAngle:clockwise:)
+  SwiftPrivate: true
+- Name: CGContextAddArcToPoint
+  # replaced by addArc(tangent1End:tangent2End:radius:)
+  SwiftName: CGContext.__addArc(self:x1:y1:x2:y2:radius:)
+  SwiftPrivate: true
+- Name: CGContextFillRects
+  # replaced by fill(_ rects: [CGRect]) -- array instead of pointer/count
+  SwiftName: CGContext.__fill(self:_:count:)
+  SwiftPrivate: true
+- Name: CGContextStrokeLineSegments
+  # replaced by strokeLineSegments(between points: [CGPoint]) -- array instead of pointer/count
+  SwiftName: CGContext.__strokeLineSegments(self:between:count:)
+  SwiftPrivate: true
+- Name: CGContextClipToRects
+  # replaced by clip(to rects: [CGRect]) -- array instead of pointer/count
+  SwiftName: CGContext.__clip(self:to:count:)
+  SwiftPrivate: true
+- Name: CGContextDrawImage
+  # replaced by draw(_ image: CGImage, in rect: CGRect, byTiling: Bool = false)
+  SwiftName: CGContext.__draw(self:in:image:)
+  SwiftPrivate: true
+- Name: CGContextDrawTiledImage
+  # replaced by draw(_ image: CGImage, in rect: CGRect, byTiling: Bool = false)
+  SwiftName: CGContext.__draw(self:in:byTiling:)
+  SwiftPrivate: true
+- Name: CGContextGetTextPosition
+  # replaced by readwrite property
+  SwiftName: getter:CGContext.__textPosition(self:)
+  SwiftPrivate: true
+- Name: CGContextSetTextPosition
+  # replaced by readwrite property
+  SwiftName: CGContext.__setTextPosition(self:x:y:)
+  SwiftPrivate: true
+- Name: CGContextShowGlyphsAtPositions
+  # replaced by showGlyphs(_:at:) -- array instead of pointer/count
+  SwiftName: CGContext.__showGlyphs(self:_:atPositions:count:)
+  SwiftPrivate: true
+- Name: CGContextFillPath
+  # replaced by combining winding and evenOdd rules to one func with an enum
+  SwiftName: CGContext.__fillPath(self:)
+  SwiftPrivate: true
+- Name: CGContextEOFillPath
+  # replaced by combining winding and evenOdd rules to one func with an enum
+  # has nothing to do with Enterprise Objects
+  SwiftName: CGContext.__eoFillPath(self:)
+  SwiftPrivate: true
+- Name: CGContextClip
+  # replaced by combining winding and evenOdd rules to one func with an enum
+  SwiftName: CGContext.__clip(self:)
+  SwiftPrivate: true
+- Name: CGContextEOClip
+  # replaced by combining winding and evenOdd rules to one func with an enum
+  SwiftName: CGContext.__eoClip(self:)
+  SwiftPrivate: true
+
+# CGDataConsumer
+# - Name: CGDataConsumerCreateWithURL
+#   SwiftName: CGDataConsumer.init(url:)
+# - Name: CGDataConsumerCreateWithCFData
+#   SwiftName: CGDataConsumer.init(data:)
+
+# CGDataProvider
+# - Name: CGDataProviderCreateWithData
+#   SwiftName: CGDataProvider.init(dataInfo:data:size:releaseData:)
+# - Name: CGDataProviderCreateWithCFData
+#   SwiftName: CGDataProvider.init(data:)
+# - Name: CGDataProviderCreateWithURL
+#   SwiftName: CGDataProvider.init(url:)
+- Name: CGDataProviderCopyData
+  SwiftName: getter:CGDataProvider.data(self:)
+
+# CGDirectDisplay
+- Name: CGDisplayModeCopyPixelEncoding
+  SwiftName: getter:CGDisplayMode.pixelEncoding(self:)
+- Name: CGDisplayCreateImageForRect
+  SwiftName: CGDisplayCreateImage(_:rect:)
+# These are hidden so we can improve them further in the SDK overlay
+- Name: CGGetLastMouseDelta
+  # replaced by a version that returns CGVector instead of using out-pointers
+  SwiftPrivate: true
+
+# CGEvent
+- Name: CGEventCreateFromData
+  SwiftName: CGEvent.init(withDataAllocator:data:)
+- Name: CGEventCreateData
+  SwiftName: getter:CGEvent.data(self:)
+- Name: CGEventCreateCopy
+  SwiftName: CGEvent.copy(self:)
+- Name: CGEventPostToPid
+  SwiftName: CGEvent.postToPid(_:self:)
+- Name: CGEventCreateSourceFromEvent
+  SwiftName: CGEventSource.init(event:)
+
+# CGFont
+- Name: CGFontCreateWithDataProvider
+  SwiftName: CGFont.init(_:)
+- Name: CGFontCreateWithFontName
+  SwiftName: CGFont.init(_:)
+- Name: CGFontCopyPostScriptName
+  SwiftName: getter:CGFont.postScriptName(self:)
+- Name: CGFontCopyFullName
+  SwiftName: getter:CGFont.fullName(self:)
+- Name: CGFontCopyVariationAxes
+  SwiftName: getter:CGFont.variationAxes(self:)
+- Name: CGFontCopyVariations
+  SwiftName: getter:CGFont.variations(self:)
+- Name: CGFontCopyGlyphNameForGlyph
+  SwiftName: CGFont.name(self:for:)
+- Name: CGFontCopyTableTags
+  SwiftName: getter:CGFont.tableTags(self:)
+- Name: CGFontCopyTableForTag
+  SwiftName: CGFont.table(self:for:)
+- Name: CGFontCreateCopyWithVariations
+  SwiftName: CGFont.copy(self:withVariations:)
+
+# CGGeometry
+- Name: CGPointCreateDictionaryRepresentation
+  SwiftName: getter:CGPoint.dictionaryRepresentation(self:)
+- Name: CGSizeCreateDictionaryRepresentation
+  SwiftName: getter:CGSize.dictionaryRepresentation(self:)
+- Name: CGRectCreateDictionaryRepresentation
+  SwiftName: getter:CGRect.dictionaryRepresentation(self:)
+- Name: CGPointEqualToPoint
+  SwiftName: CGPoint.equalTo(self:_:)
+- Name: CGSizeEqualToSize
+  SwiftName: CGSize.equalTo(self:_:)
+- Name: CGRectEqualToRect
+  SwiftName: CGRect.equalTo(self:_:)
+# These are hidden so we can improve them further in the SDK overlay
+- Name: CGRectDivide
+  # hide the pointer version in favor of the tuple-return version
+  SwiftName: CGRect.__divided(self:slice:remainder:atDistance:from:)
+  SwiftPrivate: true
+- Name: CGPointMakeWithDictionaryRepresentation
+  # hide in favor of an init (cant map to initializer because out-pointer)
+  SwiftName: CGPoint.__setFromDictionaryRepresentation(_:_:)
+  SwiftPrivate: true
+- Name: CGSizeMakeWithDictionaryRepresentation
+  # hide in favor of an init (cant map to initializer because out-pointer)
+  SwiftName: CGSize.__setFromDictionaryRepresentation(_:_:)
+  SwiftPrivate: true
+- Name: CGRectMakeWithDictionaryRepresentation
+  # hide in favor of an init (cant map to initializer because out-pointer)
+  SwiftName: CGRect.__setFromDictionaryRepresentation(_:_:)
+  SwiftPrivate: true
+
+# CGGradient
+- Name: CGGradientCreateWithColorComponents
+  SwiftName: CGGradient.init(colorSpace:colorComponents:locations:count:)
+- Name: CGGradientCreateWithColorSpace
+  SwiftName: CGGradient.init(colorSpace:colors:locations:)
+
+# CGImage
+- Name: CGImageCreateCopy
+  SwiftName: CGImage.copy(self:)
+- Name: CGImageCreateCopyWithColorSpace
+  SwiftName: CGImage.copy(self:colorSpace:)
+- Name: CGImageCreateWithImageInRect
+  SwiftName: CGImage.cropping(self:to:)
+- Name: CGImageCreateWithMask
+  SwiftName: CGImage.masking(self:_:)
+- Name: CGImageIsMask
+  SwiftName: getter:CGImage.isMask(self:)
+# These are hidden so we can improve them further in the SDK overlay
+- Name: CGImageCreateWithMaskingColors
+  # replaced by a version that takes an array instead of UnsafePointer
+  SwiftName: CGImage.__copy(self:maskingColorComponents:)
+  SwiftPrivate: true
+
+# CGLayer
+- Name: CGLayerCreateWithContext
+  SwiftName: CGLayer.init(_:size:auxiliaryInfo:)
+# These are hidden so we can improve them further in the SDK overlay
+- Name: CGContextDrawLayerInRect
+  # API notes cant rearrange args, want layer first to match draw(image:) etc
+  SwiftName: CGContext.__draw(self:in:layer:)
+  SwiftPrivate: true
+- Name: CGContextDrawLayerAtPoint
+  # API notes cant rearrange args, want layer first to match draw(image:) etc
+  SwiftName: CGContext.__draw(self:at:layer:)
+  SwiftPrivate: true
+
+# CGPDFContext
+- Name: CGPDFContextCreate
+  SwiftName: CGContext.init(consumer:mediaBox:_:)
+- Name: CGPDFContextCreateWithURL
+  SwiftName: CGContext.init(_:mediaBox:_:)
+- Name: CGPDFContextClose
+  SwiftName: CGContext.closePDF(self:)
+- Name: CGPDFContextBeginPage
+  SwiftName: CGContext.beginPDFPage(self:_:)
+- Name: CGPDFContextEndPage
+  SwiftName: CGContext.endPDFPage(self:)
+- Name: CGPDFContextAddDocumentMetadata
+  SwiftName: CGContext.addDocumentMetadata(self:_:)
+- Name: CGPDFContextSetURLForRect
+  SwiftName: CGContext.setURL(self:_:for:)
+- Name: CGPDFContextAddDestinationAtPoint
+  SwiftName: CGContext.addDestination(self:_:at:)
+- Name: CGPDFContextSetDestinationForRect
+  SwiftName: CGContext.setDestination(self:_:for:)
+
+# CGPDFDocument
+- Name: CGPDFDocumentGetID
+  SwiftName: getter:CGPDFDocument.fileIdentifier(self:)
+- Name: CGPDFDocumentIsEncrypted
+  SwiftName: getter:CGPDFDocument.isEncrypted(self:)
+- Name: CGPDFDocumentIsUnlocked
+  SwiftName: getter:CGPDFDocument.isUnlocked(self:)
+- Name: CGPDFDocumentAllowsPrinting
+  SwiftName: getter:CGPDFDocument.allowsPrinting(self:)
+- Name: CGPDFDocumentAllowsCopying
+  SwiftName: getter:CGPDFDocument.allowsCopying(self:)
+- Name: CGPDFDocumentCreateWithProvider
+  SwiftName: CGPDFDocument.init(_:)
+- Name: CGPDFDocumentCreateWithURL
+  SwiftName: CGPDFDocument.init(_:)
+- Name: CGPDFDocumentUnlockWithPassword
+  SwiftName: CGPDFDocument.unlockWithPassword(self:_:)
+- Name: CGPDFDocumentGetPage
+  SwiftName: CGPDFDocument.page(self:at:)
+# CGPDFPage
+# FIXME: cannot be getter, due to extra parameter
+# - Name: CGPDFPageGetBoxRect
+#   SwiftName: getter:CGPDFPage.boxRect(self:)
+# CGPSConverter
+- Name: CGPSConverterIsConverting
+  SwiftName: getter:CGPSConverter.isConverting(self:)
+
+# CGPath
+- Name: CGPathCreateCopy
+  SwiftName: CGPath.copy(self:)
+- Name: CGPathCreateCopyByTransformingPath
+  SwiftName: CGPath.copy(self:using:)
+- Name: CGPathCreateMutableCopy
+  SwiftName: CGPath.mutableCopy(self:)
+- Name: CGPathCreateMutableCopyByTransformingPath
+  SwiftName: CGPath.mutableCopy(self:using:)
+- Name: CGPathGetPathBoundingBox
+  SwiftName: getter:CGPath.boundingBoxOfPath(self:)
+- Name: CGPathIsEmpty
+  SwiftName: getter:CGPath.isEmpty(self:)
+# These are hidden so we can improve them further in the SDK overlay
+- Name: CGPathCreateCopyByDashingPath
+  # replaced by copy(...) method, move transform to end, pointer/count => array
+  SwiftName: CGPath.init(__byDashing:transform:phase:lengths:count:)
+  SwiftPrivate: true
+- Name: CGPathCreateCopyByStrokingPath
+  # replaced by copy(...) method, move transform to end
+  SwiftName: CGPath.init(__byStroking:transform:lineWidth:lineCap:lineJoin:miterLimit:)
+  SwiftPrivate: true
+- Name: CGPathContainsPoint
+  # replaced to move transform to end
+  # TODO: replace eoFill with a FillRule enum for clarity
+  SwiftName: CGPath.__containsPoint(self:transform:point:eoFill:)
+  SwiftPrivate: true
+- Name: CGPathEqualToPath
+  # replaced in favor of == / Equatable
+  SwiftName: CGPath.__equalTo(self:_:)
+  SwiftPrivate: true
+- Name: CGPathAddRoundedRect
+  SwiftName: CGMutablePath.__addRoundedRect(self:transform:rect:cornerWidth:cornerHeight:)
+- Name: CGPathMoveToPoint
+  # replaced to use CGPoint, move transform to end
+  SwiftName: CGMutablePath.__moveTo(self:transform:x:y:)
+  SwiftPrivate: true
+- Name: CGPathAddLineToPoint
+  # replaced to use CGPoint, move transform to end
+  SwiftName: CGMutablePath.__addLineTo(self:transform:x:y:)
+  SwiftPrivate: true
+- Name: CGPathAddCurveToPoint
+  # replaced to use CGPoint, move transform to end
+  SwiftName: CGMutablePath.__addCurve(self:transform:cp1x:cp1y:cp2x:cp2y:endingAtX:y:)
+  SwiftPrivate: true
+- Name: CGPathAddQuadCurveToPoint
+  # replaced to use CGPoint, move transform to end
+  SwiftName: CGMutablePath.__addQuadCurve(self:transform:cpx:cpy:endingAtX:y:)
+  SwiftPrivate: true
+- Name: CGPathAddRect
+  # replaced to move transform to end
+  SwiftName: CGMutablePath.__addRect(self:transform:rect:)
+  SwiftPrivate: true
+- Name: CGPathAddRects
+  # replaced to move transform to end, use array not pointer/count
+  SwiftName: CGMutablePath.__addRects(self:transform:rects:count:)
+  SwiftPrivate: true
+- Name: CGPathAddLines
+  # replaced to use CGPoint, move transform to end, use array not pointer/count
+  SwiftName: CGMutablePath.__addLines(self:transform:between:count:)
+  SwiftPrivate: true
+- Name: CGPathAddEllipseInRect
+  # replaced to use CGPoint, move transform to end
+  SwiftName: CGMutablePath.__addEllipse(self:transform:rect:)
+  SwiftPrivate: true
+- Name: CGPathAddRelativeArc
+  # replaced to use CGPoint, move transform to end
+  SwiftName: CGMutablePath.__addRelativeArc(self:transform:x:y:radius:startAngle:delta:)
+  SwiftPrivate: true
+- Name: CGPathAddArc
+  # replaced to use CGPoint, move transform to end
+  SwiftName: CGMutablePath.__addArc(self:transform:x:y:radius:startAngle:endAngle:clockwise:)
+  SwiftPrivate: true
+- Name: CGPathAddArcToPoint
+  # replaced to use CGPoint, move transform to end
+  SwiftName: CGMutablePath.__addArc(self:transform:x1:y1:x2:y2:radius:)
+  SwiftPrivate: true
+- Name: CGPathAddPath
+  # replaced to move transform to end
+  SwiftName: CGMutablePath.__addPath(self:transform:path:)
+  SwiftPrivate: true
+
+#
+# Global variables
+#
+Globals:
+# The below are globals that are defined as opaque C constants for no good
+# reason.
+- Name: CGPointZero
+  Availability: nonswift
+- Name: CGSizeZero
+  Availability: nonswift
+- Name: CGVectorZero
+  Availability: nonswift
+- Name: CGRectZero
+  Availability: nonswift
+- Name: CGAffineTransformIdentity
+  Availability: nonswift
+# The below are not available in Swift
+- Name: kCGColorSpaceGenericGray
+  Availability: nonswift
+- Name: kCGColorSpaceGenericRGB
+  Availability: nonswift
+- Name: kCGColorSpaceSRGB
+  SwiftName: CGColorSpace.sRGB
+# These are actual constant colors, not color names, in the overlay
+- Name: kCGColorWhite
+  SwiftName: CGColor.__whiteColorName
+  SwiftPrivate: true
+- Name: kCGColorBlack
+  SwiftName: CGColor.__blackColorName
+  SwiftPrivate: true
+- Name: kCGColorClear
+  SwiftName: CGColor.__clearColorName
+  SwiftPrivate: true
+
+#
+# Enums
+#
+Enumerators:
+# The below are attempts at providing better names than inference
+# CGColorSpace
+- Name: kCGRenderingIntentDefault
+  SwiftName: CGColorRenderingIntent.defaultIntent
+- Name: kCGRenderingIntentAbsoluteColorimetric
+  SwiftName: CGColorRenderingIntent.absoluteColorimetric
+- Name: kCGRenderingIntentRelativeColorimetric
+  SwiftName: CGColorRenderingIntent.relativeColorimetric
+- Name: kCGRenderingIntentPerceptual
+  SwiftName: CGColorRenderingIntent.perceptual
+- Name: kCGRenderingIntentSaturation
+  SwiftName: CGColorRenderingIntent.saturation
+- Name: kCGMomentumScrollPhaseContinue
+  SwiftName: CGMomentumScrollPhase.continuous
+- Name: kCGColorSpaceModelRGB
+  SwiftName: CGColorSpaceModel.rgb
+- Name: kCGColorSpaceModelCMYK
+  SwiftName: CGColorSpaceModel.cmyk
+
+# CGContext
+- Name: kCGBlendModeXOR
+  SwiftName: CGBlendMode.xor
+# CGEventTypes
+- Name: kCGEventMouseSubtypeDefault
+  SwiftName: CGEventMouseSubtype.defaultType
+- Name: kCGEventTapOptionDefault
+  SwiftName: CGEventTapOptions.defaultTap
+- Name: kCGEventSourceStatePrivate
+  SwiftName: CGEventSourceStateID.privateState
+# CGImage
+- Name: kCGImageAlphaOnly
+  SwiftName: alphaOnly
+# CGWindowLevel
+- Name: kCGBaseWindowLevelKey
+  SwiftName: CGWindowLevelKey.baseWindow
+- Name: kCGMinimumWindowLevelKey
+  SwiftName: CGWindowLevelKey.minimumWindow
+- Name: kCGDesktopWindowLevelKey
+  SwiftName: CGWindowLevelKey.desktopWindow
+- Name: kCGDesktopIconWindowLevelKey
+  SwiftName: CGWindowLevelKey.desktopIconWindow
+- Name: kCGBackstopMenuLevelKey
+  SwiftName: CGWindowLevelKey.backstopMenu
+- Name: kCGNormalWindowLevelKey
+  SwiftName: CGWindowLevelKey.normalWindow
+- Name: kCGFloatingWindowLevelKey
+  SwiftName: CGWindowLevelKey.floatingWindow
+- Name: kCGTornOffMenuWindowLevelKey
+  SwiftName: CGWindowLevelKey.tornOffMenuWindow
+- Name: kCGDockWindowLevelKey
+  SwiftName: CGWindowLevelKey.dockWindow
+- Name: kCGMainMenuWindowLevelKey
+  SwiftName: CGWindowLevelKey.mainMenuWindow
+- Name: kCGStatusWindowLevelKey
+  SwiftName: CGWindowLevelKey.statusWindow
+- Name: kCGModalPanelWindowLevelKey
+  SwiftName: CGWindowLevelKey.modalPanelWindow
+- Name: kCGPopUpMenuWindowLevelKey
+  SwiftName: CGWindowLevelKey.popUpMenuWindow
+- Name: kCGDraggingWindowLevelKey
+  SwiftName: CGWindowLevelKey.draggingWindow
+- Name: kCGScreenSaverWindowLevelKey
+  SwiftName: CGWindowLevelKey.screenSaverWindow
+- Name: kCGMaximumWindowLevelKey
+  SwiftName: CGWindowLevelKey.maximumWindow
+- Name: kCGOverlayWindowLevelKey
+  SwiftName: CGWindowLevelKey.overlayWindow
+- Name: kCGHelpWindowLevelKey
+  SwiftName: CGWindowLevelKey.helpWindow
+- Name: kCGUtilityWindowLevelKey
+  SwiftName: CGWindowLevelKey.utilityWindow
+- Name: kCGCursorWindowLevelKey
+  SwiftName: CGWindowLevelKey.cursorWindow
+- Name: kCGAssistiveTechHighWindowLevelKey
+  SwiftName: CGWindowLevelKey.assistiveTechHighWindow
+# CGConfigureOption
+- Name: kCGConfigureForAppOnly
+  SwiftName: forAppOnly
+# CGScreenUpdateOperation
+- Name: kCGScreenUpdateOperationRefresh
+  SwiftName: refresh
+# CGWindowListOption
+- Name: kCGWindowListOptionAll
+  SwiftName: optionAll
+
+
+#
+# Tags
+#
+Tags:
+# The below are not available in Swift
+- Name: CGGlypDeprecatedEnum
+  Availability: nonswift
Clone this wiki locally