xcode – 如何在同一源文件中有条件地编译特定于版本的Swift(1.2 vs 2.0)代码?

我有一个与我的框架捆绑在一起的 Swift演示项目.我想确保演示中的Swift代码与Xcode 6(Swift 1.2)和Xcode 7(Swift 2.0)成功编译,无需用户干预.

由于存在only marginal preprocessor support in Swift,如何在编译时确定使用哪个版本的Swift或Xcode来编译代码

现在,这是重要的细节:

>它必须自动工作!

>在Xcode 6中打开项目 – >编译
Swift 1.2代码.
>在Xcode 7中打开项目 – >编译Swift
2.0代码.

没有构建设置或其他需要用户以某种方式指定她正在使用的Swift / Xcode版本的方法.

我一直在想:这是一项微不足道的任务,用Swift怎么可能不可能?

作为一个框架开发人员,这让我感到疯狂,因为Swift项目的成功编译现在完全取决于用户的Xcode版本,我不能要求他们全部“更新到Xcode 6.4”,稍后不得不问他们一遍又一遍地“更新到Xcode 7.1”.疯了吧!

另一种选择当然是拥有单独的演示项目,管理不同的代码库,每个版本的Swift都有一个.并希望用户知道哪个项目适用于她的Xcode版本.不是一个真正的选择.

遗憾的是,另一种替代方案,即根本不使用任何Swift 2.0的增强功能.有一些语法,类和方法一个或另一个Swift版本中不起作用,只是因为编译器在较新的Xcode版本中更加挑剔.

解决方法

您可以使用Xcode的一些高级构建设置来完成此任务,特别是:

> XCODE_VERSION_MAJOR:将Xcode主要版本编码为“0700”之类的字符串.
> EXCLUDED_SOURCE_FILE_NAMES:认情况下要排除的“fnmatch”样式的源文件模式.
> INCLUDED_SOURCE_FILE_NAMES:要包含的“fnmatch”式源文件模式.

我通常不建议这样做,因为它会让你的项目很难理解大多数Xcode用户,但如果你绝对想让它工作,你可以使用这种技术.

你完成它的方式如下:

>对于需要进行版本控制的任何源文件,请将它们命名为“Thing-Versioned-0600.swift”和“Thing-Versioned-0700.swift”.确保两个文件都在源构建阶段.>通过添加项目级构建设置,使用排除机制来防止认情况下编译任何版本化文件:EXCLUDED_SOURCE_FILE_NAMES = * -Versioned – * .swift.>使用包含的机制仅添加回与当前Xcode主要版本匹配的文件,方法添加一个项目级构建设置:INCLUDED_SOURCE_FILE_NAMES = * -Versioned – $(XCODE_VERSION_MAJOR).swift.

相关文章

在有效期内的苹果开发者账号(类型为个人或者公司账号)。还...
Appuploader官网--IOS ipa上传发布工具,证书制作工具跨平台...
苹果在9月13号凌晨(北京时间)发布 iOS 16,该系统的设备可...
计算机图形学--OpenGL递归实现光线追踪
Xcode 14打出来的包在低版本系统运行时会崩溃,报错信息是Li...