@buaa_smat/hometrans 0.1.12 → 0.1.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +164 -114
- package/agents/build-fixer.md +384 -394
- package/agents/code-reviewer.md +240 -240
- package/agents/logic-coder.md +199 -199
- package/agents/logic-context-builder.md +194 -194
- package/agents/review-fixer.md +405 -405
- package/agents/self-test-fixer.md +296 -296
- package/agents/self-tester.md +393 -392
- package/agents/spec-generator.md +540 -540
- package/dist/cli/config-store.js +84 -8
- package/dist/cli/config.js +3 -3
- package/dist/cli/env-vars.js +129 -0
- package/dist/cli/init.js +272 -272
- package/dist/cli/uninstall.js +152 -17
- package/dist/context/index.js +10 -197
- package/env-requirements.json +3 -3
- package/package.json +1 -1
- package/resource/choose_editor.png +0 -0
- package/resource/common_config.png +0 -0
- package/resource/integration_test_config.png +0 -0
- package/resource/set_env.png +0 -0
- package/resource/ui_align_config.png +0 -0
- package/skills/hmos-batch-ui-align/SKILL.md +108 -98
- package/skills/hmos-batch-ui-align/references/conversion-procedure.md +180 -180
- package/skills/hmos-batch-ui-align/references/mappings/android-to-harmonyOS-ui-atomic-component-mapping-reference.md +2533 -2533
- package/skills/hmos-batch-ui-align/references/mappings/android-to-harmonyOS-ui-interaction-mapping-reference.md +555 -555
- package/skills/hmos-batch-ui-align/references/mappings/android-to-harmonyOS-ui-layout-mapping-reference.md +117 -117
- package/skills/hmos-batch-ui-align/references/mvvm/@Link/350/243/205/351/245/260/345/231/250/357/274/232/347/210/266/345/255/220/345/217/214/345/220/221/345/220/214/346/255/245.md +648 -648
- package/skills/hmos-batch-ui-align/references/mvvm/@Observed/350/243/205/351/245/260/345/231/250/345/222/214@ObjectLink/350/243/205/351/245/260/345/231/250/357/274/232/345/265/214/345/245/227/347/261/273/345/257/271/350/261/241/345/261/236/346/200/247/345/217/230/345/214/226.md +2088 -2088
- package/skills/hmos-batch-ui-align/references/mvvm/@Prop/350/243/205/351/245/260/345/231/250/357/274/232/347/210/266/345/255/220/345/215/225/345/220/221/345/220/214/346/255/245.md +1033 -1033
- package/skills/hmos-batch-ui-align/references/mvvm/@Provide/350/243/205/351/245/260/345/231/250/345/222/214@Consume/350/243/205/351/245/260/345/231/250/357/274/232/344/270/216/345/220/216/344/273/243/347/273/204/344/273/266/345/217/214/345/220/221/345/220/214/346/255/245.md +1183 -1183
- package/skills/hmos-batch-ui-align/references/mvvm/@State/350/243/205/351/245/260/345/231/250/357/274/232/347/273/204/344/273/266/345/206/205/347/212/266/346/200/201.md +576 -576
- package/skills/hmos-batch-ui-align/references/mvvm/@Track/350/243/205/351/245/260/345/231/250/357/274/232class/345/257/271/350/261/241/345/261/236/346/200/247/347/272/247/346/233/264/346/226/260.md +297 -297
- package/skills/hmos-batch-ui-align/references/mvvm/@Watch/350/243/205/351/245/260/345/231/250/357/274/232/347/212/266/346/200/201/345/217/230/351/207/217/346/233/264/346/224/271/351/200/232/347/237/245.md +395 -395
- package/skills/hmos-batch-ui-align/references/mvvm/AppStorage/357/274/232/345/272/224/347/224/250/345/205/250/345/261/200/347/232/204UI/347/212/266/346/200/201/345/255/230/345/202/250.md +902 -902
- package/skills/hmos-batch-ui-align/references/mvvm/Environment/357/274/232/350/256/276/345/244/207/347/216/257/345/242/203/346/237/245/350/257/242.md +106 -106
- package/skills/hmos-batch-ui-align/references/mvvm/LocalStorage/357/274/232/351/241/265/351/235/242/347/272/247UI/347/212/266/346/200/201/345/255/230/345/202/250.md +1178 -1178
- package/skills/hmos-batch-ui-align/references/mvvm/MVVM/346/250/241/345/274/217/357/274/210V1/357/274/211.md +911 -911
- package/skills/hmos-batch-ui-align/references/mvvm/PersistentStorage/357/274/232/346/214/201/344/271/205/345/214/226/345/255/230/345/202/250UI/347/212/266/346/200/201.md +354 -354
- package/skills/hmos-batch-ui-align/references/mvvm//347/256/241/347/220/206/345/272/224/347/224/250/346/213/245/346/234/211/347/232/204/347/212/266/346/200/201/346/246/202/350/277/260.md +11 -11
- package/skills/hmos-convert-pipeline/SKILL.md +429 -415
- package/skills/hmos-fix-build-errors/SKILL.md +272 -273
- package/skills/hmos-fix-build-errors/references/arkts-strict-patterns.md +219 -219
- package/skills/hmos-fix-build-errors/references/known-patterns.md +157 -157
- package/skills/hmos-fix-build-errors/references/rdb-entity-pattern.md +131 -131
- package/skills/hmos-incremental-ui-align/SKILL.md +219 -200
- package/skills/hmos-incremental-ui-align/diff_analysis.md +52 -52
- package/skills/hmos-incremental-ui-align/page_align.md +62 -62
- package/skills/hmos-incremental-ui-align/readme.md +237 -230
- package/skills/hmos-incremental-ui-align/references/Comparison_Template.md +2 -2
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Link/350/243/205/351/245/260/345/231/250/357/274/232/347/210/266/345/255/220/345/217/214/345/220/221/345/220/214/346/255/245.md +648 -648
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Observed/350/243/205/351/245/260/345/231/250/345/222/214@ObjectLink/350/243/205/351/245/260/345/231/250/357/274/232/345/265/214/345/245/227/347/261/273/345/257/271/350/261/241/345/261/236/346/200/247/345/217/230/345/214/226.md +2088 -2088
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Prop/350/243/205/351/245/260/345/231/250/357/274/232/347/210/266/345/255/220/345/215/225/345/220/221/345/220/214/346/255/245.md +1033 -1033
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Provide/350/243/205/351/245/260/345/231/250/345/222/214@Consume/350/243/205/351/245/260/345/231/250/357/274/232/344/270/216/345/220/216/344/273/243/347/273/204/344/273/266/345/217/214/345/220/221/345/220/214/346/255/245.md +1183 -1183
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@State/350/243/205/351/245/260/345/231/250/357/274/232/347/273/204/344/273/266/345/206/205/347/212/266/346/200/201.md +576 -576
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Track/350/243/205/351/245/260/345/231/250/357/274/232class/345/257/271/350/261/241/345/261/236/346/200/247/347/272/247/346/233/264/346/226/260.md +297 -297
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Watch/350/243/205/351/245/260/345/231/250/357/274/232/347/212/266/346/200/201/345/217/230/351/207/217/346/233/264/346/224/271/351/200/232/347/237/245.md +395 -395
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/AppStorage/357/274/232/345/272/224/347/224/250/345/205/250/345/261/200/347/232/204UI/347/212/266/346/200/201/345/255/230/345/202/250.md +902 -902
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/Environment/357/274/232/350/256/276/345/244/207/347/216/257/345/242/203/346/237/245/350/257/242.md +106 -106
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/LocalStorage/357/274/232/351/241/265/351/235/242/347/272/247UI/347/212/266/346/200/201/345/255/230/345/202/250.md +1178 -1178
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/MVVM/346/250/241/345/274/217V1.md +911 -911
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/PersistentStorage/357/274/232/346/214/201/344/271/205/345/214/226/345/255/230/345/202/250UI/347/212/266/346/200/201.md +354 -354
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243//347/256/241/347/220/206/345/272/224/347/224/250/346/213/245/346/234/211/347/232/204/347/212/266/346/200/201/346/246/202/350/277/260.md +11 -11
- package/skills/hmos-incremental-ui-align/references/UI_Analysis_Template.md +3 -3
- package/skills/hmos-incremental-ui-align/references/android-to-harmonyOS-ui-atomic-component-mapping-reference.md +2533 -2533
- package/skills/hmos-incremental-ui-align/references/android-to-harmonyOS-ui-interaction-mapping-reference.md +555 -555
- package/skills/hmos-incremental-ui-align/references/android-to-harmonyOS-ui-layout-mapping-reference.md +117 -117
- package/skills/hmos-incremental-ui-align/scripts/navigation-capure.md +37 -37
- package/skills/hmos-integration-test/SKILL.md +380 -369
- package/skills/hmos-integration-test/readme.md +309 -309
- package/skills/hmos-resources-convert/SKILL.md +623 -623
- package/skills/hmos-resources-convert/references/conversion-rules.md +663 -663
- package/skills/hmos-resources-convert/references/dependency-analysis-rules.md +388 -388
- package/skills/hmos-resources-convert/references/resource-mapping-rules.md +457 -457
- package/skills/hmos-resources-convert/references/xml-drawable-to-svg-rules.md +513 -513
- package/skills/hmos-spec-generate/SKILL.md +331 -331
- package/skills/hmos-spec-generate/references/android-platform-tokens.md +105 -105
- package/skills/hmos-spec-generate/references/spec-sample-1.md +78 -78
- package/skills/hmos-spec-generate/references/spec-sample-2.md +58 -58
- package/skills/hmos-spec-generate/references/spec-sample-3.md +116 -116
- package/skills/hmos-spec-generate/references/step4-report-template.md +33 -33
- package/tools/test-tools/autotest/README.md +33 -17
- package/tools/test-tools/autotest/self_test_runner.py +109 -15
- package/resource/hometrans_config.png +0 -0
- package/skills/hmos-incremental-ui-align/config-example.json +0 -11
- package/tools/test-tools/autotest/config.yaml.example +0 -58
package/README.md
CHANGED
|
@@ -1,23 +1,21 @@
|
|
|
1
1
|
# 安卓应用迁移鸿蒙指导
|
|
2
2
|
|
|
3
|
-
[English](README.en.md) · **简体中文**
|
|
4
3
|
|
|
5
4
|
[](LICENSE)
|
|
6
|
-

