style: 清理代码注释和格式

This commit is contained in:
xinian
2026-04-04 05:12:30 +08:00
committed by cnb
parent 31d274dd9d
commit b62b4af628
31 changed files with 863 additions and 195 deletions

View File

@@ -1,37 +0,0 @@
# Task 200: Effects 1614-1619
## 目标
- 补齐以下 5 或最后一组不足 5 当前判定未实现的 skill effect
- 实现位置优先放在 `logic/service/fight/effect/`
- effect 需要展示说明同步更新 `logic/service/fight/effect/effect_info_map.go`
- 完成后至少执行`cd /workspace/logic && go test ./service/fight/effect`
## Effect 列表
### Effect 1614
- `argsNum`: `4`
- `info`: `{0}回合内对手使用攻击技能后{1}%令对手{2},未触发则令对手全属性-{3}`
- `param`: `1,2,2`
### Effect 1616
- `argsNum`: `0`
- `info`: `当回合使用的技能克制对手时获得本系属性加成`
### Effect 1617
- `argsNum`: `4`
- `info`: `{0}回合内受到攻击后{1}%使对手{2},未触发则自身全属性+{3}`
- `param`: `1,2,2`
### Effect 1618
- `argsNum`: `2`
- `info`: `{0}回合内每回合结束时令对手随机{1}个技能PP值归零`
### Effect 1619
- `argsNum`: `0`
- `info`: `50%复制对手当回合释放的技能未触发则恢复自身最大体力的1/2且令对手全属性-1`
## 备注
- 该清单按当前仓库静态注册结果生成如果某个 effect 实际通过其他模块或运行时路径实现需要先复核后再落代码
- `201``445` 这类占位 effect优先补核心逻辑或补充明确的不可实现说明

View File

