使用Bazel創(chuàng)建iOS應(yīng)用

Bazel簡介

Bazel是一個Google開源的構(gòu)建和測試工具,Bazel支持多種語言的項目,并為多個平臺構(gòu)建輸出。Bazel的主要特點如下:

  • 高級語言構(gòu)建。Bazel使用一種抽象的、人類可讀的語言在高語義級別上描述項目的構(gòu)建屬性。與其他工具不同的是,Bazel使用的是庫、二進制文件、腳本和數(shù)據(jù)集的概念,這樣可以避免編寫對編譯器和鏈接器等工具的單獨調(diào)用的復(fù)雜性。
  • 又快又可靠。Bazel緩存所有以前做過的工作,并跟蹤對文件內(nèi)容和構(gòu)建命令的更改。通過這種方式,Bazel知道什么時候需要重建,而且只需要重建。為了進一步加速構(gòu)建,您可以設(shè)置項目以高度并行和增量的方式構(gòu)建。
  • 多平臺。Bazel可以在Linux、macOS和Windows上運行。Bazel可以為同一項目中的多個平臺(包括桌面、服務(wù)器和移動平臺)構(gòu)建二進制文件和可部署包。
  • Bazel是可擴展的。您可以擴展Bazel來支持您所選擇的語言。
  • 可伸縮性:Bazel可以處理大型項目;在Google,一個服務(wù)器軟件有十萬行代碼是很常見的,在什么都不改的前提下重新構(gòu)建這樣一個項目,大概只需要200毫秒。
  • 可重復(fù)性:在BUILD文件中,每個庫、測試用例和二進制文件都需要明確指定它們的依賴關(guān)系。當(dāng)一個源碼文件被修改時,Bazel憑這些依賴來判斷哪些部分需要重新構(gòu)建,以及哪些任務(wù)可以并行進行。這意味著所有構(gòu)建都是增量的,并且相同構(gòu)建總是產(chǎn)生一樣的結(jié)果。

安裝Bazel

以下為Mac終端命令:

如果下載速度緩慢, 請檢查自己是否科學(xué)的上網(wǎng)了-

//download JDK version 8
brew cask install homebrew/cask-versions/java8

//Install the Bazel Homebrew package
brew install bazel

//test bazel
bazel version

build iOS App

空殼文件下載

首先clone一個我創(chuàng)建的示例App, 它是一個空殼的框架
git clone -b shell https://github.com/zhuge1127/BazelDemo
里面有一個sample文件夾, 下面的App文件夾內(nèi)包含著一個最簡單的空殼文件.但是并沒有用Xcode的xcodeproj組織文件.

創(chuàng)建WORKSPACE文件

cd path/BazelDemo
touch WORKSPACE

path表示BazelDemo所在路徑, 下同.

編輯WORKSPACE文件

要為App設(shè)備構(gòu)建應(yīng)用程序,Bazel需要從其GitHub存儲庫中提取最新的蘋果構(gòu)建規(guī)則.https://github.com/bazelbuild/rules_apple

load("@bazel_tools//tools/build_defs/repo:git.bzl", "git_repository")

git_repository(
    name = "build_bazel_rules_apple",
    remote = "https://github.com/bazelbuild/rules_apple.git",
    tag = "0.6.0",
)

load(
    "@build_bazel_rules_apple//apple:repositories.bzl",
    "apple_rules_dependencies",
)

apple_rules_dependencies()

保存上面的內(nèi)容到WORKSPACE.

創(chuàng)建BUILD文件

介紹一下package和BUILD文件的關(guān)系: Bazel把代碼劃分成package, 可以把package理解為一個目錄,這個目錄里面包含了源文件和一個描述文件,描述文件中指定了如何將源文件轉(zhuǎn)換成構(gòu)建的輸出。這個描述文件叫做 BUILD,一個目錄中存在這個BUILD文件,就可以把這個目錄當(dāng)作一個包。

cd path/BazelDemo/sample
touch BUILD