|
|
7
5
|
|
|
8
|
-
本文档为完整的
|
|
6
|
+
本文档为完整的Android到HarmonyOS迁移流程指导。
|
|
9
7
|
|
|
10
8
|
---
|
|
11
9
|
|
|
12
|
-
## 步骤
|
|
10
|
+
## 步骤0:安装依赖
|
|
13
11
|
|
|
14
|
-
### 0.1
|
|
12
|
+
### 0.1安装依赖并连接设备
|
|
15
13
|
|
|
16
|
-
按以下顺序安装(`ht init` 会逐项检测,并提示缺失项对各
|
|
14
|
+
按以下顺序安装(`ht init` 会逐项检测,并提示缺失项对各skill的影响)。各依赖下方均列出了「被依赖」的步骤:如果你不需要执行某依赖所对应的步骤,则可以不安装该依赖(相应skill会显示为受限或不可用,但不影响其它步骤)。
|
|
17
15
|
|
|
18
|
-
1. **安装
|
|
16
|
+
1. **安装DevEco Studio** — 下载地址:<https://developer.huawei.com/consumer/cn/download/>。安装完成后,配置以下 **PATH环境变量**(`<DevEco安装目录>` 指DevEco Studio的安装根目录):
|
|
19
17
|
|
|
20
|
-
| 工具 | PATH
|
|
18
|
+
| 工具 | PATH中加入的目录 |
|
|
21
19
|
|------|------------------|
|
|
22
20
|
| node / npm / npx | `<DevEco安装目录>\tools\node` |
|
|
23
21
|
| java | `<DevEco安装目录>\jbr\bin` |
|
|
@@ -26,113 +24,138 @@
|
|
|
26
24
|
验证方式:执行 `node -v`、`java -version`、`hdc -v` 均返回正常
|
|
27
25
|
|
|
28
26
|
被依赖:
|
|
29
|
-
- 步骤
|
|
30
|
-
- 步骤
|
|
31
|
-
- 步骤
|
|
32
|
-
- 步骤
|
|
33
|
-
2. **安装
|
|
27
|
+
- 步骤1资源转换(java可选,缺失时回退读取源码 `res/`)
|
|
28
|
+
- 步骤2.2增量UI对齐(必需)
|
|
29
|
+
- 步骤4逻辑代码转换流水线(必需,构建/评审修复)
|
|
30
|
+
- 步骤5自测回归(必需,真机调试)
|
|
31
|
+
2. **安装Android Studio** — 下载地址:<https://developer.android.com/studio>,并在 **SDK Manager** 中安装SDK。
|
|
34
32
|
|
|
35
33
|
验证方式:执行 `adb version` 返回正常
|
|
36
34
|
|
|
37
35
|
被依赖:
|
|
38
|
-
- 步骤
|
|
39
|
-
- 步骤
|
|
40
|
-
3. **安装
|
|
36
|
+
- 步骤2.1全量UI迁移(可选,仅自动抓取页面快照时需要)
|
|
37
|
+
- 步骤2.2增量UI对齐(必需)
|
|
38
|
+
3. **安装uv** — 安装指引:<https://docs.astral.sh/uv/getting-started/installation/>。
|
|
41
39
|
|
|
42
40
|
验证方式:执行 `uv --version` 返回正常
|
|
43
41
|
|
|
44
42
|
被依赖:
|
|
45
|
-
- 步骤
|
|
46
|
-
- 步骤
|
|
47
|
-
4. **安装
|
|
43
|
+
- 步骤4逻辑代码转换流水线的自测阶段(可经 `skip_test` 跳过)
|
|
44
|
+
- 步骤5自测回归(必需,AutoTest在uv下运行)
|
|
45
|
+
4. **安装python** — 安装指引:<https://www.python.org/downloads/>,要求 ≥ 3.10。
|
|
48
46
|
|
|
49
47
|
验证方式:执行 `python --version` 返回正常
|
|
50
48
|
|
|
51
49
|
被依赖:
|
|
52
|
-
- 步骤
|
|
53
|
-
- 步骤
|
|
50
|
+
- 步骤2.1全量UI迁移(必需,页面快照解析脚本)
|
|
51
|
+
- 步骤2.2增量UI对齐(必需,双端页面采集脚本)
|
|
54
52
|
5. **安装 [GitNexus](https://github.com/abhigyanpatwari/GitNexus)** — 执行 `npm install -g gitnexus && gitnexus setup`
|
|
55
53
|
|
|
56
54
|
验证方式:执行 `gitnexus --version` 返回正常
|
|
57
55
|
|
|
58
56
|
被依赖:
|
|
59
|
-
- 步骤
|
|
57
|
+
- 步骤3生成需求规格(必需)
|
|
60
58
|
6. **连接设备** — 连接安卓和鸿蒙真机,或启动模拟器
|
|
61
59
|
|
|
62
60
|
被依赖:
|
|
63
|
-
- 安卓真机/模拟器 — 步骤
|
|
64
|
-
- 鸿蒙真机/模拟器 — 步骤
|
|
65
|
-
- 鸿蒙**真机** — 步骤
|
|
61
|
+
- 安卓真机/模拟器 — 步骤2 UI迁移
|
|
62
|
+
- 鸿蒙真机/模拟器 — 步骤2.2增量UI对齐
|
|
63
|
+
- 鸿蒙**真机** — 步骤4流水线自测阶段、步骤5自测回归
|
|
66
64
|
|
|
67
|
-
### 0.2
|
|
65
|
+
### 0.2安装hometrans
|
|
68
66
|
|
|
69
67
|
执行 `npm install -g @buaa_smat/hometrans`。
|
|
70
68
|
|
|
71
69
|
验证方式:执行 `hometrans --version` 或 `ht --version` 返回正常
|
|
72
70
|
|
|
73
|
-
然后执行 `hometrans init` 或 `ht init
|
|
71
|
+
然后执行 `hometrans init` 或 `ht init`。
|
|
74
72
|
|
|
75
73
|
|
|
76
|
-
> 如果在
|
|
74
|
+
> 如果在PowerShell下运行,命令需要加上 `.cmd` 后缀,如 `hometrans.cmd --version`、`ht.cmd init`。
|
|
77
75
|
|
|
78
|
-
选择本地
|
|
76
|
+
### 0.2.1选择本地editor:
|
|
77
|
+

|
|
79
78
|
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-

|
|
85
|
-
|
|
86
|
-
- `DEVECO_SDK_HOME` — DevEco Studio 的 sdk 目录(唯一输入),其余路径由它派生并校验存在,示例:
|
|
79
|
+
### 0.2.2通用配置:
|
|
80
|
+

|
|
81
|
+
- `DEVECO_SDK_HOME` — DevEco Studio的sdk目录,其余路径由它派生并校验存在。示例:
|
|
87
82
|
|
|
88
83
|
```text
|
|
89
84
|
+ DEVECO_SDK_HOME : <DevEco安装目录>\sdk
|
|
90
|
-
+
|
|
85
|
+
+ DEVECO_HOME : <DevEco安装目录>
|
|
91
86
|
+ OHOS_SDK_PATH : <DevEco安装目录>\sdk\default\openharmony\ets
|
|
92
87
|
+ HMS_SDK_PATH : <DevEco安装目录>\sdk\default\hms\ets
|
|
93
88
|
```
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
- `GLM_API_KEY` — UI对齐中过程中GLM phone agent
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
89
|
+
### 0.2.3 UI对齐配置(如果不执行步骤2.2增量UI对齐,则可以不配置):
|
|
90
|
+

|
|
91
|
+
- `GLM_API_KEY` — UI对齐中过程中GLM phone agent所用的LLM API key。
|
|
92
|
+
|
|
93
|
+
申请方式:在[智谱官方网站](https://bigmodel.cn/apikey/platform)注册用户后,申请一个API KEY即可,调用的是免费的auto-glm模型,无需充值。
|
|
94
|
+
|
|
95
|
+
### 0.2.4集成测试配置(如果不执行步骤4的自测阶段与步骤5自测回归,则可以不配置):
|
|
96
|
+

|
|
97
|
+
- `autotest api_key` — 集成测试agent执行测试用例(真机自测)所用的多模态大模型API key。各配置项含义如下,`init` 环节只配置前4项,其余参数在`config.json`中配置。
|
|
98
|
+
|
|
99
|
+
| 参数 | 示例 / 默认值 | 含义 |
|
|
100
|
+
|-------------------|--------------|------|
|
|
101
|
+
| `name` | `""` | 多模态(视觉)模型的名字 |
|
|
102
|
+
| `base_url` | `""` | 模型API服务的基础地址 |
|
|
103
|
+
| `api_key` | (需填写) | 用于模型API请求认证的令牌 |
|
|
104
|
+
| `provider` | `openai` | 模型API服务的提供方标识,如openai;Azure服务填azure |
|
|
105
|
+
| `temperature` | `0.1` | 采样温度 |
|
|
106
|
+
| `top_p` | `0.9` | 核采样阈值 |
|
|
107
|
+
| `frequency_penalty` | `0.5` | 重复惩罚 |
|
|
108
|
+
| `device_sn` | `null` | 设备序列号;`null` 表示自动选用当前连接的设备 |
|
|
109
|
+
| `ip` | `127.0.0.1` | 设备连接IP(hdc) |
|
|
110
|
+
| `port` | `8710` | 设备连接端口(hdc) |
|
|
111
|
+
| `device_log_level` | `debug` | 设备日志级别:debug/info/... |
|
|
112
|
+
| `max_steps` | `50` | 单条用例最大执行步数 |
|
|
113
|
+
| `verbose` | `true` | 是否输出详细日志 |
|
|
114
|
+
| `lang` | `zh` | 输出语言:zh/en |
|
|
115
|
+
| `enable_preprocess` | `false` | 执行前是否先用unified_model把用例拆成步骤序列(多一次LLM调用,默认关) |
|
|
116
|
+
| `debug_mode` | `null` | 调试会话:`null` 关闭 / `memory` 内存 / `file` 存盘并跑完后起调试服务(:5000) |
|
|
117
|
+
|
|
118
|
+
### 0.2.5将配置信息添加到环境变量:
|
|
119
|
+

|
|
120
|
+
|
|
121
|
+
### 0.3准备项目
|
|
122
|
+
|
|
123
|
+
准备 **Android源项目** 与 **HarmonyOS目标项目目录**。
|
|
101
124
|
|
|
102
125
|
---
|
|
103
126
|
|
|
104
|
-
## 步骤
|
|
127
|
+
## 步骤1:资源转换(`hmos-resources-convert`)
|
|
105
128
|
|
|
106
|
-
> 📦 依赖:DevEco Studio
|
|
129
|
+
> 📦 依赖:DevEco Studio中的java(可选,缺失时回退读取源码 `res/`)。
|
|
107
130
|
|
|
108
|
-
> ⚠️ 提示:如果步骤
|
|
131
|
+
> ⚠️ 提示:如果步骤2的UI迁移采用**全量迁移**(`hmos-batch-ui-align`),则跳过当前步骤(全量UI迁移内部已包含资源转换)。
|
|
109
132
|
|
|
110
133
|
```
|
|
111
|
-
/hmos-resources-convert
|
|
134
|
+
/hmos-resources-convert android_project_dir=<安卓项目路径> harmony_project_dir=<鸿蒙项目路径> resource_mapping_path=<资源映射文档路径>
|
|
112
135
|
```
|
|
113
136
|
|
|
114
137
|
**输入参数**
|
|
115
138
|
|
|
116
139
|
| 参数 | 类型 | 说明 |
|
|
117
140
|
|------|------|------|
|
|
118
|
-
| `
|
|
119
|
-
| `
|
|
120
|
-
| `resource_mapping_path` | **必选** | Android ↔ HarmonyOS
|
|
121
|
-
| `
|
|
141
|
+
| `android_project_dir` | **必选** | Android项目根目录路径(含 `build.gradle` 或 `build.gradle.kts`) |
|
|
142
|
+
| `harmony_project_dir` | **必选** | HarmonyOS项目输出路径 |
|
|
143
|
+
| `resource_mapping_path` | **必选** | Android ↔ HarmonyOS资源映射文档的完整输出路径(`.md`) |
|
|
144
|
+
| `apk_path` | 可选 | Android APK文件路径;提供后跳过Gradle构建和apktool解包,直接从APK提取资源 |
|
|
122
145
|
|
|
123
146
|
**输出产物**
|
|
124
147
|
|
|
125
148
|
| 产物 | 位置 | 说明 |
|
|
126
149
|
|------|------|------|
|
|
127
|
-
| `resources/` 目录 | HarmonyOS
|
|
128
|
-
| 资源映射文档 | `resource_mapping_path` | Android ↔ HarmonyOS
|
|
129
|
-
| 转换报告 | HarmonyOS
|
|
150
|
+
| `resources/` 目录 | HarmonyOS项目下 | 转换后的HarmonyOS资源(strings、colors、dimensions、images等) |
|
|
151
|
+
| 资源映射文档 | `resource_mapping_path` | Android ↔ HarmonyOS资源条目映射(`.md`) |
|
|
152
|
+
| 转换报告 | HarmonyOS项目下 | 资源转换过程与统计 |
|
|
130
153
|
|
|
131
154
|
---
|
|
132
155
|
|
|
133
|
-
## 步骤
|
|
156
|
+
## 步骤2:UI迁移
|
|
134
157
|
|
|
135
|
-
### 2.1
|
|
158
|
+
### 2.1全量迁移(`hmos-batch-ui-align`)
|
|
136
159
|
|
|
137
160
|
> 📦 依赖:python(必需,页面快照解析脚本);Android Studio + 安卓真机/模拟器(可选,仅自动抓取页面快照时需要)。
|
|
138
161
|
|
|
@@ -144,97 +167,124 @@
|
|
|
144
167
|
|
|
145
168
|
| 参数 | 类型 | 说明 |
|
|
146
169
|
|------|------|-------------------------------------------------------------------------------------------------------------|
|
|
147
|
-
| `android_project_dir` | **必选** | Android
|
|
148
|
-
| `harmony_project_dir` | **必选** | HarmonyOS
|
|
149
|
-
| `ui_info_root` | 可选 | 包含 `page_NNNN_ActivityName` 格式子目录的父目录(每子目录含 `meta.json` + `view.xml` + 可选 `screenshot.png`);不提供时自动通过
|
|
170
|
+
| `android_project_dir` | **必选** | Android项目根目录路径 |
|
|
171
|
+
| `harmony_project_dir` | **必选** | HarmonyOS项目输出路径 |
|
|
172
|
+
| `ui_info_root` | 可选 | 包含 `page_NNNN_ActivityName` 格式子目录的父目录(每子目录含 `meta.json` + `view.xml` + 可选 `screenshot.png`);不提供时自动通过adb抓取 |
|
|
150
173
|
| `pages` | 可选 | 显式列出的页面子集(不提供则处理所有页面) |
|
|
151
174
|
|
|
152
175
|
**输出产物**
|
|
153
176
|
|
|
154
177
|
| 产物 | 位置 | 说明 |
|
|
155
178
|
|------|------|------|
|
|
156
|
-
| ArkTS
|
|
157
|
-
| 资源文件 | HarmonyOS
|
|
158
|
-
| 批量转换报告 | HarmonyOS
|
|
179
|
+
| ArkTS页面文件 | HarmonyOS项目下 | 由Android Activity转换生成的ArkTS页面 |
|
|
180
|
+
| 资源文件 | HarmonyOS项目下 | 页面所需资源(含全量迁移内部触发的资源转换产物) |
|
|
181
|
+
| 批量转换报告 | HarmonyOS项目下 | 各页面转换结果、缺陷与统计 |
|
|
159
182
|
|
|
160
|
-
### 2.2
|
|
183
|
+
### 2.2增量对齐(`hmos-incremental-ui-align`,按需)
|
|
161
184
|
|
|
162
185
|
> 📦 依赖:DevEco Studio、Android Studio、python(必需,双端页面采集脚本);安卓真机/模拟器 + 鸿蒙真机/模拟器(必需)。
|
|
163
186
|
|
|
164
|
-
> 👤 前置:需用户预先配置好 `config.json`(双端 app 包名/工程路径等,参考 skill 目录下 `config-example.json`;`ht init` 已预置并填充 `glm_api_key` / `hmos_sdk_dir`)。对齐目标在消息中描述,如 "帮我对齐设置页面的关于页面"。
|
|
165
|
-
|
|
166
187
|
```
|
|
167
|
-
/hmos-incremental-ui-align
|
|
188
|
+
/hmos-incremental-ui-align android_project_dir=<安卓工程路径> harmony_project_dir=<鸿蒙工程路径>
|
|
168
189
|
```
|
|
169
190
|
|
|
170
191
|
**输入参数**
|
|
171
192
|
|
|
172
193
|
| 参数 | 类型 | 说明 |
|
|
173
194
|
|------|------|------|
|
|
174
|
-
| `
|
|
195
|
+
| `android_project_dir` | 必填 | 安卓源码根目录;用于自动解析安卓app名/包名 |
|
|
196
|
+
| `harmony_project_dir` | 必填 | 鸿蒙工程根目录(会被直接修改);用于自动解析鸿蒙app名/包名 |
|
|
197
|
+
| `capture_output_dir` | 可选 | 采集产物输出目录,默认 `<harmony_project_dir>/.hometrans/capture_output` |
|
|
175
198
|
|
|
176
199
|
**输出产物**
|
|
177
200
|
|
|
178
201
|
| 产物 | 位置 | 说明 |
|
|
179
202
|
|------|------|------|
|
|
180
|
-
| 修改后的
|
|
181
|
-
| 双端页面截图与视图树 | `capture_output_dir` | Android/HarmonyOS
|
|
203
|
+
| 修改后的ArkTS页面文件 | HarmonyOS项目下 | 对齐目标页面后的代码改动 |
|
|
204
|
+
| 双端页面截图与视图树 | `capture_output_dir` | Android/HarmonyOS两侧 `screenshot.png` + 视图树文件 |
|
|
182
205
|
| 对齐差异/修复报告 | `capture_output_dir` | 差异分析与修复说明 |
|
|
183
206
|
|
|
184
207
|
---
|
|
185
208
|
|
|
186
|
-
## 步骤
|
|
209
|
+
## 步骤3:生成需求规格(`hmos-spec-generate`)
|
|
187
210
|
|
|
188
211
|
> 📦 依赖:GitNexus(必需)。
|
|
189
212
|
|
|
190
|
-
> 👤 前置:用户编写 REQ
|
|
213
|
+
> 👤 前置:用户编写 `REQ.txt` 文件 — 以自然语言描述原始需求,如有多个需求则在文件中使用空行进行分隔,需求中建议包含页面跳转路径的说明以及业务逻辑的描述。
|
|
214
|
+
|
|
215
|
+
`REQ.txt` 示例:
|
|
216
|
+
|
|
217
|
+
```text
|
|
218
|
+
设置-歌词-歌词界面-卡拉OK歌词动画兼容策略(播放页歌词设置同步实现)
|
|
219
|
+
逐字歌词效果,默认是当前行
|
|
220
|
+
1,当前行:只为前歌曲的歌词中有单字时间戳的歌词行显示逐字特效
|
|
221
|
+
2,扩展全部:当前歌曲的歌词中只要有一行歌词带单字时间戳,所有歌词行都显示逐字特效
|
|
222
|
+
3,总是:当前歌曲所有歌词行都显示逐字特效
|
|
223
|
+
|
|
224
|
+
设置-用户界面-圆形播放封面(圆形支持旋转)
|
|
225
|
+
开关,默认关闭,打开后,在播放页以圆形展示封面,并且自动旋转
|
|
226
|
+
|
|
227
|
+
设置-用户界面-允许不规则封面(支持长方形封面,参考无归)
|
|
228
|
+
开关,默认打开,播放页封面以大小一致的正方形展示,打开后,在播放页封面以原始样式展示
|
|
229
|
+
|
|
230
|
+
设置-歌词-悬浮窗状态栏歌词
|
|
231
|
+
开关 ,默认关闭,打开前需要申请悬浮窗权限,打开后在悬浮窗滚动展示歌词
|
|
232
|
+
1,左右位置:默认0%
|
|
233
|
+
2,上下位置:默认0px
|
|
234
|
+
3,宽度:默认150dp
|
|
235
|
+
4,大小:默认14.0dp
|
|
236
|
+
5,选择颜色:默认蓝色
|
|
237
|
+
6,歌词文本居左对齐:开关 默认关闭,歌词在设置的宽度内中对齐
|
|
238
|
+
7,状态栏歌词不显示翻译:开关 默认关闭
|
|
239
|
+
8,在播放界面隐藏:开关 默认关闭 打开后如果切换到播放页,则不在悬浮窗区域显示歌词
|
|
240
|
+
```
|
|
191
241
|
|
|
192
242
|
```
|
|
193
|
-
/hmos-spec-generate
|
|
243
|
+
/hmos-spec-generate requirement_description_file=<需求描述文件路径> android_project_dir=<安卓项目路径> spec_output_dir=<规格输出目录>
|
|
194
244
|
```
|
|
195
245
|
|
|
196
246
|
**输入参数**
|
|
197
247
|
|
|
198
248
|
| 参数 | 类型 | 说明 |
|
|
199
249
|
|------|------|------|
|
|
200
|
-
| `
|
|
201
|
-
| `
|
|
202
|
-
| `
|
|
250
|
+
| `requirement_description_file` | **必选** | 需求描述 `.txt` 文件路径(每段以 `REQ` 开头,空行分隔) |
|
|
251
|
+
| `android_project_dir` | **必选** | Android项目根目录路径(必须位于Git仓库内) |
|
|
252
|
+
| `spec_output_dir` | **必选** | 规格文档输出目录(自动创建;每个REQ生成 `<feature>-SPEC.md` + `.trace/<feature>.md`) |
|
|
203
253
|
|
|
204
254
|
**输出产物**
|
|
205
255
|
|
|
206
256
|
| 产物 | 位置 | 说明 |
|
|
207
257
|
|------|------|------|
|
|
208
|
-
| `<feature>-SPEC.md` | `
|
|
209
|
-
| `.trace/<feature>.md` | `
|
|
258
|
+
| `<feature>-SPEC.md` | `spec_output_dir` | 每个REQ对应一份原子场景规格文档 |
|
|
259
|
+
| `.trace/<feature>.md` | `spec_output_dir/.trace/` | 每个REQ对应的代码trace(GitNexus探索结果) |
|
|
210
260
|
|
|
211
261
|
---
|
|
212
262
|
|
|
213
|
-
## 步骤
|
|
263
|
+
## 步骤4:逻辑代码转换流水线(`hmos-convert-pipeline`)
|
|
214
264
|
|
|
215
|
-
> 📦 依赖:DevEco Studio(必需,构建/评审修复);uv + 鸿蒙真机(
|
|
265
|
+
> 📦 依赖:DevEco Studio(必需,构建/评审修复);uv + 鸿蒙真机(集成测试阶段需要,可经 `skip_test` 跳过)。
|
|
216
266
|
|
|
217
267
|
> 👤 前置:
|
|
218
|
-
> 1.
|
|
219
|
-
> 2.
|
|
268
|
+
> 1. 如果执行集成测试,需要**编写测试用例文档**输出前置测试用例(非必须,用于测试用例的环境准备等)通过pre_test_case_path参数传递,测试用例通过test_case_path参数传递。
|
|
269
|
+
> 2. 如果执行集成测试,需要**连接HarmonyOS真机**并且在DevEco Studio中[**配置签名**](https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/networkboost-preparations#%E9%85%8D%E7%BD%AE%E7%AD%BE%E5%90%8D)。
|
|
220
270
|
|
|
221
271
|
```
|
|
222
|
-
/hmos-convert-pipeline
|
|
272
|
+
/hmos-convert-pipeline android_project_dir=<安卓项目路径> harmony_project_dir=<鸿蒙项目路径> spec_file_path=<需求规格文档路径>
|
|
223
273
|
```
|
|
224
274
|
|
|
225
275
|
**输入参数**
|
|
226
276
|
|
|
227
277
|
| 参数 | 类型 | 说明 |
|
|
228
278
|
|------|------|------|
|
|
229
|
-
| `
|
|
230
|
-
| `
|
|
231
|
-
| `
|
|
232
|
-
| `
|
|
233
|
-
| `
|
|
234
|
-
| `
|
|
235
|
-
| `
|
|
236
|
-
| `
|
|
237
|
-
| `
|
|
279
|
+
| `android_project_dir` | **必选** | Android项目根目录路径 |
|
|
280
|
+
| `harmony_project_dir` | **必选** | HarmonyOS项目根目录路径 |
|
|
281
|
+
| `spec_file_path` | **必选** | 需求规格文档路径(各阶段直接读取,无需复制到输出目录) |
|
|
282
|
+
| `assets_output_path` | 可选 | 输出/报告文件存放目录(默认鸿蒙工程下 `.hometrans`,自动创建) |
|
|
283
|
+
| `test_case_path` | 可选 | 自测用例文件路径(默认读输出目录下 `test_case.md`;不存在则跳过自测循环) |
|
|
284
|
+
| `pre_test_case_path` | 可选 | 前置用例文件路径(默认读输出目录下 `pre_test_case.md`;存在才传给自测) |
|
|
285
|
+
| `max_rounds_review` | 可选 | 代码检视循环最大轮数(正整数 `>= 1`,默认 `2`) |
|
|
286
|
+
| `max_rounds_test` | 可选 | 自测循环最大轮数(正整数 `>= 1`,默认 `2`) |
|
|
287
|
+
| `skip_test` | 可选 | `true` 跳过集成测试阶段(无真机验证环境时设为 `true`,默认 `false`) |
|
|
238
288
|
|
|
239
289
|
> 参数按位置传递:要传某个可选参数,需先显式给出它前面的所有可选参数。
|
|
240
290
|
|
|
@@ -242,57 +292,57 @@
|
|
|
242
292
|
|
|
243
293
|
| 产物 | 位置 | 说明 |
|
|
244
294
|
|------|------|------|
|
|
245
|
-
| 已签名
|
|
246
|
-
| `pipeline-manifest.md` | `
|
|
247
|
-
| 构建阶段报告 | `
|
|
248
|
-
| 评审阶段报告 | `
|
|
249
|
-
| 自测阶段报告 | `
|
|
295
|
+
| 已签名HAP | HarmonyOS项目下 `build/` | 通过自测/评审循环后的最终发布包 |
|
|
296
|
+
| `pipeline-manifest.md` | `assets_output_path` | 流水线清单:阶段耗时、轮数、缺陷统计 |
|
|
297
|
+
| 构建阶段报告 | `assets_output_path` | 编译错误与修复记录 |
|
|
298
|
+
| 评审阶段报告 | `assets_output_path` | 代码检视报告与修复记录 |
|
|
299
|
+
| 自测阶段报告 | `assets_output_path` | 测试结果、失败用例与修复记录 |
|
|
250
300
|
|
|
251
301
|
---
|
|
252
302
|
|
|
253
|
-
## 步骤
|
|
303
|
+
## 步骤5:集成测试(`hmos-integration-test`,已包含在步骤4,也可以单独运行)
|
|
254
304
|
|
|
255
|
-
> 📦 依赖:DevEco Studio(必需,真机调试);uv(必需,AutoTest
|
|
305
|
+
> 📦 依赖:DevEco Studio(必需,真机调试);uv(必需,AutoTest在uv下运行);鸿蒙真机(必需)。
|
|
256
306
|
|
|
257
307
|
```
|
|
258
|
-
/hmos-integration-test
|
|
308
|
+
/hmos-integration-test test_case_path=<测试用例路径> hap_path=<签名HAP路径>
|
|
259
309
|
```
|
|
260
310
|
|
|
261
311
|
**输入参数**
|
|
262
312
|
|
|
263
313
|
| 参数 | 类型 | 说明 |
|
|
264
314
|
|------|------|------|
|
|
265
|
-
| `
|
|
266
|
-
| `
|
|
267
|
-
| `
|
|
268
|
-
| `
|
|
269
|
-
| `
|
|
270
|
-
| `
|
|
315
|
+
| `test_case_path` | **必选** | `test_case.md` 测试用例文件路径 |
|
|
316
|
+
| `hap_path` | **必选** | 已签名的HAP文件路径 |
|
|
317
|
+
| `output_path` | 可选 | 报告输出目录 |
|
|
318
|
+
| `pre_test_case_path` | 可选 | 前置用例文件路径 |
|
|
319
|
+
| `android_project_dir` | 可选 | Android项目路径(修复时参考) |
|
|
320
|
+
| `max_rounds` | 可选 | 测试-修复循环最大轮数(默认 `3`) |
|
|
271
321
|
|
|
272
322
|
**输出产物**
|
|
273
323
|
|
|
274
324
|
| 产物 | 位置 | 说明 |
|
|
275
325
|
|------|------|------|
|
|
276
|
-
| 测试报告 | `
|
|
277
|
-
| 失败用例详情 | `
|
|
278
|
-
| 修复建议 | `
|
|
326
|
+
| 测试报告 | `output_path` | 测试结果、通过/失败用例统计 |
|
|
327
|
+
| 失败用例详情 | `output_path` | 失败用例的复现步骤与日志 |
|
|
328
|
+
| 修复建议 | `output_path` | 针对失败用例的修复方向(进入测试-修复循环时生效) |
|
|
279
329
|
|
|
280
330
|
---
|
|
281
331
|
|
|
282
|
-
## 步骤
|
|
332
|
+
## 步骤6:人工验收(👤 用户介入)
|
|
283
333
|
|
|
284
334
|
**输入**
|
|
285
335
|
|
|
286
336
|
| 输入 | 说明 |
|
|
287
337
|
|------|------|
|
|
288
338
|
| `pipeline-manifest.md` | 流水线清单与缺陷统计 |
|
|
289
|
-
| 自测报告 | 步骤
|
|
290
|
-
| 已签名
|
|
339
|
+
| 自测报告 | 步骤5/步骤4自测阶段产出的测试报告 |
|
|
340
|
+
| 已签名HAP | 步骤4流水线产出的最终发布包 |
|
|
291
341
|
|
|
292
342
|
**输出**
|
|
293
343
|
|
|
294
344
|
| 产物 | 说明 |
|
|
295
345
|
|------|------|
|
|
296
|
-
| 可发布的
|
|
346
|
+
| 可发布的HarmonyOS应用 | 已处理报告中的遗留缺陷/TODO,通过核心场景走查 |
|
|
297
347
|
|
|
298
|
-
通读 `pipeline-manifest.md` 与自测报告,真机走查核心场景,处理报告中的遗留缺陷/TODO
|
|
348
|
+
通读 `pipeline-manifest.md` 与自测报告,真机走查核心场景,处理报告中的遗留缺陷/TODO后发布。
|