Android的Soong介绍

原文:https://android.googlesource.com/platform/build/soong/+/master/README.md

Soong

Soong是以前Android基于make的编译系统的替代品。它以Android.bp文件替代Android.mk,Android.bp文件用类似JSON的简洁声明来描述需要构建的模块。

Android.bp文件格式

Android.bp文件设计得非常简洁。没有条件或控制流语言(任何复杂性都在用Go编写的构建逻辑中被处理)。Android.bp文件的语法和语义在可能的情况下有意类似于 Bazel构建文件

模块

Android.bp文件中的模块以模块类型开头,后跟一组name: value格式的属性:

cc_binary {
    name: "gzip",
    srcs: ["src/test/minigzip.c"],
    shared_libs: ["libz"],
    stl: "none",
}

每个模块必须有name属性,且其值在所有Android.bp文件中必须是唯一的。
关于可用模块类型及其属性列表,参见$OUT_DIR/soong/.bootstrap/docs/soong_build.html.

Glob模式

获取文件列表的属性可以采用glob模式。Glob模式可以包含普通的Unix通配符*,如"*.java"。Glob模式还可以包含单个**通配符作为路径元素,它将匹配零个或多个路径元素。如 java/**/*.java 将匹配
java/Main.javajava/com/android/Main.java

变量

Android.bp文件可包含顶级变量赋值:

gzip_srcs = ["src/test/minigzip.c"],
cc_binary {
    name: "gzip",
    srcs: gzip_srcs,
    shared_libs: ["libz"],
    stl: "none",
}

变量范围限定为声明它们的文件的其余部分,以及任何子蓝图文件。变量是不可变的,但有一个例外 —— 它们可以附上+= 赋值,但仅在变量被引用之前。

注释

Android.bp文件可以包含C风格多行 /* */ 注释和C++风格的单行 // 注释。

类型

变量和属性是强类型的,变量动态地基于首次赋值,属性静态地由模块类型。支持的类型是:

  • Bool (true or false)
  • Integers (int)
  • Strings ("string")
  • Lists of strings (["string1", "string2"])
  • Maps ({key1: "value1", key2: ["value2"]})

Map可以是任何类型的值,包括嵌套Map。List和Map在最后一个值后可能有逗号。

操作符

字符串(String),字符串列表和映射(Map)可以使用 + 操作符追加字符串。整形(Integers )可以使用 + 操作符来求和。追加Map映射会产生两个Map中键(Key)的并集,并追加上两个Map中所有键的值(Value)。

默认模块

默认模块可用于在多个模块中重复相同的属性。例如:

cc_defaults {
    name: "gzip_defaults",
    shared_libs: ["libz"],
    stl: "none",
}
cc_binary {
    name: "gzip",
    defaults: ["gzip_defaults"],
    srcs: ["src/test/minigzip.c"],
}

名称解析

Soong提供为不同目录中的模块指定相同名称的能力,只要每个模块在单独的命名空间中声明即可。命名空间可以像这样声明:

soong_namespace {
    imports: ["path/to/otherNamespace1", "path/to/otherNamespace2"],
}

每个Soong模块都根据其在树中的位置分配命名空间。每个Soong模块都被认为是在当前目录或最近祖先目录中的Android.bp中找到的soong_namespace定义的命名空间中,除非找不到这样的soong_namespace模块,在这种情况下,模块被认为是在隐式root命名空间中。

当Soong尝试解析依赖关系D声明的我的模块M时(M在导入命名空间I1,I2,I3 ......的命名空间N中),如果D是一个形如“// namespace:module”的完全限定名称,则只有特定的命名空间才会被搜索指定的模块名称。否则,Soong将首先查找在命名空间N中声明的名为D的模块。如果该模块不存在,Soong将在命名空间I1,I2,I3中寻找名为D的模块......最后,Soong将查找根命名空间。

在我们完全从Make转换为Soong之前,Make product配置必须指定PRODUCT_SOONG_NAMESPACES的值。它的值应该是一个空格分隔的命名空间列表,Soong导出到Make由m命令构建 。在我们完全从Make转换为Soong之后,启用命名空间的细节可能会发生变化。

格式化

Soong包含一个蓝图文件的规范的格式化程序,类似于gofmt。以递归重新格式化当前目录中的所有Android.bp文件:

bpfmt -w .

规范的格式包括4个空格缩进,在多元素列表的每个元素之后的换行,并且在列表和映射中始终包含尾随的逗号。

转换Android.mk文件

Soong包含一个工具,在将Android.mk文件转换为Android.bp文件时执行第一遍:

androidmk Android.mk > Android.bp

该工具转换变量,模块,注释和一些条件,但必须手动转换任何自定义Makefile规则,复杂条件或额外包含。

Android.mk和Android.bp之间的差异

  • Android.mk文件通常具有多个具有相同名称的模块(如:库的静态和共享版本,或主机和设备版本)。Android.bp文件需要每个模块有唯一的名称,但是可以在多个变体中构建单个模块,如通过添加host_supported: true。androidmk转换器会生成多个冲突的模块,必须通过处理单个模块的target: { android: { }, host: { } }块里的差异来手动解决。

构建逻辑

使用blueprint 框架在Go中编写构建逻辑。构建逻辑接收使用反射解析为Go结构的模块定义并生成构建规则。构建规则由blueprint收集并写入ninja构建文件。

其他文档

常问问题

如何编辑条件?

Soong特意在Android.bp文件中不支持条件。相反,需要条件的构建规则的复杂性在Go中处理,其中可以使用高级语言特性并且可以跟踪条件引入的隐式依赖性。大多数条件被转换为map属性,其中将选择映射中的一个值并将其附加到顶级属性。

例如,要支持特定体系结构的文件:

cc_library {
    ...
    srcs: ["generic.cpp"],
    arch: {
        arm: {
            srcs: ["arm.cpp"],
        },
        x86: {
            srcs: ["x86.cpp"],
        },
    },
}

有关产品变量或环境变量的更复杂条件的示例,请参阅 art/build/art.go
external/llvm/soong/llvm.go

Soong开发

要在Go-aware IDE中加载Soong代码,请在android树之外创建一个目录,然后:

apt install bindfs
export GOPATH=<path to the directory you created>
build/soong/scripts/setup_go_workspace_for_soong.sh

以上将把Soong源目录挂载到IDE所期望的布局目录中。

联系方式

任何疑问请发电子邮件至android-building@googlegroups.com (外部)或参阅go/soong (内部)。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,498评论 25 707
  • 一 概述 1.1 编译系统变化 随着android工程越来越大,包含的module越来越多,以makefile...
    Little熊猫阅读 30,323评论 4 15
  • Soong Soong is the replacement for the old Android make-b...
    gaolinfeng阅读 3,206评论 0 2
  • 应青椒学员王雪琴推荐,我加入了一个有趣而且免费的彩铅绘画课程,第一节课画的便是这灯塔,看的时候课程已过半,迅速拿出...
    陕县1903贺绍芳阅读 1,320评论 1 2
  • “a==b”和”a.equals(b)”有什么区别?如果 a 和 b 都是对象,则 a==b 是比较两个对象的引用...
    迷人的酋长阅读 184评论 0 0