模块级build-profile.json5文件
配置文件结构
模块级build-profile.json5文件整体的结构如下。
apiType
targets
└── name
└── runtimeOS
└── config
└── distroFilter / distributionFilter
└── apiVersion
└── policy
└── value
└── screenShape
└── policy
└── value
└── screenWindow
└── policy
└── value
└── screenDensity
└── policy
└── value
└── countryCode
└── policy
└── value
└── deviceType
└── buildOption
└── atomicService
└── preloads
└── moduleName
└── source
└── abilities
└── name
└── pages
└── res
└── icon
└── label
└── launchType
└── pages
└── sourceRoots
└── resource
└── directories
└── output
└── artifactName
showInServiceCenter
buildOption
buildOptionSet
└── name
└── debuggable
└── generateSharedTgz
└── copyFrom
└── resOptions
└── compression
└── media
└── enable
└── filters
└── method
└── type
└── blocks
└── files
└── path
└── size
└── resolution
└── exclude
└── path
└── size
└── resolution
└── resCompileThreads
└── copyCodeResource
└── enable
└── includes
└── excludes
└── ignoreResourcePattern
└── excludeHarRes
└── includeAppScopeRes
└── qualifiersConfig
└── Mcc&Mnc
└── Locale
└── Orientation
└── Device
└── ColorMode
└── Density
└── externalNativeOptions
└── path
└── abiFilters
└── arguments
└── cppFlags
└── cFlags
└── targets
└── sourceOption
└── workers
└── nativeLib
└── filter
└── excludes
└── pickFirsts
└── pickLasts
└── enableOverride
└── select
└── package
└── version
└── includePattern
└── excludePattern
└── include
└── exclude
└── debugSymbol
└── strip
└── exclude
└── headerPath
└── collectAllLibs
└── excludeFromHar
└── excludeSoFromInterfaceHar
└── excludeSoFromBinXO
└── librariesInfo
└── name
└── linkLibraries
└── napiLibFilterOption
└── excludes
└── pickFirsts
└── pickLasts
└── enableOverride
└── arkOptions
└── runtimeOnly
└── sources
└── packages
└── excludePackages
└── types
└── obfuscation
└── ruleOptions
└── enable
└── files
└── consumerFiles
└── buildProfileFields
└── integratedHsp
└── transformLib
└── branchElimination
└── byteCodeHar
└── bundledDependencies
└── packSourceMap
└── autoLazyImport
└── autoLazyFilter
└── include
└── exclude
└── reExportCheckMode
└── skipOhModulesLint
└── expandImportPath
└── enable
└── exclude
└── apPath
└── hostPGO
└── packingOptions
└── asset
└── include
└── exclude
└── customizedOptions
└── basePackage
└── removePermissions
└── name
buildModeBinder
└── buildModeName
└── mappings
└── targetName
└── buildOptionName
entryModules
配置文件字段说明
下表为"Ability"类型的Module(HAP)对应的模块级build-profile.json5中配置项包含的字段,"Library"类型的Module(HAR和HSP)对应的模块级build-profile.json5中配置项为下表罗列范围的子集。
表1 模块级build-profile.json5文件字段说明
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| apiType | 字符串 | 可选 | API模型类型: - stageMode:Stage模型,后续长期演进的模型,推荐使用该模型。 - faMode:FA模型。 |
| targets | 对象数组 | 可选 | 定义的target,可配置多个;若配置,数组长度至少为1。 |
| showInServiceCenter | 布尔值 | 可选 | 是否显示在服务中心: - true:显示。 - false(缺省默认值):不显示。 |
| buildOption | 对象 | 可选 | 模块在构建过程中的相关配置。 其中不支持配置name、debuggable和copyFrom字段。 在FA模型中,arkOptions配置中仅支持配置types字段。 |
| buildOptionSet | 对象数组 | 可选 | 表16buildOption的集合,其中name字段必填,每个配置都是当前支持的编译过程中所有可用工具的通用配置选项集。 |
| buildModeBinder | 对象数组 | 可选 | 构建模式(debug、release 等)与构建配置(buildOption)的关联配置。通过该配置可以将不同的构建配置和target进行组合,并绑定到对应的构建模式上,其中构建模式需要在工程级别的构建模式列表中已定义。 |
| entryModules | 字符串数组 | 可选 | Feature类型模块所关联的入口模块,仅对FA模型工程生效。 |
targets
targets用于给模块配置多目标产物,可配置多个;若配置,数组长度至少为1。
表2 targets
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| name | 字符串 | 必选 | target名称。 |
| runtimeOS | 字符串 | 可选 | target的目标运行环境: - HarmonyOS - OpenHarmony |
| config | 对象 | 可选 | target相关配置。 |
| source | 对象 | 可选 | target的源码范围。 |
| resource | 对象 | 可选 | target包含的资源目录。 |
| output | 对象 | 可选 | 定制产品生成的应用包的配置。 |
表3 resource
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| directories | 字符串数组 | 可选 | 资源目录地址。 |
表4 output
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| artifactName | 字符串 | 必选 | 自定义产品生成的应用包名称,可由数字、英文字母、中划线、下划线和英文句号(.)组成,支持输入版本号。 |
targets字段示例:
"targets": [
{
"name": "default",
"resource": {
"directories": ["./src/main/resources"]
},
"output": {
"artifactName": "customizedTargetOutputName-1.0.0"
}
}
]
config
config是target相关配置。
表5 config
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| distroFilter | 对象 | 可选 | 应用市场分发规则。在FA模型中使用。 |
| distributionFilter | 对象 | 可选 | 应用市场分发规则。在Stage模型中使用。 |
| deviceType | 字符串数组 | 可选 | target支持的设备类型,必须在module.json5中已定义。 在FA模型中,对应的文件为config.json。 |
| buildOption | 对象 | 可选 | 模块在构建过程中的相关配置。 其中不支持配置name、debuggable和copyFrom字段。 |
| atomicService | 对象 | 可选 | 元服务相关配置,仅支持在Stage模型中配置。 |
source
source用于指定target的源码范围。
表6 source
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| abilities | 对象数组 | 可选 | 自定义target的能力范围。 在FA模型工程中支持对Ability源码目录下的page页面进行定制。 |
| pages | 字符串数组 | 可选 | Stage模型工程中支持对pages源码目录的page页面进行定制,数组长度至少为1。 |
| sourceRoots | 字符串数组 | 可选 | Stage模型工程中支持对差异化代码空间进行定制,数组长度至少为1。数组中的值有以下限制: 1. 必须唯一; 2. 必须为相对路径; 3. 类型必须为文件夹; 4. 文件夹必须真实存在; 5. 文件夹必须与src/main同级; 当数组中存在多个值时,寻址的优先级为数组中值的顺序。 |
source字段示例:
"targets": [
{
"name": "default",
"source": {
"pages": [ // Stage模型
"pages/Index"
],
"abilities": [ // FA模型
{
"name": ".MainAbility",
"pages": [
"pages/index"
]
}
],
"sourceRoots": [
"./src/default"
]
}
}
]
distroFilter/distributionFilter
distroFilter/distributionFilter用于指定应用市场分发规则,distroFilter在FA模型中使用,distributionFilter在Stage模型中使用。
表7 distroFilter/distributionFilter
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| apiVersion | 对象 | 可选 | 支持的apiVersion范围。 |
| screenShape | 对象 | 可选 | 屏幕形状的支持策略。 |
| screenWindow | 对象 | 可选 | 应用运行时窗口的分辨率支持策略。 |
| screenDensity | 对象 | 可选 | 屏幕的像素密度支持策略。 |
| countryCode | 对象 | 可选 | 应用需要分发的国家地区码。 |
apiVersion
表8 apiVersion
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| policy | 字符串 | 必选 | 取值规则: - include:需要包含的value属性。 - exclude:需要排除的value属性。 |
| value | 整型数组 | 必选 | 支持的取值为API Version存在的整数值,例如10。 |
screenShape
表9 screenShape
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| policy | 字符串 | 必选 | 取值规则: - include:需要包含的value属性。 - exclude:需要排除的value属性。 |
| value | 字符串数组 | 必选 | 支持的取值范围: - circle:圆形 - rect:矩形 |
screenWindow
表10 screenWindow
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| policy | 字符串 | 必选 | 当前取值仅支持“include”。 - include:需要包含的value属性。 |
| value | 字符串数组 | 必选 | 单个字符串的取值格式为“宽*高”,取值为整数像素值,例如"454*454"。 |
screenDensity
表11 screenDensity
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| policy | 字符串 | 必选 | 取值规则: - include:需要包含的value属性。 - exclude:需要排除的value属性。 |
| value | 字符串数组 | 必选 | 取值范围: - sdpi:小规模的屏幕密度(Small-scale Dots per Inch),适用于dpi取值为(0,120]的设备。 - mdpi:中规模的屏幕密度(Medium-scale Dots Per Inch),适用于dpi取值为(120,160]的设备。 - ldpi:大规模的屏幕密度(Large-scale Dots Per Inch),适用于dpi取值为(160,240]的设备。 - xldpi:大规模的屏幕密度(Extra Large-scale Dots Per Inch),适用于dpi取值为(240,320]的设备。 - xxldpi:大规模的屏幕密度(Extra Extra Large-scale Dots Per Inch),适用于dpi取值为(320,480]的设备。 - xxxldpi:表示大规模的屏幕密度(Extra Extra Extra Large-scale Dots Per Inch),适用于dpi取值为(480, 640]的设备。 |
countryCode
表12 countryCode
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| policy | 字符串 | 必选 | 取值规则: - include:需要包含的value属性。 - exclude:需要排除的value属性。 |
| value | 字符串数组 | 必选 | 国家地区码取值,具体值以ISO-3166-1标准为准。支持多个国家和地区枚举定义。 |
distroFilter/distributionFilter字段示例:
"targets": [
{
"name": "default",
"config": {
"distributionFilter": {
"apiVersion": {
"policy": "include",
"value": [12]
},
"screenShape": {
"policy": "include",
"value": [
"circle",
"rect"
]
},
"screenWindow": {
"policy": "include",
"value": [
"454*454",
"466*466"
]
},
"screenDensity": {
"policy": "exclude",
"value": [
"ldpi",
"xldpi"
]
},
"countryCode": {
"policy": "include",
"value": [
"CN"
]
}
}
},
}
]
atomicService
表13 atomicService
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| preloads | 对象数组 | 可选 | 定义当前模块运行时预加载的模块。 |
表14 preloads
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| moduleName | 字符串 | 可选 | 预加载的模块名称。 |
atomicService字段示例:
"targets": [
{
"name": "default",
"config": {
"atomicService": {
"preloads": [
{
"moduleName": "preloadSharedLibrary"
}
]
}
}
}
]
abilities
abilities用于自定义target的能力范围。
表15 abilities
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| name | 字符串 | 必选 | 指定target选择的ability的名称。 |
| pages | 字符串数组 | 可选 | FA模型中,指定target选择的ability的page。 |
| res | 字符串数组 | 可选 | 指定资源目录。 |
| icon | 字符串 | 可选 | 指定ability图标文件的索引,格式为"$media:ability_icon"。 |
| label | 字符串 | 可选 | 指定对用户可见的名称,要求采用该名称的资源索引,以支持多语言。 |
| launchType | 字符串 | 可选 | 指定ability的启动模式: - multiton:多实例模式,每次启动创建一个新实例。 - standard:同multiton,建议使用multiton替代。 - singleton(缺省默认值):单实例模式,仅第一次启动创建新实例。 - specified:指定实例模式,运行时由开发者决定是否创建新实例。 |
abilities字段示例:
"targets": [
{
"name": "default",
"source": {
"abilities": [
{
"name": "EntryAbility",
"icon": "$media:layered_image",
"label": "$string:EntryAbility_label",
"launchType": "singleton"
}
]
}
}
]
buildOption
buildOption是模块在构建过程中的相关配置,buildOptionSet和targets中也支持配置buildOption。此外,工程级build-profile.json5中也支持配置buildOption。工程级别buildOption配置会与模块级别的buildOption进行合并,具体合并规则和优先级请参考合并编译选项规则。
表16 buildOption
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| name | 字符串 | 可选 | 构建配置方案buildOption的名称。 |
| debuggable | 布尔值 | 可选 | 当前编译产物是否为可调试模式(debug): - true:可调试。 - false:不可调试。 如果未配置debuggable字段,使用release的编译模式时,默认值为false,使用其他编译模式时,默认值为true。 |
| generateSharedTgz | 布尔值 | 可选 | 编译HSP模块时是否生成tgz包。 - true:生成。 - false:不生成。 如果未配置generateSharedTgz,根据debuggable字段决定是否生成tgz包。debuggable为true时,不生成tgz包,debuggable为false时,生成tgz包。 从DevEco Studio 5.1.1 Beta1版本开始支持。 说明: 该字段配置后仅对HSP模块生效。 |
| copyFrom | 字符串 | 可选 | 配置已定义的buildOption的name,表示从本模块已有的buildOption复制配置。 |
| resOptions | 对象 | 可选 | 资源编译配置项。 |
| externalNativeOptions | 对象 | 可选 | Native编译配置项。 |
| sourceOption | 对象 | 可选 | 源码相关配置。使用不同的标签对源代码进行分类,以便在构建过程中对不同的源代码进行不同的处理。 |
| nativeLib | 对象 | 可选 | Native 库(.so)相关配置。 |
| napiLibFilterOption | 对象 | 可选 | NAPI库(.so)文件的筛选选项。标记为废弃,不建议使用,推荐使用nativeLib/filter。 |
| arkOptions | 对象 | 可选 | ArkTS编译配置。 |
| packingOptions | 对象 | 可选 | 打包配置项,仅支持HAR模块。 |
| removePermissions | 对象数组 | 可选 | 指定编译时需要删除的依赖包中的冗余权限,模块本身的权限不会被删除,仅HAP/HSP模块支持配置。 |
resOptions
resOptions是资源编译配置项。
表17 resOptions
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| compression | 对象 | 可选 | 对工程预置图片资源进行纹理压缩的编译配置参数。 |
| resCompileThreads | 整型数值 | 可选 | 资源编译的线程数量 ,最小为1,最大为主机的CPU核数。 该字段从DevEco Studio 5.1.0 Release版本开始支持。 |
| copyCodeResource | 对象 | 可选 | 对模块的src/main/ets目录下的资源文件(非源码文件)拷贝的编译配置参数。 说明: 该字段对不开启混淆的源码HAR不生效。 |
| ignoreResourcePattern | 字符串数组 | 可选 | 根据glob语法,对资源目录resources或开发者自定义的资源目录下的文件/文件夹名称进行过滤,匹配到的文件不会被打包到产物中。 从DevEco Studio 5.1.1 Beta1版本开始支持。 说明: - 如果规则中带有路径(例如./src/main/a.png),该规则不生效。 - 如果未配置该字段,打包HAP/HSP时存在默认的过滤规则:默认不打包.git、.svn、.scc、.ds_store、desktop.ini、picasa.ini、cvs、thumbs.db以及以.开头的隐藏文件/目录和以~结尾的文件。 - 配置该字段后,会覆盖默认的过滤规则;如果字段配置为空数组,则不应用任何过滤规则,即全部资源都打包。 |
| excludeHarRes | 字符串数组 | 可选 | 编译HAP/HSP模块时,指定不参与资源编译的三方HAR包的包名,配置后,依赖HAR包中的资源不会被打包到产物中,支持直接依赖和间接依赖。 从DevEco Studio 6.0.0 Beta2版本开始支持。 说明: 仅支持在HAP/HSP中配置。 |
| includeAppScopeRes | 布尔值 | 可选 | 编译HSP时,是否将AppScope目录下的资源打包到产物中。 - true(缺省默认值):打包。 - false:不打包。 从DevEco Studio 6.0.0 Beta2版本开始支持。 说明: - 该字段仅对HSP模块生效。 - 配置为false后,app.json5的icon和label字段不再对HSP模块生效。 |
| qualifiersConfig | 对象 | 可选 | 配置HAP/HSP模块的限定词目录,编译时会进行过滤,匹配到的限定词目录会被打包到产物中。支持六类限定词,具体请查看表19,配置的目录要符合限定词目录取值要求。 如果某类限定词未配置过滤,则包含该类限定词的目录默认会打包。 从DevEco Studio 6.1.0 Beta1版本开始支持。 说明: - qualifiersConfig不能为{},至少配置一类限定词。 - 如果配置了限定词,取值不能为空数组[],数组中的值不能为空字符串""。 - 仅支持Stage模型。 |
表18 copyCodeResource
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| enable | 布尔值 | 可选 | 是否将src/main/ets目录下的资源文件(.ets/.ts/.js以外的其他文件)打包到产物中。 从DevEco Studio 6.0.0 Beta2版本开始,新建工程或模块时,默认配置enable字段并且值为false,即默认不打包ets目录下的资源文件。 - true(缺省默认值):打包。 - false:不打包。 |
| includes | 字符串数组 | 可选 | - 当enable为true时,用于指定打包的资源文件,其他资源文件均不会打包到产物中,支持glob语法,以"**/"开头。 - 当enable为false时,includes不生效。 从DevEco Studio 6.0.0 Beta2版本开始支持。 说明: excludes和includes互斥,只能配置一个。 |
| excludes | 字符串数组 | 可选 | - 当enable为true时,用于指定不打包的资源文件,其他资源文件均会打包到产物中,支持glob语法,以"**/"开头。 - 当enable为false时,excludes不生效。 |
- 模块的src/main/ets目录下,编译时仅处理.ets/.ts/.js文件,其他文件会被当作资源文件打包进产物中,不会进行混淆或加密,如需过滤请配置excludes字段。
- 请勿将源码等文件放在以.开头的系统隐藏目录中,可能会导致过滤规则失效,会将src/main/ets目录下的所有文件作为资源文件打包进产物中,不会进行混淆或加密。
表19 qualifiersConfig
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| Mcc&Mnc | 字符串数组 | 可选 | 配置移动国家码(MCC)和移动网络码(MNC)限定词目录,匹配到的目录会被打包到产物中,如['mcc460']表示过滤其他国家码,打包包含mcc460的目录。 如果未配置,默认所有的MCC或MNC都会打包。 |
| Locale | 字符串数组 | 可选 | 配置语言、文字、国家或地区限定词目录,匹配到的目录会被打包到产物中,如['zh_CN']表示过滤其他语言,打包包含zh_CN的目录。 如果未配置,默认所有的语言都会打包。 |
| Orientation | 字符串数组 | 可选 | 配置横竖屏限定词目录,匹配到的目录会被打包到产物中,如['vertical']表示过滤其他屏幕方向,打包包含vertical的目录。 如果未配置,默认所有的屏幕方向都会打包。 |
| Device | 字符串数组 | 可选 | 配置设备类型限定词目录,匹配到的目录会被打包到产物中,如['phone']表示过滤其他设备,打包包含phone的目录。 如果未配置,默认所有的设备都会打包。 |
| ColorMode | 字符串数组 | 可选 | 配置颜色模式限定词目录,匹配到的目录会被打包到产物中,如['dark']表示过滤其他模式,打包包含dark的目录。 如果未配置,默认所有的颜色模式都会打包。 |
| Density | 字符串数组 | 可选 | 配置屏幕密度限定词目录,匹配到的目录会被打包到产物中,如['sdpi']表示过滤其他屏幕密度,打包包含sdpi的目录。 如果未配置,默认所有的屏幕密度都会打包。 |
如果同时配置多类限定词,最终打包的目录要同时符合多类限定词的过滤条件,例如存在以下限定词目录:
phone-dark-Vertical
phone-dark-Horizontal
phone-light-Horizontal
car-dark-Vertical
配置如下:
"qualifiersConfig":{
"Device":['phone'],
"ColorMode":['dark'],
}
过滤步骤如下:
- Device限定词配置了phone,所以phone-dark-Vertical、phone-dark-Horizontal、phone-light-Horizontal符合,car-dark-Vertical不符合,会过滤掉。
- ColorMode限定词配置了dark,所以phone-dark-Vertical、phone-dark-Horizontal符合,phone-light-Horizontal不符合,会过滤掉。
- Orientation限定词未配置,所以不过滤限定词目录,phone-dark-Vertical、phone-dark-Horizontal都符合。
- 综上所述,最终打包到产物中的是phone-dark-Vertical和phone-dark-Horizontal。
resOptions字段示例:
"buildOption": {
"resOptions": {
"resCompileThreads": 2,
"copyCodeResource": {
"enable": true,
"excludes": ['**/entry/src/main/ets/component/big_picture.png', '**/*.yml', '**/subDir/**'], // includes字段配置方式相同
},
"ignoreResourcePattern": ['*.png' ,'abc.json'],
"excludeHarRes": ['har'],
"qualifiersConfig":{
"Mcc&Mnc":['mcc460'],
"Locale":['zh_CN'],
"Orientation":['vertical'],
"Device":['phone','tv'],
"ColorMode":['dark'],
// "Density":['sdpi'], 不配置表示所有的屏幕密度都打包
},
}
}
sourceOption
sourceOption是源码相关配置,使用不同的标签对源代码进行分类,以便在构建过程中对不同的源代码进行不同的处理。
表20 sourceOption
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| workers | 字符串数组 | 可选 | 指定使用node.js工作器的JS/TS源代码,源代码在构建过程中单独处理。 |
sourceOption字段示例:
"buildOption": {
"sourceOption": {
"workers": [
"./src/main/ets/common/constants/CommonConstants.ets"
]
}
}
napiLibFilterOption
napiLibFilterOption是NAPI库(.so)文件的筛选选项,字段已废弃,不建议使用,推荐使用nativeLib/filter。
表21 napiLibFilterOption
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| excludes | 字符串数组 | 可选 | 排除的.so文件。罗列的NAPI库将不会被打包。 |
| pickFirsts | 字符串数组 | 可选 | 按照.so文件的优先级顺序,打包最高优先级的.so文件。 |
| pickLasts | 字符串数组 | 可选 | 按照.so文件的优先级顺序,打包最低优先级的.so文件。 |
| enableOverride | 布尔值 | 可选 | 是否允许当.so文件重名冲突时,使用高优先级的.so文件覆盖低优先级的.so文件: - true:允许。 - false(缺省默认值):不允许。 |
arkOptions
arkOptions是ArkTS编译配置。
表22 arkOptions
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| runtimeOnly | 对象 | 可选 | 配置变量动态import的文件和依赖的包名,仅支持在Stage模型中配置。 runtimeOnly为非必选配置,当工程需要以变量方式动态import文件、目录的相对路径或三方包时,需要通过配置runtimeOnly来确保其加入编译流程。详情请参考动态import变量表达式。 |
| types | 字符串数组 | 可选 | 自定义类型,可配置包名或d.ts/d.ets文件路径。 |
| obfuscation | 对象 | 可选 | 代码混淆配置。 |
| buildProfileFields | 对象 | 可选 | 运行时可获取的自定义构建参数,支持键值对配置,key可由数字、英文、下划线、中划线组成,value类型仅支持string、number、boolean。 |
| integratedHsp | 布尔值 | 可选 | 是否为集成态HSP。 - true:是。 - false(缺省默认值):否。 说明: - 从API 12开始支持。 - 需在工程级build-profile.json5中配置useNormalizedOHMUrl为true后使用。 - 该字段仅在HSP模块中配置后生效。 |
| transformLib | 字符串 | 可选 | 字节码插桩插件配置,允许开发者在编译时对字节码进行插桩修改,仅支持Stage模型,格式为相对路径,不同系统要求的文件类型如下,文件内容需要在对应平台生成,不能拷贝修改后缀名混用。 - Windows:.dll文件。 - Linux/Mac:.so文件。 说明: - Mac环境下添加配置后插桩未生效的问题请参考FAQ。 - HAR模块仅字节码HAR配置生效,非字节码HAR配置不生效。 |
| branchElimination | 布尔值 | 可选 | 是否启用代码分支裁剪,减少编译产物大小,开启后,在release编译模式下,不会被执行到的代码分支会被裁剪掉,示例请参考branchElimination示例。 - true:启用(将导致使用"ApplyChanges"功能时,对const声明的常量的值进行的修改可能不生效)。 - false(缺省默认值):不启用。 说明: - 仅支持API 11及以上的Stage模型。 - HAR模块仅字节码HAR配置生效,非字节码HAR配置不生效。 - 仅支持const声明的bool类型常量和const声明的string/number类型常量的判断表达式。 - 不支持间接导入,例如A文件中定义const变量A1,B文件导入A1,导出B1,ets导入B1进行判断,无法进行裁剪。 |
| byteCodeHar | 布尔值 | 可选 | 是否构建字节码HAR,仅在HAR模块中配置后生效。详情请参考构建字节码HAR。 - true:支持。 - false:不支持。 说明: - 从API 12开始支持。 - 从DevEco Studio NEXT Beta1(5.0.3.800)版本开始,当工程级build-profile.json5中useNormalizedOHMUrl配置为true时,byteCodeHar缺省默认值为true;当useNormalizedOHMUrl配置为false时,byteCodeHar缺省默认值为false。 |
| bundledDependencies | 布尔值 | 可选 | 是否支持将多个源码HAR(本地+远程)打包成一个字节码HAR。字节码HAR、HSP、npm不会被打包进去,仅会合并源码HAR。 - true:支持。 - false(缺省默认值):不支持。 说明: - 仅支持字节码HAR配置该字段。 - 从API 12开始支持。 - 仅支持Stage模型。 |
| packSourceMap | 布尔值 | 可选 | 编译字节码HAR时,是否将sourceMap文件打包到产物中。仅HAR模块支持配置,并且只对字节码HAR生效。 - true:打包。 - false:不打包。 该字段从DevEco Studio 5.1.0 Release版本开始支持。 说明: - 如果不配置,debug模式默认值为true,release模式默认值为false。 - 将sourceMap打包到release的HAR包中,可能会导致HAR中的代码资产泄漏。 |
| autoLazyImport | 布尔值 | 可选 | 编译时是否自动将符合lazy-import语法规范的import语句添加"lazy"关键字。仅支持在源码中添加"lazy"关键字,不包含依赖的字节码HAR包或HSP。关于lazy-import的介绍及相关影响请参考延迟加载(lazy import)。 - true:添加。 - false(缺省默认值):不添加。 说明: - 如果配置为true,编译时不会做场景识别,即源码中任何符合语法规范的import语句都会被添加"lazy"。 - 仅支持Stage模型。 |
| autoLazyFilter | 对象 | 可选 | 自定义添加"lazy"关键字的模块,仅当autoLazyImport为true时生效。 从DevEco Studio 6.0.1 Beta1版本开始支持。 |
| reExportCheckMode | 字符串 | 可选 | 针对以下场景,编译时是否进行拦截报错:使用lazy import导入的变量,在同文件中被再次导出。 - noCheck(缺省默认值):不检查,不报错。 - compatible:兼容模式,报Warning。 - strict:严格模式,报Error。 该字段从DevEco Studio 5.0.5 Release版本开始支持。 |
| skipOhModulesLint | 布尔值 | 可选 | 是否跳过工程中oh_modules目录的ArkTS规则检查。从DevEco Studio 6.0.0 Beta1版本开始支持。 - true:跳过。 - false(缺省默认值):不跳过。 |
| expandImportPath | 对象 | 可选 | import路径展开相关配置选项。 从DevEco Studio 6.0.0 Beta3版本开始支持。 说明: HAR模块不支持配置。 |
| apPath | 字符串 | 可选 | 说明: API 11及以上版本不再支持,即该字段配置后不再生效。 应用热点信息文件路径。 |
| hostPGO | 布尔值 | 可选 | 是否启用配置文件引导优化功能: - true:启用。 - false(缺省默认值):不启用。 从API 10开始废弃。 |
-
branchElimination字段配置为true时,代码分支的裁剪情况示例如下:
// 编译生成的BuildProfile文件export const DEBUG = false;export const VERSION_CODE = 100;// 开发者自定义的ets文件import { DEBUG } from 'BuildProfile';import { VERSION_CODE } from 'BuildProfile';if (DEBUG){XXX} // 该分支会被裁剪掉else{XXX}if (VERSION_CODE){XXX} // 该语法发生了类型转换,不支持代码裁剪。if (VERSION_CODE === 100){XXX} // 若需要裁剪代码,使用该方式,显式指定判断条件为boolean类型。
表23 runtimeOnly
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| sources | 字符串数组 | 可选 | 配置变量动态import的文件/文件夹的相对路径。 配置的文件/文件夹必须在工程中真实存在,且文件的后缀只能为ets或ts。 |
| packages | 字符串数组 | 可选 | 配置变量动态import依赖的包名。 该包名需要和工程级/模块级oh-package.json5的dependencies或dynamicDependencies中的名字保持一致。 从DevEco Studio 5.1.1 Beta1版本开始,packages中的三方包支持配置在dynamicDependencies中。 |
| excludePackages | 字符串数组 | 可选 | 编译HAP/HSP模块时,指定不参与变量动态import的源码HAR的包名,配置的源码HAR不会参与编译,支持直接/间接依赖。 仅支持在HAP/HSP模块中配置。 从DevEco Studio 6.0.0 Beta2版本开始支持。 |
表24 expandImportPath
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| enable | 布尔值 | 可选 | 是否启用import路径展开,启用后可以提升应用的运行时性能。关于import路径展开的原理及开启后的副作用请参考通过import路径展开优化性能。 - true:启用。 - false(缺省默认值):不启用。 说明: import XXX from 'A',A必须为本地HAR模块,并且仅当A为包名时支持进行展开,A为相对路径或包名+路径都不支持展开。 |
| exclude | 字符串数组 | 可选 | 配置oh-package.json5中的依赖别名,用于指定不展开import语句的依赖,仅支持本地HAR模块。 |
表25 autoLazyFilter
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| include | 字符串数组 | 可选 | - 当autoLazyImport为true时,指定自动添加"lazy"关键字的包名(即oh-package.json5中的name),其他包不会添加"lazy"关键字,支持正则语法。 - 当autoLazyImport为false时,include不生效。 说明: - include和exclude互斥,只能配置一个。 - include不支持配置空数组或空字符串,至少配置一个包名,并且包名不能重复。 |
| exclude | 字符串数组 | 可选 | - 当autoLazyImport为true时,指定不添加"lazy"关键字的包名,其他包都会添加"lazy"关键字,支持正则语法。 - 当autoLazyImport为false时,exclude不生效。 说明: - include和exclude互斥,只能配置一个。 - exclude不支持配置空数组或空字符串,至少配置一个包名,并且包名不能重复。 |
arkOptions字段示例:
"buildOption": {
"arkOptions": {
"runtimeOnly": {
"sources": ["./src/main/ets/utils/Calc.ets"],
"packages": ["myHar"],
"excludePackages": ["har1","har2"], // myHar依赖har1、har2
},
"buildProfileFields": {
"buildOptionSetData": "BuildOptionSetDataRelease",
"data": "DataRelease"
},
"transformLib": "./dll/example.dll",
"branchElimination": true,
"autoLazyImport": true,
"autoLazyFilter": {
"include": ['entry']
},
"reExportCheckMode": "compatible",
"expandImportPath": {
"enable": true,
"exclude": ['localhar']
},
}
}
packingOptions
packingOptions是打包配置项,仅支持HAR模块。该字段从DevEco Studio 5.1.0 Release版本开始支持。
表26 packingOptions
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| asset | 对象 | 可选 | 打包资产配置项。 |
| customizedOptions | 对象 | 可选 | HAR模块的定制化选项。 从DevEco Studio 6.0.2 Beta1版本开始支持。 |
表27 asset
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| include | 字符串数组 | 可选 | 配置打包到HAR产物中的文件,遵循glob语法。 说明: - 以下目录配置后不生效,即不会被打包到产物中:node_modules、oh_modules、.preview、build、.cxx、.test。 - 配置include字段后,构建源码HAR时,.gitignore和.ohpmignore文件不生效,详细请参考以debug模式构建。 |
| exclude | 字符串数组 | 可选 | 配置不打包到HAR产物中的文件,遵循glob语法。 说明: - 以下文件配置后不生效,默认会打包:oh-package.json5。 - 配置exclude字段后,构建源码HAR时,.gitignore和.ohpmignore文件不生效,详细请参考以debug模式构建。 |
表28 customizedOptions
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| basePackage | 字符串 | 可选 | 指定需要定制的字节码HAR的abc文件的相对路径。配置后,编译时支持替换掉abc中的同名文件,以实现对字节码HAR的定制修改,具体使用方式请参考三方SDK定制修改部分源码。 |
packingOptions字段示例:
"buildOption": {
"packingOptions": {
"asset": {
"include": ["./src/router.json5", "router.json5"],
"exclude": ["./config/*"]
},
"customizedOptions": {
"basePackage": "./basePackage/modules.abc",
},
}
}
removePermissions
removePermissions是一个对象数组,用于编译HAP/HSP模块时,指定需要删除的依赖包中的冗余权限,模块本身的权限不会被删除。
表29 removePermissions
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| name | 字符串 | 必选 | 待删除的权限名称,需要包含在依赖包的module.json的requestPermissions中。 |
removePermissions字段示例:
"buildOption": {
"removePermissions": [
{
"name": "ohos.permission.ABILITY_BACKGROUND_COMMUNICATION"
},
{
"name": "ohos.permission.ACCELEROMETER"
}
]
}
compression
compression是对工程预置图片资源进行纹理压缩的编译配置参数。
表30 compression
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| media | 对象 | 可选 | 对资源目录下media目录的图片进行纹理压缩的配置参数。 |
| filters | 对象数组 | 可选 | 文件过滤配置参数。 说明: 编译过程中会依次遍历图片文件,并与filters条件进行匹配,一旦匹配成功,则完成该图片的处理。当工程级和模块级同时配置时,先按照模块级的过滤条件匹配,一旦匹配成功,则忽略工程级的过滤条件;如果模块级的没有匹配成功,继续按工程级的条件进行匹配。 |
media
media是对资源目录下media目录的图片进行纹理压缩的配置参数。
表31 media
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| enable | 布尔值 | 可选 | 是否对media图片启用纹理压缩。 - true:启用。 - false(缺省默认值):不启用。 说明: - 在linux系统的构建场景下,请确认系统环境已安装libGL1库。 - 对图片进行纹理压缩会改变文件名称和内容,在分层图标以及二次编辑的场景下会引起图片显示异常,请进一步使用filters排除掉这部分文件。 |
filters
filters是文件过滤配置参数。
表32 filters
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| method | 对象 | 必选 | 纹理压缩的方式。 |
| files | 对象 | 可选 | 指定用来参与压缩的文件,与exclude字段配合使用。 |
| exclude | 对象 | 可选 | 从files中剔除掉不需要压缩的文件。 |
表33 method
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| type | 字符串 | 必选 | 转换类型。 - astc(Adaptive Scalable Texture Compression):自适应可变纹理压缩,一种对GPU友好的纹理格式,可在设备侧更快地显示,有更少的内存占用。 - sut(SUper compression for Texture) :纹理超压缩,可在设备侧更快地显示,有更少的内存占用,相比astc具备更大压缩率和更少ROM占用。 |
| blocks | 字符串 | 必选 | astc/sut转换类型的扩展参数,决定画质和压缩率,当前仅支持"4x4"。 |
表34 files
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| path | 字符串数组 | 可选 | 指定“按路径匹配”的过滤条件,符合glob规范,格式为相对路径。 |
| size | 二维数组 | 可选 | 指定“按大小匹配”的过滤条件,格式为[min,max],闭区间,表示大小从min到max之间的文件。 - 每个数值可以填数字、字符串或字符串中带单位(大小写均可),如[0, '1k']。 - 单位K/k=1024,M/m=1024*1024,G/g=1024*1024*1024,T/t=1024*1024*1024*1024。 - 区间最大值可省略,表示无限大,如['3K']。 |
| resolution | 二维数组 | 可选 | 指定“按分辨率匹配”的过滤条件,配置示例: resolution:[ [ { width:32, height:32 }, // 最小宽高 { width:64, height:64 }, // 最大宽高 ], // 分辨率在32*32到64*64之间的图片 [ { width:200, height:200 }, // 最小宽高 // 此处第2个不填表示最大宽高是无限大 ], // 分辨率大于200*200的图片 ] - width和height只能是数字。 - 最大宽高可以省略,表示无限大。 |
表35 exclude
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| path | 字符串数组 | 可选 | 同files/path。 |
| size | 二维数组 | 可选 | 同files/size。 |
| resolution | 二维数组 | 可选 | 同files/resolution。 |
compression字段示例:
"buildOption": {
"resOptions": {
"compression": {
"media": {
"enable": true // 是否对media图片启用纹理压缩
},
// 纹理压缩文件过滤,非必填,不填会压缩资源目录中的所有图片
"filters": [
{
"method": {
"type": "sut", // 转换类型
"blocks": "4x4" // 转换类型的扩展参数
},
// 指定用来参与压缩的文件,需要满足所有条件且不被exclude过滤的文件才会参与压缩
"files": {
"path": ["./**/*"], // 指定资源目录中的所有文件
"size": [[0, '10k']], // 指定大小10k以下的文件
// 指定分辨率小于2048*2048的图片
"resolution": [
[
{ "width": 0, "height": 0 }, // 最小宽高
{ "width": 2048, "height": 2048 } // 最大宽高
]
]
},
// 从files中剔除掉不需要压缩的文件,需要满足所有过滤条件的文件才会被剔除
"exclude": {
"path": ["./**/*.jpg"], // 过滤所有jpg文件
"size": [[0, '1k']], // 过滤大小1k以下的文件
// 过滤分辨率小于1024*1024的图片
"resolution": [
[
{ "width": 0, "height": 0 }, // 最小宽高
{ "width": 1024, "height": 1024 } // 最大宽高
]
]
}
}
]
}
}
}
buildModeBinder
buildModeBinder是构建模式(debug、release 等)与构建配置(buildOption)的关联配置。通过该配置可以将不同的构建配置和target进行组合,并绑定到对应的构建模式上。如果没有配置buildModeBinder,默认的绑定策略请参考合并编译选项规则。
表36 buildModeBinder
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| buildModeName | 字符串 | 可选 | 构建模式名称,需要在工程级别的buildModeSet中定义。 |
| mappings | 对象数组 | 可选 | target和buildOption之间的一对一映射关系。 |
表37 mappings
| 字段名称 | 类型 | 可选/必选 | 含义 |
|---|---|---|---|
| targetName | 字符串 | 可选 | target名称。 |
| buildOptionName | 字符串 | 可选 | 构建配置buildOption名称。 |
buildModeBinder字段示例:
"buildModeBinder": [
{
"buildModeName": "debug",
"mappings": [
{
"targetName": "default",
"buildOptionName": "release"
}
]
}
]