本文主要对xcode中常见的工程配置进行介绍,仅用于记录分享,不做其他用途。
picture1
在编译的时候需要附加的SDK。
支持的处理器架构。支持的指令集越多,就会编译出包含多个指令集代码的数据包,对应生成二进制包就越大,最终目标文件也会变大。
指令集可以参考:http://www.jianshu.com/p/3fce0bd6f045
App所能支持的最大iOS版本。Xcode默认会设置为能够支持的最新版本。
如果此项为YES,则Xcode会根据当前所连接设备的版本只将相应的Architecture编译入app。否则会同时编译“Valid Architectures”中的指令集。
建议在Debug模式下设置为YES,Release模式下设置为NO,加快编译速度。
app支持的平台。目前可选的有iOS、macOS、tvOS、watchOS。
限制可能被支持的指令集的范围,也就是Xcode编译出来的二进制包类型最终从这些类型产生,而编译出哪种指令集的包,将由Architectures与Valid Architectures(因此这个不能为空)的交集来确定。
lipo源于mac系统要制作兼容powerpc平台和intel平台的程序。
lipo 是一个在 Mac OS X 中处理通用程序(Universal Binaries)的工具。
picture2
lipo –create Release-iphoneos/libiphone.a Debig-iphonesimulator/libiphone.a –output libiphone.a
lipo SDK.a -thin armv7 -output */SDK.a
picture3
资源包清单的下载路径URL前缀
是否将资源包嵌入产品的bundle中
是否开启按需获取资源功能
按需加载资源时的初始安装资源文件标签
按需加载资源时预加载的标签顺序
picture4
picture5
buildLocations-01
产品文件和编译中间文件的根目录。产品文件和编译时临时文件都将放在这个目录的子目录中。
编译时临时文件的存放位置。编译中间文件格式为product name+.build,如MyProduct.build。
当前编译设置下的产品存放位置。
当前编译设置下编译时临时文件的存放位置。
预编译头文件缓存存放路径。通过这个配置,Targets可以互相共享预编译的头文件。
这个在Xcode中的设置在File->Project Setting界面进行设置,
BuildLocation-02
BuildLocatios-03
Build Option-01
始终嵌入swift标准库。对于未使用swift代码的情况可以设置为NO。
此项可以设定生成产品的变种。您可以创建额外的产品变种作为特殊用途。例如,您可以使用编译配置文件的名称来创建一个高度定制的二进制文件。
Build Variants的值有三个:
normal-用于生成普通的二进制文件;
profile-用于可以生成配置信息的二进制文件;
debug-用于生成带有debug标志、额外断言和诊断代码的二进制文件。
选择使用的编译器。目前Xcode8.2默认使用APPLE LLVM 8.0版本的编译器。
记录debug信息的文件格式。共有DWARF with dSYM File和DWARF两种可以选择。建议选择DWARF with dSYM File。DWARF是较老的文件格式,会在编译时将debug信息写在执行文件中。
Bitcode is an intermediate representation of a compiled program. Apps you upload to iTunes Connect that contain bitcode will be compiled and linked on the App Store. Including bitcode will allow Apple to re-optimize your app binary in the future without the need to submit a new version of your app to the store.
Bitcode. When you archive for submission to the App Store, Xcode will compile your app into an intermediate representation. The App Store will then compile the bitcode down into the 64 or 32 bit executables as necessary.
说的是bitcode是被编译程序的一种中间形式的代码。包含bitcode配置的程序将会在App store上被编译和链接。bitcode允许苹果在后期重新优化我们程序的二进制文件,而不需要我们重新提交一个新的版本到App store上。
当我们提交程序到App store上时,Xcode会将程序编译为一个中间表现形式(bitcode)。然后App store会再将这个botcode编译为可执行的64位或32位程序。
不过,我们现在需要考虑的是三个平台:iOS,Mac OS,watchOS。
对应iOS,bitcode是可选的。
对于watchOS,bitcode是必须的。
Mac OS不支持bitcode。
是否支持测试。默认选NO;
是否生成配置代码。默认选择NO。
预编译build路径中的头文件。由于编译过程比较耗时,且两次编译之间未必会改动所有文件。因此将不会改动的常用文件保留成预编译文件将大大减少编译时的时间。建议这一项选择YES。
如果我们要想应用扩展使用内嵌框架,那么首先要配置一下。将target的Require Only App-Extension-Safe API选项设置为Yes。如果你不这样设置,那么Xcode会向你提示警告:linking against dylib not safe for use in application extensions。
扫描include文件所包含的所有源文件。
这个选项决定了是否在编译的时候进行验证。验证的内容和app store的审查内容一致。默认选项是debug时不验证,release时验证。
search path-01
是否搜索用户指定的路径,默认是NO;
工程引用的framework搜索路径
工程中引用的头文件搜索路径
library搜索路径,比如静态.a库
This is a list of paths to search for files included by CarbonResource Manager resources and compiled with the Rez tool.
指定哪些类型的子目录在递归查找时忽略
指定哪些类型的子目录在递归查找时包含
设置头文件搜索路径,这个只有当Always Search User Path开启后才有效。
sign-01
授权机制。在Xcode的capabilities选项卡下选择一些选项后,Xcode就会生成这样一段XML,Xcode会自动生成一个entitlements文件,然后再需要的时候往里面添加条目。当构建整个应用时,这个文件也会提及给codesign作为应用所需要拥有哪些授权的参考。这些授权信息必须都在开发者中心的AppID中启用,并且包含在配置文件中。
配置证书
开发者所在的群组
常见的配置为--deep。用法不详。
配置描述文件。
user-define
这里用户可以在debug、release或者自己定义的编译模式下设置不同的变量,可以达到一套代码同时支持多个不同版本的目的。比如可以编译出叫APP1和APP2两个名字不一样的APP。
Packaging-01
是否定义模块。默认app类的工程为NO,framwork工程默认为YES。
告诉编译器是否处理info.plist。默认是YES。这是一个很大的特点,因为它避免了有根据您的构建设置和配置不同的Info.plist中,避免您在多个地方修改设置。 但是如果你真的不想要它,只需在项目或目标的构建设置中关闭此设置。
创建工程后默认会创建一个info.plist文件。也可以根据需要进行主动创建。
私有头文件的存放位置。
产品bundle的标识
产品模块名称
产品名称
公共头文件路径
打包的扩展名,默认app。
preprocessing