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

有一些文章介紹.xconfig文件的使用,如這篇,但是經過親自實踐,發現還是有一些坑,這里記錄下。

構建新的configuration

這一步在“project-info-configuration”位置進行,點擊“+”構建“-”消除,沒什么問題,這個很簡單也不會出錯。


新建configuration

只是原來使用xcodebuild進行自動打包時的-configuration指的是就是這里啊。每個項目默認就有的Debug和Release配置。

這個Configuration是對于同一個項目的配置的一個完整的最高的總結了。

使用.xcconfig文件

新建這個文件很簡單,xcode自帶了這個模板。然后是在Configuration里配置,比如在debug時使用First.xcconfigrelease時使用Second.xcconfig,如圖:

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

這一步也簡單。但是我開始使用的時候,思維就走錯方向了:

根據各種文章的指示,配置文件(.xcconfig)里面的內容會覆蓋當前的Build Settings里面的東西,所以我以為是我在配置文件里面寫了一個配置,那么Build Settings里面的東西會跟著變。

比如我現在是Debug環境,然后對應的就是First.xcconfig,我在它里面寫入:

//:configuration = Debug
OTHER_LDFLAGS = -Objcxxx

//:configuration = Release
OTHER_LDFLAGS = -Objcxxx

//:completeSettings = some
OTHER_LDFLAGS

其實就是Other Linker flags的配置,可是外面Build Settings里的東西并沒有變。

Build Settings實際樣子

我就暈了,這到底怎么回事。

這里有兩個坑

  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)來引用其他配置里的東西,那么也就可以在這里定義宏并且跟隨其他配置而改變。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容