@@ -0,0 +1,283 @@
# 战斗多单位模式改造交接文档2026-04-04
## 1. 任务目标
将当前战斗系统从每回合双方各 1 个动作的模型改造成支持多上场位多操作者的统一回合模型最终支持以下 3 种战斗模式
1. `1玩家:N精灵:1上场 VS 1玩家:N精灵:1上场`
2. `N玩家:N精灵:N上场 VS N玩家:N精灵:N上场`
3. `1玩家:N精灵:N上场 VS 1玩家:N精灵:N上场`
当前代码只完整支持模式 1模式 2 和模式 3 只做了结构铺垫还没有真正打通
---
## 2. 当前已完成的基础改造
以下结构改造已经落地
- `FightC.Our/Opp` 已改成数组表示战场单位数组不再是单对象
- `input.Input.CurrentPet` 已改成 `CurPet`并且是数组
- `FightC.OurPlayers/OppPlayers` 已加入用于表达操作者数组
- 战斗单位与操作者已解耦
- `Our/Opp` 表示战斗位
- `OurPlayers/OppPlayers` 表示操作这些战斗位的玩家
- `BattlePetEntity` 已支持绑定控制者`ControllerUserID`
- 动作模型已支持
- `ActorIndex`
- `TargetIndex`
- 已提供 indexed 入口
- `UseSkillAt(c, skillID, actorIndex, targetIndex)`
- `ChangePetAt(c, petID, actorIndex)`
- `UseItemAt(c, catchTime, itemID, actorIndex, targetIndex)`
当前默认行为仍等价于
- `actorIndex = 0`
- `targetIndex = 0`
也就是当前模式下仍然是操作和结算 `0` 号单位
---
## 3. 当前未完成的核心问题
### 3.1 回合模型仍然是双动作模型
目前主流程仍然是每回合只处理双方两个动作而不是处理一个动作列表
关键位置
- `logic/service/fight/loop.go`
- `collectPlayerActions(...)` 只收 2 个动作
- `resolveRound(p1Action, p2Action)` 只结算 2 个动作
这意味着
- 模式 2 无法支持双方多个操作者或多个上场位同时行动
- 模式 3 无法支持同一玩家控制多个上场位分别出手
### 3.2 动作提交仍按 `playerID` 去重
当前动作队列逻辑仍以 `playerID` 作为主要识别维度
关键位置
- `logic/service/fight/action.go`
- `submitAction(...)`
这会导致
- 同一玩家在同一回合给多个上场位下达动作时动作会互相覆盖或无法完整保留
这一点对模式 3 是直接阻塞对模式 2 也不够健壮
### 3.3 切宠和当前上场位逻辑仍大量默认使用 `CurPet[0]`
虽然 `CurPet` 已经是数组但主流程中不少逻辑仍固定操作 `0` 号位
典型影响
- 死亡换宠
- 主动换宠
- 当前出手单位检查
- 当前目标单位检查
这部分需要按 `actorIndex` 或上场槽位改造
### 3.4 开战协议仍然只有两个当前单位
当前开战下发协议仍然是双单位结构
关键位置
- `logic/service/fight/info/info.go`
- `FightStartOutboundInfo`
- 仍只有 `Info1` `Info2`
这不适合多上场位模式
### 3.5 公共接口仍是旧的单单位接口
关键位置
- `logic/service/common/fight.go`
- `FightI`
目前接口仍只有
- `UseSkill(c, id)`
- `ChangePet(c, id)`
- `UseItem(c, cacthid, itemid)`
indexed 版本只存在于具体实现 `FightC` 没有进入正式接口层
---
## 4. 当前实现与目标模式的对应关系
### 4.1 模式 1
`1玩家:N精灵:1上场 VS 1玩家:N精灵:1上场`
当前支持
原因
- 当前默认就是操作 `0` 号单位
- 当前默认就是攻击 `0` 号目标
- 当前回合系统仍是每边 1 个动作这与模式 1 一致
### 4.2 模式 2
`N玩家:N精灵:N上场 VS N玩家:N精灵:N上场`
当前不支持
直接原因
- 一回合只收 2 个动作
- 一回合只结算 2 个动作
- 协议仍只同步 2 个当前上场位
### 4.3 模式 3
`1玩家:N精灵:N上场 VS 1玩家:N精灵:N上场`
当前不支持
直接原因
- 同一玩家的多个动作无法作为同回合动作列表完整保留
- 主流程仍不是按动作列表统一排序和执行
---
## 5. 需要完成的工作
### 5.1 改造动作收集模型
将当前每边 1 个动作的模型改成每个可操作上场位 1 个动作的模型
至少需要做到
- 同一玩家可以在同一回合提交多个动作
- 每个动作能区分是哪个上场位发出的
- 每个动作能区分目标上场位
建议将动作唯一键至少扩为
- `playerID`
- `actorIndex`
### 5.2 改造回合结算模型
将当前
- `resolveRound(p1Action, p2Action)`
改成
- `resolveRound(actions []action.BattleActionI)`
并完成
- 动作列表排序
- 按优先级速度等规则统一排序
- 排序后逐个结算
注意
- 当前 effect/node 体系里仍有大量双动作接口不适合一次性全部重写
- 建议先在主流程做兼容层逐步过渡
### 5.3 按槽位处理切宠与死亡换宠
将当前固定 `CurPet[0]` 的逻辑改成按槽位处理
- 主动换宠
- 被动死亡换宠
- 死亡校验
- 出手资格判断
### 5.4 增加开战与战斗同步结构
将当前的双单位同步结构扩成可支持多上场位的结构但是保持协议结构不变现在是固定两个可以改成数组来实现
重点是
- 开战协议
- 当前上场位同步
- 切宠同步
- 可能的回合播报结构
### 5.5 补齐公共接口
indexed 版本能力补进接口层避免只能通过具体实现类型访问
建议新增类似接口
- `UseSkillAt(...)`
- `ChangePetAt(...)`
- `UseItemAt(...)`
---
## 6. 推荐实施顺序
建议按下面顺序推进避免一次性改动面过大
1. 先改动作队列和动作收集逻辑
2. 再改回合结算为动作列表
3. 再改切宠和死亡换宠按槽位处理
4. 最后改协议和正式接口
不建议一开始就全量重写 effect/node 接口因为当前大量效果实现仍假设双动作上下文
---
## 7. 建议重点查看文件
- `logic/service/fight/action.go`
- `logic/service/fight/loop.go`
- `logic/service/fight/fightc.go`
- `logic/service/fight/input.go`
- `logic/service/fight/input/input.go`
- `logic/service/fight/action/BattleAction.go`
- `logic/service/fight/info/info.go`
- `logic/service/common/fight.go`
---
## 8. 完成标准
至少满足以下条件才算这次改造完成
1. 同一玩家可以在同一回合给多个上场位分别提交动作动作不会互相覆盖
2. 双方多个上场位可以在同一回合统一排序并依次结算
3. 攻击目标位可选不再默认只能打对面 `0`
4. 切宠可以按上场槽位处理
5. 模式 1 不回归
6. 代码编译通过
---
## 9. 最低验证要求
至少执行
- `cd /workspace/logic && go build ./...`
- `cd /workspace/logic && go test ./service/fight/effect`
如果本轮改动较大建议再补一轮
- `cd /workspace/logic && go test ./...`
---
## 10. 额外提醒
- 当前仓库工作区可能是脏的不要回滚无关修改
- 这次改造的真正核心不是结构字段改数组而是把回合系统从双动作模型改成动作列表模型
- 已有 `ActorIndex/TargetIndex` 只是入口铺垫不代表多单位模式已经完成