【发布时间】:2017-10-19 06:29:18
【问题描述】:
背景
我们一直在开发公共动态 iOS / macOS 框架。该框架是用 Objective-C 编写的,但它与 Swift 完全兼容。
最近,我们为我们的一种公共 API 方法更改了可空性注释:
来自
- (void)setServer:(nullable ABCLocation *)location;
到
- (void)setServer:(nonnull ABCLocation *)location;
,因此开发人员需要创建 [ABCLocation default] 实例并将其传递给新的 API。
问题
现在,我们关心的是,如何强制/通知开发人员围绕我们的新 API 更改他们现有的代码?
将 API 与 Swift 一起使用时,它似乎可以通过抛出错误很好地处理可空性。
但是,Objective-C 只有在传递 nil 时才会生成警告,而当开发人员将 nullable 属性传递给方法时,Xcode 什么也不做。
我们如何强制开发人员更改他们的 API?这里的常见做法是什么?
UPD:
我们将框架作为二进制文件分发,使用 Release 配置构建,其中关闭了断言。
UPD #2:
到目前为止,我们已经接受了从 Objective-C 使用 API 的现实。但是,我们实现了“故障安全”行为:如果传递了nil,则该方法在内部创建[ABCLocation default] 实例并隐式传递它。
【问题讨论】:
-
"当开发人员将一个可为空的属性传递给方法时,Xcode 什么也不做。"还有其他问题,如果情况确实如此,您应该收到警告。
标签: ios objective-c ios-frameworks