ccgx-workflow 1.0.0 → 1.0.1
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 +37 -5
- package/README.zh-CN.md +35 -5
- package/dist/cli.mjs +1 -1
- package/dist/index.mjs +2 -2
- package/dist/shared/{ccgx-workflow.WgUzkiC3.mjs → ccgx-workflow.SJPbUy5_.mjs} +17 -110
- package/package.json +2 -1
- package/templates/commands/agents/phase-runner.md +321 -321
- package/templates/commands/autonomous.md +792 -792
- package/templates/commands/cancel.md +132 -132
- package/templates/commands/debug.md +226 -226
- package/templates/commands/status.md +206 -206
- package/templates/commands/team.md +484 -0
- package/templates/hooks/ccg-session-state.cjs +510 -510
- package/templates/scripts/ccg-phase-runner-launcher.mjs +467 -467
- package/templates/scripts/invoke-model.mjs +64 -0
- package/templates/skills/domains/ai/SKILL.md +35 -35
- package/templates/skills/domains/ai/agent-dev.md +242 -242
- package/templates/skills/domains/ai/llm-security.md +288 -288
- package/templates/skills/domains/ai/rag-system.md +542 -542
- package/templates/skills/domains/architecture/SKILL.md +43 -43
- package/templates/skills/domains/architecture/api-design.md +225 -225
- package/templates/skills/domains/architecture/cloud-native.md +285 -285
- package/templates/skills/domains/architecture/security-arch.md +297 -297
- package/templates/skills/domains/data-engineering/SKILL.md +208 -208
- package/templates/skills/domains/development/SKILL.md +47 -47
- package/templates/skills/domains/development/cpp.md +246 -246
- package/templates/skills/domains/development/go.md +323 -323
- package/templates/skills/domains/development/java.md +277 -277
- package/templates/skills/domains/development/python.md +288 -288
- package/templates/skills/domains/development/rust.md +313 -313
- package/templates/skills/domains/development/shell.md +313 -313
- package/templates/skills/domains/development/typescript.md +277 -277
- package/templates/skills/domains/devops/SKILL.md +40 -40
- package/templates/skills/domains/devops/database.md +217 -217
- package/templates/skills/domains/devops/devsecops.md +198 -198
- package/templates/skills/domains/devops/git-workflow.md +181 -181
- package/templates/skills/domains/devops/testing.md +283 -283
- package/templates/skills/domains/frontend-design/SKILL.md +244 -244
- package/templates/skills/domains/frontend-design/claymorphism/SKILL.md +121 -121
- package/templates/skills/domains/frontend-design/component-patterns.md +202 -202
- package/templates/skills/domains/frontend-design/glassmorphism/SKILL.md +142 -142
- package/templates/skills/domains/frontend-design/liquid-glass/SKILL.md +139 -139
- package/templates/skills/domains/frontend-design/neubrutalism/SKILL.md +145 -145
- package/templates/skills/domains/frontend-design/state-management.md +680 -680
- package/templates/skills/domains/frontend-design/ui-aesthetics.md +110 -110
- package/templates/skills/domains/frontend-design/ux-principles.md +156 -156
- package/templates/skills/domains/infrastructure/SKILL.md +201 -201
- package/templates/skills/domains/mobile/SKILL.md +225 -225
- package/templates/skills/domains/orchestration/SKILL.md +30 -30
- package/templates/skills/domains/orchestration/multi-agent.md +228 -228
- package/templates/skills/domains/security/SKILL.md +73 -73
- package/templates/skills/domains/security/blue-team.md +436 -436
- package/templates/skills/domains/security/code-audit.md +265 -265
- package/templates/skills/domains/security/pentest.md +226 -226
- package/templates/skills/domains/security/red-team.md +374 -374
- package/templates/skills/domains/security/threat-intel.md +372 -372
- package/templates/skills/domains/security/vuln-research.md +369 -369
- package/templates/skills/tools/lib/shared.js +98 -98
- package/templates/skills/tools/override-refusal/SKILL.md +53 -53
- package/templates/skills/tools/override-refusal/scripts/refusal_rewriter.js +226 -226
|
@@ -1,225 +1,225 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: mobile
|
|
3
|
-
description: 移动开发(iOS/Android/SwiftUI/Jetpack Compose/React Native/Flutter)。
|
|
4
|
-
license: MIT
|
|
5
|
-
user-invocable: false
|
|
6
|
-
disable-model-invocation: false
|
|
7
|
-
context: fork
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
# 移动开发域 · Mobile Development
|
|
11
|
-
|
|
12
|
-
## 域概览
|
|
13
|
-
|
|
14
|
-
```
|
|
15
|
-
原生开发 跨平台开发
|
|
16
|
-
├── iOS (SwiftUI/UIKit) ├── React Native (JS/TS)
|
|
17
|
-
├── Android (Compose/Kotlin) └── Flutter (Dart)
|
|
18
|
-
└── 共通:MVVM / 网络层 / 持久化 / 测试
|
|
19
|
-
```
|
|
20
|
-
|
|
21
|
-
---
|
|
22
|
-
|
|
23
|
-
## iOS 开发
|
|
24
|
-
|
|
25
|
-
### SwiftUI 核心模式
|
|
26
|
-
|
|
27
|
-
- View 组件:`struct MyView: View { var body: some View { ... } }`
|
|
28
|
-
- State 管理:
|
|
29
|
-
- `@State` — 本地状态
|
|
30
|
-
- `@Binding` — 父子双向绑定
|
|
31
|
-
- `@StateObject` — 拥有 ObservableObject
|
|
32
|
-
- `@ObservedObject` — 引用 ObservableObject
|
|
33
|
-
- `@EnvironmentObject` / `@Environment` — 全局注入
|
|
34
|
-
- ObservableObject:`@Published` 属性自动触发 UI 更新
|
|
35
|
-
- Custom ViewModifier:`struct CardModifier: ViewModifier` + `extension View { func cardStyle() }`
|
|
36
|
-
- 生命周期:`.task { await ... }` / `.onAppear` / `.onDisappear`
|
|
37
|
-
|
|
38
|
-
### UIKit 集成
|
|
39
|
-
|
|
40
|
-
- UIViewControllerRepresentable:包装 UIViewController 到 SwiftUI
|
|
41
|
-
- UIViewRepresentable:包装 UIView 到 SwiftUI
|
|
42
|
-
- Coordinator 模式:处理 delegate 回调
|
|
43
|
-
- Auto Layout:`NSLayoutConstraint.activate([...])` + `translatesAutoresizingMaskIntoConstraints = false`
|
|
44
|
-
|
|
45
|
-
### Combine 响应式
|
|
46
|
-
|
|
47
|
-
- Publisher:`URLSession.shared.dataTaskPublisher` → `map` → `decode` → `eraseToAnyPublisher`
|
|
48
|
-
- 订阅:`.sink(receiveCompletion:receiveValue:)` + `.store(in: &cancellables)`
|
|
49
|
-
- 常用 Operators:`debounce` / `removeDuplicates` / `combineLatest` / `flatMap`
|
|
50
|
-
- Subject:`PassthroughSubject`(无初始值)/ `CurrentValueSubject`(有初始值)
|
|
51
|
-
|
|
52
|
-
### iOS 架构
|
|
53
|
-
|
|
54
|
-
MVVM(推荐):
|
|
55
|
-
- Model:`Codable` 数据结构
|
|
56
|
-
- Repository:`protocol` + `async throws` 方法
|
|
57
|
-
- ViewModel:`@MainActor class VM: ObservableObject` + `@Published` 属性
|
|
58
|
-
- View:`@StateObject private var viewModel = VM()`
|
|
59
|
-
|
|
60
|
-
VIPER(复杂场景):
|
|
61
|
-
- View ←→ Presenter ←→ Interactor → Entity
|
|
62
|
-
- Router 处理导航
|
|
63
|
-
|
|
64
|
-
### 网络层
|
|
65
|
-
|
|
66
|
-
- APIClient:泛型 `func get<T: Decodable>(_ path:) async throws -> T`
|
|
67
|
-
- Token 管理:`request.setValue("Bearer \(token)", forHTTPHeaderField: "Authorization")`
|
|
68
|
-
- 错误处理:`enum APIError: Error { case invalidURL, invalidResponse, httpError(Int) }`
|
|
69
|
-
|
|
70
|
-
### 数据持久化
|
|
71
|
-
|
|
72
|
-
- UserDefaults:`@propertyWrapper struct UserDefault<T>` 简化访问
|
|
73
|
-
- Keychain:`SecItemAdd` / `SecItemCopyMatching` 存储敏感数据
|
|
74
|
-
- Core Data:`NSPersistentContainer` + `NSManagedObjectContext`
|
|
75
|
-
- SwiftData(iOS 17+):`@Model` 宏简化持久化
|
|
76
|
-
|
|
77
|
-
### iOS Checklist
|
|
78
|
-
|
|
79
|
-
- [ ] SwiftUI 优先,UIKit 按需集成
|
|
80
|
-
- [ ] `@MainActor` 确保 UI 线程安全
|
|
81
|
-
- [ ] async/await 替代回调
|
|
82
|
-
- [ ] 依赖注入提升可测试性
|
|
83
|
-
- [ ] LazyVStack/LazyHStack 优化大列表
|
|
84
|
-
- [ ] 图片缓存(NSCache)减少内存压力
|
|
85
|
-
- [ ] Keychain 存储敏感数据(非 UserDefaults)
|
|
86
|
-
- [ ] 单元测试覆盖 ViewModel + Mock Repository
|
|
87
|
-
|
|
88
|
-
---
|
|
89
|
-
|
|
90
|
-
## Android 开发
|
|
91
|
-
|
|
92
|
-
### Jetpack Compose 核心模式
|
|
93
|
-
|
|
94
|
-
- Composable:`@Composable fun MyScreen() { ... }`
|
|
95
|
-
- State 管理:
|
|
96
|
-
- `remember { mutableStateOf(value) }` — 本地状态
|
|
97
|
-
- `rememberSaveable` — 跨配置变更保存
|
|
98
|
-
- `derivedStateOf` — 派生状态避免重组
|
|
99
|
-
- LazyColumn:`items(list, key = { it.id })` 提供稳定 key
|
|
100
|
-
- Side Effects:
|
|
101
|
-
- `LaunchedEffect(key)` — 启动协程
|
|
102
|
-
- `DisposableEffect(key)` — 清理资源(onDispose)
|
|
103
|
-
- `SideEffect` — 同步状态到外部
|
|
104
|
-
- `snapshotFlow { state }` — 监听状态变化转 Flow
|
|
105
|
-
- Navigation:`NavHost` + `composable(route)` + `navController.navigate()`
|
|
106
|
-
- Custom Modifier:`fun Modifier.myModifier(): Modifier = composed { ... }`
|
|
107
|
-
|
|
108
|
-
### ViewModel + StateFlow
|
|
109
|
-
|
|
110
|
-
- StateFlow(推荐替代 LiveData):
|
|
111
|
-
- `MutableStateFlow(UiState())` + `.asStateFlow()`
|
|
112
|
-
- `_uiState.update { it.copy(isLoading = true) }`
|
|
113
|
-
- Compose 中:`val uiState by viewModel.uiState.collectAsState()`
|
|
114
|
-
- UiState data class:封装 loading / error / data
|
|
115
|
-
|
|
116
|
-
### Kotlin Coroutines & Flow
|
|
117
|
-
|
|
118
|
-
- 协程:`viewModelScope.launch { withContext(Dispatchers.IO) { ... } }`
|
|
119
|
-
- 并发:`coroutineScope { val a = async { ... }; val b = async { ... } }`
|
|
120
|
-
- Flow:`flow { emit(value) }` + `.flowOn(Dispatchers.IO)`
|
|
121
|
-
- StateFlow:`.stateIn(scope, SharingStarted.WhileSubscribed(5000), initial)`
|
|
122
|
-
- 搜索防抖:`searchQuery.debounce(300).filter { it.isNotEmpty() }.flatMapLatest { ... }`
|
|
123
|
-
- Channel:`Channel<Event>(BUFFERED)` + `.receiveAsFlow()` 一次性事件
|
|
124
|
-
|
|
125
|
-
### 依赖注入 (Hilt)
|
|
126
|
-
|
|
127
|
-
- `@HiltAndroidApp` Application + `@AndroidEntryPoint` Activity
|
|
128
|
-
- `@Module @InstallIn(SingletonComponent::class)` 提供依赖
|
|
129
|
-
- `@Provides @Singleton` 提供实例 / `@Binds` 绑定接口
|
|
130
|
-
- ViewModel:`@HiltViewModel class VM @Inject constructor(repo)` + `hiltViewModel()`
|
|
131
|
-
|
|
132
|
-
### Room 数据库
|
|
133
|
-
|
|
134
|
-
- Entity:`@Entity(tableName)` + `@PrimaryKey` + `@ColumnInfo`
|
|
135
|
-
- DAO:`@Query` / `@Insert(onConflict = REPLACE)` / `@Delete` + 返回 `Flow<List<T>>`
|
|
136
|
-
- Database:`@Database(entities, version)` + `Room.databaseBuilder`
|
|
137
|
-
|
|
138
|
-
### 网络层 (Retrofit)
|
|
139
|
-
|
|
140
|
-
- ApiService:`@GET` / `@POST` / `@Path` / `@Query` / `@Body` / `@Multipart`
|
|
141
|
-
- Interceptor:AuthInterceptor 注入 Bearer Token
|
|
142
|
-
- OkHttpClient:`addInterceptor` + `connectTimeout`
|
|
143
|
-
|
|
144
|
-
### Android Checklist
|
|
145
|
-
|
|
146
|
-
- [ ] Compose 优先,View 系统按需使用
|
|
147
|
-
- [ ] StateFlow 替代 LiveData
|
|
148
|
-
- [ ] Hilt 依赖注入
|
|
149
|
-
- [ ] Room 本地持久化
|
|
150
|
-
- [ ] `key` 参数优化 LazyColumn
|
|
151
|
-
- [ ] `remember` / `derivedStateOf` 避免过度重组
|
|
152
|
-
- [ ] Coil 图片加载 + 缓存策略
|
|
153
|
-
- [ ] 单元测试覆盖 ViewModel(runTest + advanceUntilIdle)
|
|
154
|
-
|
|
155
|
-
---
|
|
156
|
-
|
|
157
|
-
## 跨平台开发
|
|
158
|
-
|
|
159
|
-
### React Native vs Flutter
|
|
160
|
-
|
|
161
|
-
| 维度 | React Native | Flutter |
|
|
162
|
-
|------|--------------|---------|
|
|
163
|
-
| 语言 | TypeScript | Dart |
|
|
164
|
-
| 渲染 | 原生组件(桥接) | 自绘引擎(Skia) |
|
|
165
|
-
| 性能 | 接近原生 | 接近原生 |
|
|
166
|
-
| 热重载 | Fast Refresh | Hot Reload |
|
|
167
|
-
| 生态 | npm(成熟) | pub.dev(快速增长) |
|
|
168
|
-
| UI 一致性 | 跟随系统 | 完全一致 |
|
|
169
|
-
| 包体积 | ~7MB | ~15MB |
|
|
170
|
-
|
|
171
|
-
### React Native 核心模式
|
|
172
|
-
|
|
173
|
-
- 组件:函数组件 + Hooks(useState / useEffect / useCallback / useMemo)
|
|
174
|
-
- 列表:`FlatList` + `keyExtractor` + `initialNumToRender` + `windowSize`
|
|
175
|
-
- Navigation:`@react-navigation/native` + `createNativeStackNavigator`
|
|
176
|
-
- 状态管理:Redux Toolkit(`createSlice` + `createAsyncThunk`)/ Zustand
|
|
177
|
-
- 原生桥接:`NativeModules` 调用 iOS(Swift) / Android(Kotlin) 原生代码
|
|
178
|
-
- 性能:`React.memo` / Hermes 引擎 / 新架构 JSI(无桥接序列化)
|
|
179
|
-
|
|
180
|
-
### Flutter 核心模式
|
|
181
|
-
|
|
182
|
-
- Widget:StatelessWidget / StatefulWidget + `setState`
|
|
183
|
-
- 状态管理:
|
|
184
|
-
- Provider:`ChangeNotifier` + `Consumer` / `context.watch`
|
|
185
|
-
- Riverpod(推荐):`FutureProvider` / `StateNotifierProvider` + `ref.watch`
|
|
186
|
-
- Navigation:go_router(`GoRoute` + `context.go/push/pop`)
|
|
187
|
-
- 原生桥接:`MethodChannel` + Platform Channels(iOS Swift / Android Kotlin)
|
|
188
|
-
- 性能:`const` 构造函数 / `ListView.builder` / `RepaintBoundary` / `ValueKey`
|
|
189
|
-
|
|
190
|
-
### 选型建议
|
|
191
|
-
|
|
192
|
-
| 场景 | 推荐 | 理由 |
|
|
193
|
-
|------|------|------|
|
|
194
|
-
| 团队有 Web 背景 | React Native | 学习成本低 |
|
|
195
|
-
| 追求极致性能/动画 | Flutter | 自绘引擎 60fps |
|
|
196
|
-
| UI 高度定制 | Flutter | 完全控制渲染 |
|
|
197
|
-
| 大量原生交互 | React Native | 桥接生态成熟 |
|
|
198
|
-
| 需要原生极致体验 | 原生开发 | 无桥接开销 |
|
|
199
|
-
|
|
200
|
-
### 跨平台 Checklist
|
|
201
|
-
|
|
202
|
-
- [ ] 选型匹配团队技术栈和业务需求
|
|
203
|
-
- [ ] 列表优化:FlatList(RN) / ListView.builder(Flutter) + key
|
|
204
|
-
- [ ] 状态管理:Redux Toolkit(RN) / Riverpod(Flutter)
|
|
205
|
-
- [ ] 原生模块桥接方案验证
|
|
206
|
-
- [ ] 包体积优化:ProGuard(Android) / tree-shake-icons(Flutter)
|
|
207
|
-
- [ ] 性能基线:冷启动 < 1.5s / 渲染 > 55fps
|
|
208
|
-
|
|
209
|
-
---
|
|
210
|
-
|
|
211
|
-
## 通用最佳实践
|
|
212
|
-
|
|
213
|
-
| 实践 | 说明 |
|
|
214
|
-
|------|------|
|
|
215
|
-
| MVVM 架构 | 分离 UI / 业务逻辑 / 数据层 |
|
|
216
|
-
| 依赖注入 | Hilt(Android) / Protocol(iOS) / Context(RN) |
|
|
217
|
-
| 响应式状态 | StateFlow / Combine / Hooks / Riverpod |
|
|
218
|
-
| 网络层封装 | 统一错误处理 + Token 管理 + 重试 |
|
|
219
|
-
| 本地持久化 | Room / Core Data / AsyncStorage / Hive |
|
|
220
|
-
| 列表优化 | 懒加载 + 稳定 key + 缓存 |
|
|
221
|
-
| 测试覆盖 | ViewModel 单元测试 + UI 测试关键流程 |
|
|
222
|
-
|
|
223
|
-
## 触发词
|
|
224
|
-
|
|
225
|
-
iOS、SwiftUI、UIKit、Combine、Android、Jetpack Compose、Kotlin、React Native、Flutter、跨平台、移动开发、MVVM
|
|
1
|
+
---
|
|
2
|
+
name: mobile
|
|
3
|
+
description: 移动开发(iOS/Android/SwiftUI/Jetpack Compose/React Native/Flutter)。
|
|
4
|
+
license: MIT
|
|
5
|
+
user-invocable: false
|
|
6
|
+
disable-model-invocation: false
|
|
7
|
+
context: fork
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# 移动开发域 · Mobile Development
|
|
11
|
+
|
|
12
|
+
## 域概览
|
|
13
|
+
|
|
14
|
+
```
|
|
15
|
+
原生开发 跨平台开发
|
|
16
|
+
├── iOS (SwiftUI/UIKit) ├── React Native (JS/TS)
|
|
17
|
+
├── Android (Compose/Kotlin) └── Flutter (Dart)
|
|
18
|
+
└── 共通:MVVM / 网络层 / 持久化 / 测试
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
---
|
|
22
|
+
|
|
23
|
+
## iOS 开发
|
|
24
|
+
|
|
25
|
+
### SwiftUI 核心模式
|
|
26
|
+
|
|
27
|
+
- View 组件:`struct MyView: View { var body: some View { ... } }`
|
|
28
|
+
- State 管理:
|
|
29
|
+
- `@State` — 本地状态
|
|
30
|
+
- `@Binding` — 父子双向绑定
|
|
31
|
+
- `@StateObject` — 拥有 ObservableObject
|
|
32
|
+
- `@ObservedObject` — 引用 ObservableObject
|
|
33
|
+
- `@EnvironmentObject` / `@Environment` — 全局注入
|
|
34
|
+
- ObservableObject:`@Published` 属性自动触发 UI 更新
|
|
35
|
+
- Custom ViewModifier:`struct CardModifier: ViewModifier` + `extension View { func cardStyle() }`
|
|
36
|
+
- 生命周期:`.task { await ... }` / `.onAppear` / `.onDisappear`
|
|
37
|
+
|
|
38
|
+
### UIKit 集成
|
|
39
|
+
|
|
40
|
+
- UIViewControllerRepresentable:包装 UIViewController 到 SwiftUI
|
|
41
|
+
- UIViewRepresentable:包装 UIView 到 SwiftUI
|
|
42
|
+
- Coordinator 模式:处理 delegate 回调
|
|
43
|
+
- Auto Layout:`NSLayoutConstraint.activate([...])` + `translatesAutoresizingMaskIntoConstraints = false`
|
|
44
|
+
|
|
45
|
+
### Combine 响应式
|
|
46
|
+
|
|
47
|
+
- Publisher:`URLSession.shared.dataTaskPublisher` → `map` → `decode` → `eraseToAnyPublisher`
|
|
48
|
+
- 订阅:`.sink(receiveCompletion:receiveValue:)` + `.store(in: &cancellables)`
|
|
49
|
+
- 常用 Operators:`debounce` / `removeDuplicates` / `combineLatest` / `flatMap`
|
|
50
|
+
- Subject:`PassthroughSubject`(无初始值)/ `CurrentValueSubject`(有初始值)
|
|
51
|
+
|
|
52
|
+
### iOS 架构
|
|
53
|
+
|
|
54
|
+
MVVM(推荐):
|
|
55
|
+
- Model:`Codable` 数据结构
|
|
56
|
+
- Repository:`protocol` + `async throws` 方法
|
|
57
|
+
- ViewModel:`@MainActor class VM: ObservableObject` + `@Published` 属性
|
|
58
|
+
- View:`@StateObject private var viewModel = VM()`
|
|
59
|
+
|
|
60
|
+
VIPER(复杂场景):
|
|
61
|
+
- View ←→ Presenter ←→ Interactor → Entity
|
|
62
|
+
- Router 处理导航
|
|
63
|
+
|
|
64
|
+
### 网络层
|
|
65
|
+
|
|
66
|
+
- APIClient:泛型 `func get<T: Decodable>(_ path:) async throws -> T`
|
|
67
|
+
- Token 管理:`request.setValue("Bearer \(token)", forHTTPHeaderField: "Authorization")`
|
|
68
|
+
- 错误处理:`enum APIError: Error { case invalidURL, invalidResponse, httpError(Int) }`
|
|
69
|
+
|
|
70
|
+
### 数据持久化
|
|
71
|
+
|
|
72
|
+
- UserDefaults:`@propertyWrapper struct UserDefault<T>` 简化访问
|
|
73
|
+
- Keychain:`SecItemAdd` / `SecItemCopyMatching` 存储敏感数据
|
|
74
|
+
- Core Data:`NSPersistentContainer` + `NSManagedObjectContext`
|
|
75
|
+
- SwiftData(iOS 17+):`@Model` 宏简化持久化
|
|
76
|
+
|
|
77
|
+
### iOS Checklist
|
|
78
|
+
|
|
79
|
+
- [ ] SwiftUI 优先,UIKit 按需集成
|
|
80
|
+
- [ ] `@MainActor` 确保 UI 线程安全
|
|
81
|
+
- [ ] async/await 替代回调
|
|
82
|
+
- [ ] 依赖注入提升可测试性
|
|
83
|
+
- [ ] LazyVStack/LazyHStack 优化大列表
|
|
84
|
+
- [ ] 图片缓存(NSCache)减少内存压力
|
|
85
|
+
- [ ] Keychain 存储敏感数据(非 UserDefaults)
|
|
86
|
+
- [ ] 单元测试覆盖 ViewModel + Mock Repository
|
|
87
|
+
|
|
88
|
+
---
|
|
89
|
+
|
|
90
|
+
## Android 开发
|
|
91
|
+
|
|
92
|
+
### Jetpack Compose 核心模式
|
|
93
|
+
|
|
94
|
+
- Composable:`@Composable fun MyScreen() { ... }`
|
|
95
|
+
- State 管理:
|
|
96
|
+
- `remember { mutableStateOf(value) }` — 本地状态
|
|
97
|
+
- `rememberSaveable` — 跨配置变更保存
|
|
98
|
+
- `derivedStateOf` — 派生状态避免重组
|
|
99
|
+
- LazyColumn:`items(list, key = { it.id })` 提供稳定 key
|
|
100
|
+
- Side Effects:
|
|
101
|
+
- `LaunchedEffect(key)` — 启动协程
|
|
102
|
+
- `DisposableEffect(key)` — 清理资源(onDispose)
|
|
103
|
+
- `SideEffect` — 同步状态到外部
|
|
104
|
+
- `snapshotFlow { state }` — 监听状态变化转 Flow
|
|
105
|
+
- Navigation:`NavHost` + `composable(route)` + `navController.navigate()`
|
|
106
|
+
- Custom Modifier:`fun Modifier.myModifier(): Modifier = composed { ... }`
|
|
107
|
+
|
|
108
|
+
### ViewModel + StateFlow
|
|
109
|
+
|
|
110
|
+
- StateFlow(推荐替代 LiveData):
|
|
111
|
+
- `MutableStateFlow(UiState())` + `.asStateFlow()`
|
|
112
|
+
- `_uiState.update { it.copy(isLoading = true) }`
|
|
113
|
+
- Compose 中:`val uiState by viewModel.uiState.collectAsState()`
|
|
114
|
+
- UiState data class:封装 loading / error / data
|
|
115
|
+
|
|
116
|
+
### Kotlin Coroutines & Flow
|
|
117
|
+
|
|
118
|
+
- 协程:`viewModelScope.launch { withContext(Dispatchers.IO) { ... } }`
|
|
119
|
+
- 并发:`coroutineScope { val a = async { ... }; val b = async { ... } }`
|
|
120
|
+
- Flow:`flow { emit(value) }` + `.flowOn(Dispatchers.IO)`
|
|
121
|
+
- StateFlow:`.stateIn(scope, SharingStarted.WhileSubscribed(5000), initial)`
|
|
122
|
+
- 搜索防抖:`searchQuery.debounce(300).filter { it.isNotEmpty() }.flatMapLatest { ... }`
|
|
123
|
+
- Channel:`Channel<Event>(BUFFERED)` + `.receiveAsFlow()` 一次性事件
|
|
124
|
+
|
|
125
|
+
### 依赖注入 (Hilt)
|
|
126
|
+
|
|
127
|
+
- `@HiltAndroidApp` Application + `@AndroidEntryPoint` Activity
|
|
128
|
+
- `@Module @InstallIn(SingletonComponent::class)` 提供依赖
|
|
129
|
+
- `@Provides @Singleton` 提供实例 / `@Binds` 绑定接口
|
|
130
|
+
- ViewModel:`@HiltViewModel class VM @Inject constructor(repo)` + `hiltViewModel()`
|
|
131
|
+
|
|
132
|
+
### Room 数据库
|
|
133
|
+
|
|
134
|
+
- Entity:`@Entity(tableName)` + `@PrimaryKey` + `@ColumnInfo`
|
|
135
|
+
- DAO:`@Query` / `@Insert(onConflict = REPLACE)` / `@Delete` + 返回 `Flow<List<T>>`
|
|
136
|
+
- Database:`@Database(entities, version)` + `Room.databaseBuilder`
|
|
137
|
+
|
|
138
|
+
### 网络层 (Retrofit)
|
|
139
|
+
|
|
140
|
+
- ApiService:`@GET` / `@POST` / `@Path` / `@Query` / `@Body` / `@Multipart`
|
|
141
|
+
- Interceptor:AuthInterceptor 注入 Bearer Token
|
|
142
|
+
- OkHttpClient:`addInterceptor` + `connectTimeout`
|
|
143
|
+
|
|
144
|
+
### Android Checklist
|
|
145
|
+
|
|
146
|
+
- [ ] Compose 优先,View 系统按需使用
|
|
147
|
+
- [ ] StateFlow 替代 LiveData
|
|
148
|
+
- [ ] Hilt 依赖注入
|
|
149
|
+
- [ ] Room 本地持久化
|
|
150
|
+
- [ ] `key` 参数优化 LazyColumn
|
|
151
|
+
- [ ] `remember` / `derivedStateOf` 避免过度重组
|
|
152
|
+
- [ ] Coil 图片加载 + 缓存策略
|
|
153
|
+
- [ ] 单元测试覆盖 ViewModel(runTest + advanceUntilIdle)
|
|
154
|
+
|
|
155
|
+
---
|
|
156
|
+
|
|
157
|
+
## 跨平台开发
|
|
158
|
+
|
|
159
|
+
### React Native vs Flutter
|
|
160
|
+
|
|
161
|
+
| 维度 | React Native | Flutter |
|
|
162
|
+
|------|--------------|---------|
|
|
163
|
+
| 语言 | TypeScript | Dart |
|
|
164
|
+
| 渲染 | 原生组件(桥接) | 自绘引擎(Skia) |
|
|
165
|
+
| 性能 | 接近原生 | 接近原生 |
|
|
166
|
+
| 热重载 | Fast Refresh | Hot Reload |
|
|
167
|
+
| 生态 | npm(成熟) | pub.dev(快速增长) |
|
|
168
|
+
| UI 一致性 | 跟随系统 | 完全一致 |
|
|
169
|
+
| 包体积 | ~7MB | ~15MB |
|
|
170
|
+
|
|
171
|
+
### React Native 核心模式
|
|
172
|
+
|
|
173
|
+
- 组件:函数组件 + Hooks(useState / useEffect / useCallback / useMemo)
|
|
174
|
+
- 列表:`FlatList` + `keyExtractor` + `initialNumToRender` + `windowSize`
|
|
175
|
+
- Navigation:`@react-navigation/native` + `createNativeStackNavigator`
|
|
176
|
+
- 状态管理:Redux Toolkit(`createSlice` + `createAsyncThunk`)/ Zustand
|
|
177
|
+
- 原生桥接:`NativeModules` 调用 iOS(Swift) / Android(Kotlin) 原生代码
|
|
178
|
+
- 性能:`React.memo` / Hermes 引擎 / 新架构 JSI(无桥接序列化)
|
|
179
|
+
|
|
180
|
+
### Flutter 核心模式
|
|
181
|
+
|
|
182
|
+
- Widget:StatelessWidget / StatefulWidget + `setState`
|
|
183
|
+
- 状态管理:
|
|
184
|
+
- Provider:`ChangeNotifier` + `Consumer` / `context.watch`
|
|
185
|
+
- Riverpod(推荐):`FutureProvider` / `StateNotifierProvider` + `ref.watch`
|
|
186
|
+
- Navigation:go_router(`GoRoute` + `context.go/push/pop`)
|
|
187
|
+
- 原生桥接:`MethodChannel` + Platform Channels(iOS Swift / Android Kotlin)
|
|
188
|
+
- 性能:`const` 构造函数 / `ListView.builder` / `RepaintBoundary` / `ValueKey`
|
|
189
|
+
|
|
190
|
+
### 选型建议
|
|
191
|
+
|
|
192
|
+
| 场景 | 推荐 | 理由 |
|
|
193
|
+
|------|------|------|
|
|
194
|
+
| 团队有 Web 背景 | React Native | 学习成本低 |
|
|
195
|
+
| 追求极致性能/动画 | Flutter | 自绘引擎 60fps |
|
|
196
|
+
| UI 高度定制 | Flutter | 完全控制渲染 |
|
|
197
|
+
| 大量原生交互 | React Native | 桥接生态成熟 |
|
|
198
|
+
| 需要原生极致体验 | 原生开发 | 无桥接开销 |
|
|
199
|
+
|
|
200
|
+
### 跨平台 Checklist
|
|
201
|
+
|
|
202
|
+
- [ ] 选型匹配团队技术栈和业务需求
|
|
203
|
+
- [ ] 列表优化:FlatList(RN) / ListView.builder(Flutter) + key
|
|
204
|
+
- [ ] 状态管理:Redux Toolkit(RN) / Riverpod(Flutter)
|
|
205
|
+
- [ ] 原生模块桥接方案验证
|
|
206
|
+
- [ ] 包体积优化:ProGuard(Android) / tree-shake-icons(Flutter)
|
|
207
|
+
- [ ] 性能基线:冷启动 < 1.5s / 渲染 > 55fps
|
|
208
|
+
|
|
209
|
+
---
|
|
210
|
+
|
|
211
|
+
## 通用最佳实践
|
|
212
|
+
|
|
213
|
+
| 实践 | 说明 |
|
|
214
|
+
|------|------|
|
|
215
|
+
| MVVM 架构 | 分离 UI / 业务逻辑 / 数据层 |
|
|
216
|
+
| 依赖注入 | Hilt(Android) / Protocol(iOS) / Context(RN) |
|
|
217
|
+
| 响应式状态 | StateFlow / Combine / Hooks / Riverpod |
|
|
218
|
+
| 网络层封装 | 统一错误处理 + Token 管理 + 重试 |
|
|
219
|
+
| 本地持久化 | Room / Core Data / AsyncStorage / Hive |
|
|
220
|
+
| 列表优化 | 懒加载 + 稳定 key + 缓存 |
|
|
221
|
+
| 测试覆盖 | ViewModel 单元测试 + UI 测试关键流程 |
|
|
222
|
+
|
|
223
|
+
## 触发词
|
|
224
|
+
|
|
225
|
+
iOS、SwiftUI、UIKit、Combine、Android、Jetpack Compose、Kotlin、React Native、Flutter、跨平台、移动开发、MVVM
|
|
@@ -1,30 +1,30 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: orchestration
|
|
3
|
-
description: 协同编排知识域(多 Agent 协同、任务分解、并行执行、冲突解决)。
|
|
4
|
-
license: MIT
|
|
5
|
-
user-invocable: false
|
|
6
|
-
disable-model-invocation: false
|
|
7
|
-
context: fork
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
# 🕸 协同编排秘典
|
|
11
|
-
|
|
12
|
-
## 知识主题
|
|
13
|
-
|
|
14
|
-
| 主题 | 文档 | 涵盖 |
|
|
15
|
-
|------|------|------|
|
|
16
|
-
| 多Agent协同 | [multi-agent.md](multi-agent.md) | 角色定义、任务分解、通信协议、冲突解决、状态共享 |
|
|
17
|
-
|
|
18
|
-
## 使用场景
|
|
19
|
-
|
|
20
|
-
- 大型任务分解
|
|
21
|
-
- 多文件并行处理
|
|
22
|
-
- 复杂系统重构
|
|
23
|
-
- 跨模块协同开发
|
|
24
|
-
- 紧急多点修复
|
|
25
|
-
|
|
26
|
-
## Codex 强化要点
|
|
27
|
-
|
|
28
|
-
- 优先使用 `spawn_agent/send_input/wait/close_agent` 形成闭环。
|
|
29
|
-
- 代码探索优先 `explorer`,执行改动使用 `worker`,长耗时任务使用 `awaiter`。
|
|
30
|
-
- 每个文件同一时刻仅允许一个 Agent 写入,先锁文件再并行。
|
|
1
|
+
---
|
|
2
|
+
name: orchestration
|
|
3
|
+
description: 协同编排知识域(多 Agent 协同、任务分解、并行执行、冲突解决)。
|
|
4
|
+
license: MIT
|
|
5
|
+
user-invocable: false
|
|
6
|
+
disable-model-invocation: false
|
|
7
|
+
context: fork
|
|
8
|
+
---
|
|
9
|
+
|
|
10
|
+
# 🕸 协同编排秘典
|
|
11
|
+
|
|
12
|
+
## 知识主题
|
|
13
|
+
|
|
14
|
+
| 主题 | 文档 | 涵盖 |
|
|
15
|
+
|------|------|------|
|
|
16
|
+
| 多Agent协同 | [multi-agent.md](multi-agent.md) | 角色定义、任务分解、通信协议、冲突解决、状态共享 |
|
|
17
|
+
|
|
18
|
+
## 使用场景
|
|
19
|
+
|
|
20
|
+
- 大型任务分解
|
|
21
|
+
- 多文件并行处理
|
|
22
|
+
- 复杂系统重构
|
|
23
|
+
- 跨模块协同开发
|
|
24
|
+
- 紧急多点修复
|
|
25
|
+
|
|
26
|
+
## Codex 强化要点
|
|
27
|
+
|
|
28
|
+
- 优先使用 `spawn_agent/send_input/wait/close_agent` 形成闭环。
|
|
29
|
+
- 代码探索优先 `explorer`,执行改动使用 `worker`,长耗时任务使用 `awaiter`。
|
|
30
|
+
- 每个文件同一时刻仅允许一个 Agent 写入,先锁文件再并行。
|