iOS使用 xcconfig配置文件的若干坑

有一些文章介绍.xconfig文件的使用,如这篇,可是通过亲自实践,发现仍是有一些坑,这里记录下。html

构建新的configuration

这一步在“project-info-configuration”位置进行,点击“+”构建“-”消除,没什么问题,这个很简单也不会出错。 ios

新建configuration

只是原来使用xcodebuild进行自动打包时的-configuration指的是就是这里啊。每一个项目默认就有的Debug和Release配置。git

这个Configuration是对于同一个项目的配置的一个完整的最高的总结了。github

使用.xcconfig文件

新建这个文件很简单,xcode自带了这个模板。而后是在Configuration里配置,好比在debug时使用First.xcconfigrelease时使用Second.xcconfig,如图:xcode

屏幕快照 2017-05-13 下午9.22.08.png

这一步也简单。可是我开始使用的时候,思惟就走错方向了:bash

根据各类文章的指示,配置文件(.xcconfig)里面的内容会覆盖当前的Build Settings里面的东西,因此我觉得是我在配置文件里面写了一个配置,那么Build Settings里面的东西会跟着变。app

好比我如今是Debug环境,而后对应的就是First.xcconfig,我在它里面写入:ui

//:configuration = Debug
OTHER_LDFLAGS = -Objcxxx

//:configuration = Release
OTHER_LDFLAGS = -Objcxxx

//:completeSettings = some
OTHER_LDFLAGS
复制代码

其实就是Other Linker flags的配置,但是外面Build Settings里的东西并无变。 spa

Build Settings实际样子

我就晕了,这到底怎么回事。debug

这里有两个坑

  1. 项目的Build Settings里直接写的内容是会优先显示的,就是说Xcode有一个默认的配置文件(yourAppName.xcodeproj/project.pbxproj),若是你直接在Build Settings里编辑,是写到它里面去,好比只是修改了other linker flag,再看github的修改:

修改了配置文件

这个文件里的配置会优先在Configuration里指定的.xcconfig文件里的配置,那要怎么使用.xcconfig文件里的配置?删掉Build Settings里的配置就行了。Command+delete搞定。

  1. 由于.xcconfig配置文件很难写,主要是各类配置名你记不住,因此就到实际的Build Settings里面去拷贝,就在对应的配置项Command+C就有了,因此内容就变成了上面那样,我觉得3句话是在不一样环境下起做用的,是互不干扰的,实际上是OTHER_LDFLAGS设了3遍,左后一次生效,最后是啥?空的啊,因此即便删除了Build Settings里的内容也不出现,我还觉得.xcconfig文件没起做用!

    因此改为:OTHER_LDFLAGS = -Objcxxx而后就有了。

    配置文件生效了

环境切换配置也跟着切换?

首先使用配置文件的做用就是,在环境切换后,配置能够跟着一整套的切换,.xcconfig就至关于一个把相关的配置打包了。

这里就有了另外一个坑,或者说理解失误:

我觉得是你在Build Configuration里选择什么,那么Build Settings里的内容会跟着改变。

Build Configuration修改

实际上Build Settings仍是原来那样,改变的是每一项里面的内容,好比First.xcconfig配置里写入OTHER_LDFLAGS = -Objc_first,而Second.xcconfig里写入OTHER_LDFLAGS = -Objc_second,在外面看到的是这样的:

build settings不变

每一项配置里面会再分红Debug、Release等不一样的Configuration,而不是Build Settings总体切换了。

或者说这是一个结构上的问题,让新接触者会改不清楚Xcode究竟是什么作到不一样状况使用不一样配置的。

整个配置的结构

实际结构是这样:

  • 最上层就是Project-info-Configuration里的配置了
  • 而后每一个配置里能够有不一样配置文件(.xcconfig),每一个target一个配置文件
  • 而后是每一个配置文件里面有许多的配置项

可是在Build Settings的显示里,这个结构是倒过来的:

  • 配置文件
  • 配置项
  • 不一样Configuration

另外,关于宏

在整个Build Settings里,能够在代码里直接使用的,Preprocess Mcros就是其中之一。

在这里定义不一样的宏,就能够在代码里由此作不一样处理,好比默认的DEBUG宏就常常用来作条件编译。

Build Settings里能够$(xxx)来引用其余配置里的东西,那么也就能够在这里定义宏而且跟随其余配置而改变。

相关文章
相关标签/搜索