編輯BUILD內(nèi)容

  • 要構(gòu)建一個target,Bazel都需要從GitHub存儲庫加載構(gòu)建規(guī)則。
    因此需要在BUILD開頭添加以下load語句:
    load("@build_bazel_rules_apple//apple:ios.bzl", "ios_application")

  • 構(gòu)建.m和.xib文件: Bazel提供了幾個構(gòu)建規(guī)則, 現(xiàn)在使用objc_library規(guī)則告訴Bazel如何源代碼和Xib文件構(gòu)建靜態(tài)庫

    為了更好地解釋下面的內(nèi)容, 將使用//表示注釋內(nèi)容, 實際使用的時候請刪除注釋內(nèi)容.

    objc_library(
    // name 設(shè)置成當(dāng)前文件夾下包含源代碼或者.xib等文件的文件夾名稱+Classes; 此處為App文件夾所以叫AppClasses
    name = "AppClasses",
    // 資源: 填寫當(dāng)前文件夾下資源的相對路徑
    srcs = [
         "App/AppDelegate.m",
         "App/ViewController.m",
         "App/main.m",
    ],
    // 頭文件
    hdrs = glob(["App/*.h"]),
    // xib文件
    xibs = ["App/ViewController.xib"],
    )
  • 使用ios_application規(guī)則告訴它如何構(gòu)建應(yīng)用程序二進制文件和.ipa包

注意這里的內(nèi)容填寫的值要和info.plist文件中的對應(yīng)一致, 不要出現(xiàn)bundle_id對應(yīng)不上類似的問題

    ios_application(
    name = "sample",
    bundle_id = "Bazel.App",
    families = [
        "iphone",
        "ipad",
    ],
    minimum_os_version = "9.0",
    infoplists = [":App/Info.plist"],
    visibility = ["http://visibility:public"],
    deps = [":AppClasses"],
)

構(gòu)建App

至此, 我們的配置已經(jīng)全部完成了.可以開始構(gòu)建

cd path/BazelDemo
bazel build //sample:sample

# 以下為正確構(gòu)建輸出內(nèi)容
INFO: Build options have changed, discarding analysis cache.
INFO: Analysed target //sample:sample (31 packages loaded).
INFO: Found 1 target...
Target //sample:sample up-to-date:
  bazel-bin/sample/sample.ipa
INFO: Elapsed time: 3.220s, Critical Path: 0.03s
INFO: 0 processes.
INFO: Build completed successfully, 5 total actions

查看構(gòu)建產(chǎn)物在 path/BazelDemo/bazel-bin/sample.


正確構(gòu)建結(jié)果

使用Tulsi生成一個xcodeproj

Tulsi是生成xcodeproj的工具, 也是Bazel的一部分內(nèi)容, 官方地址在 https://tulsi.bazel.build/你可以訪問官網(wǎng)然后從github下載這個工具, 它是一個Mac App, 為了方便我已經(jīng)將它放置在BazelDemo/Tulsi/Tulsi.app. 下面通過截圖表示一個xcodeproj創(chuàng)建的過程, 其中一些配置基本沒有設(shè)置. 需要根據(jù)實際項目進行對應(yīng)的設(shè)置, 此處僅做為參考而已

1

2
3
4
5
6
7

通過以上步驟, 你就可以在指定的文件夾下找到類似Sample.xcodeproj的文件, 可以使用xcode打開進行編輯了.

資料介紹

DEMO資料:
demo地址: https://github.com/zhuge1127/BazelDemo.git
demo分支: shell空殼實驗分支, master完成之后的全部內(nèi)容

官方資料:
Bazel官網(wǎng): https://www.bazel.build/
Bazel-github: https://github.com/bazelbuild
Tulsi官網(wǎng): https://tulsi.bazel.build/

Bazel相關(guān)文章:
http://www.infoq.com/cn/news/2015/03/google-open-source-bazel
https://blog.csdn.net/qq_40114263/article/details/79479886
https://www.cnblogs.com/Leo_wl/p/4458115.html
https://www.zhihu.com/question/29025960
https://medium.com/windmill-engineering/bazel-is-the-worst-build-system-except-for-all-the-others-b369396a9e26
https://www.cnblogs.com/Jack47/p/build-in-the-cloud.html

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容