From 0d41e25fcbd1049426bb030aac8c48a8d4db6b4c Mon Sep 17 00:00:00 2001 From: swrring Date: Sun, 10 May 2026 00:26:51 +0900 Subject: [PATCH] =?UTF-8?q?diag(BT12-Dev):=20AttackHitbox=C2=B7EnemyDeath?= =?UTF-8?q?=20=EC=A7=84=EB=8B=A8=20=EB=8F=84=EA=B5=AC=202=EC=B0=A8=20+=20?= =?UTF-8?q?=EB=B3=B8=20PM=20=EA=B0=80=EC=84=A4=205=ED=9A=8C=20=EB=B6=80?= =?UTF-8?q?=EC=A0=95=ED=99=95=20=EC=9E=90=EC=84=B1=20(=EB=8C=80=ED=99=94?= =?UTF-8?q?=EB=A1=9C=EA=B7=B8=202026-05-10=20=EC=8B=A0=EA=B7=9C=20+=20PD?= =?UTF-8?q?=20=EC=A7=80=EC=8B=9C=20=EB=A1=9C=EA=B7=B8)?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit - BT12-Dev-Death 후속 — PD Console 분석 + 본 PM 가설 5회 누적 부정확 자성 - 핵심 발견: 투사체 hit X·AttackHitbox(BT7-Dev 자동 근접) hit·EnemyDeath.Execute 호출 X - A 진단 Debug.Log 추가 (AttackHitbox·EnemyDeath 각 1줄) - B PD 자료 능동 요청 (Enemy.prefab Inspector + Animator Controller Parameters) - EerieVillage `d6764ce` push 정합 - pm-auditor 통과 + Minor 1 (회수 트리거 명시) + Improvement 1 (_collider 동시 캡처) 수용 - 본 PM 자성 #12: 가설 5회 누적 부정확·재발 차단 3 단계 실측 의무 - 회수 의무 명시 (PD 사망 원인 확정 직후 본 PM revert commit) PD 결정 (2026-05-10): "A+B 진행해" — A 진단 도구 추가·B 자료 능동 요청 동시. --- 공유/PD_지시_트래킹/개발팀_PD_지시_로그.md | 2 +- 공유/대화로그/EerieVillage/2026-05-10.md | 137 +++++++++++++++++++++ 2 files changed, 138 insertions(+), 1 deletion(-) create mode 100644 공유/대화로그/EerieVillage/2026-05-10.md diff --git a/공유/PD_지시_트래킹/개발팀_PD_지시_로그.md b/공유/PD_지시_트래킹/개발팀_PD_지시_로그.md index ac6389c..7b1e448 100644 --- a/공유/PD_지시_트래킹/개발팀_PD_지시_로그.md +++ b/공유/PD_지시_트래킹/개발팀_PD_지시_로그.md @@ -34,7 +34,7 @@ C3·C13 위반에 해당. **즉시 자진 보고 후 소급 등록**. | # | 일시 | 지시 요지 | 처리 상태 | 산출물 경로 | 중단 사유 | 사후 조치 | |---|------|----------|----------|-----------|----------|----------| | BT12-Dev-Vis | 2026-05-09 | **PlayerSkillInventory 등록 시각화 지시** — PD 직접 발화: "PlayerSkillInventory 등록이 되었는지 어떻게 판단해야하지? 시각적인 변화가 없으니 확인이 불가능해. 유니티 기본 제공 리소스를 활용해도 좋으니 보이게 해줘." | **진행중** | 신규 `Assets/Scripts/MyUI/SkillInventoryHUD.cs` (OnGUI 좌상단·장착 액티브 DisplayName·Lv·CooldownRemaining/EffectiveCooldown·패시브 카운트). PlayerController.Awake 자동 부착. 보강: ProjectileSpawner fallback prefab에 SpriteRenderer + 동적 흰색 원 sprite + 속성별 색상 (Fire 주황·Frost 하늘·Dark 보라·Lightning 노랑·Physical 흰). Unity 기본 자원 활용 — Texture2D 동적 생성 16×16 알파 원. | — | **PM 후속**: PD Editor Refresh + Play 검증 → 카드 선택 후 좌상단 HUD에 카드명·Lv·CD 노출 확인 + 투사체 색상 원 시각 노출 확인 → 결과 보고 → 완료 아카이브 | -| BT12-Dev-Death | 2026-05-09 | **스킬 습득 후 사망 버그 지시** — PD 직접 발화: "스킬 습득 후 일정시간이 지나면 왜 플레이어가 갑자기 죽는거지? 버그를 수정해줘." | **fix 1+2+3+4 완료·진단 도구 추가 2026-05-09 PD Console 수령 대기** | (1) Projectile.OnTriggerEnter2D에 PlayerController 명시 차단 (defensive proxy·자기 hit 차단). (2) Health.Decrement·DecrementSilent·Die에 Debug.Log + System.Environment.StackTrace 추가 (사망 호출자 추적). **(3) 근본 fix 1 2026-05-09 EerieVillage `b37b4a6`**: HealthIsZero.Execute에 sender 검증 가드 추가 (PlayerController 보유 Health만 PlayerDeath 발화). **인수인계서 가설(EnemyController patrol → PlayerEnemyCollision) 부정** — Player Decrement 로그 부재. **근본 원인 1**: HealthIsZero.Execute가 health sender 검증 없이 무차별 Schedule() 발화. BT12-Dev Phase 2-B 투사체가 사상 처음 Enemy.Health.Decrement → Enemy의 HealthIsZero가 PlayerDeath 직결 노출. **PD 결정 (2026-05-09) "1 즉시 적용해"** — A안 1줄 fix 즉시 적용. pm-auditor Pass + Minor 1 (매니페스트 등록 정정 적용) + Improvement 2. **(4) 근본 fix 2 2026-05-09 EerieVillage `33eaa55`**: ProjectileSpawner fallback Scene GameObject 잔존 fix. **(7) 진단 도구 fix 5 2026-05-09 EerieVillage `d27a63f`** (PD A안 결정·feedback_pm_root_diagnosis_priority 영역 적용): PD 4차 보고 "여전히 적에게 제대로 피격되지 않고 통과하고 있어" → 본 PM 가설 4회 누적 부정확·회귀 1회 → 가설 즉시 중단·실측 우선·진단 Debug.Log 영역 추가. Projectile.OnTriggerEnter2D 영역 8 분기 진입·return·Hit 시점 영역 [Projectile][...] prefix 통일 영역 → PD Play Console 영역 호출 여부·other 정보·Layer·EnemyController·Health 영역 정확 진단 → 근본 원인 확정 후 fix. 회수 의무 명시 (PD Console 수령 + 근본 fix 후 일괄 제거). pm-auditor 통과 (조건부) + 권고 4종 (prefix 통일·가설 X·회수 명시·PD 안내) 수용. **(6) 회귀 정정 fix 4 2026-05-09 EerieVillage `9eebbec`** (C3 자진 고지): fix 3 영역 Kinematic Rigidbody2D 추가가 회귀 유발 — PD 3차 보고 "여전히 적이 플레이어의 투사체에 피격되지 않아". **근본**: Enemy = KinematicObject 상속 영역 Kinematic Rigidbody2D → Projectile Kinematic 영역 추가 시 Kinematic vs Kinematic + useFullKinematicContacts=false (기본값) → OnTriggerEnter2D 발화 X 영역 회귀. **본 PM 자성 #11 (헌법급)**: C39 위반·KinematicObject.cs:76 영역 사전 Read X. **fix**: ProjectileSpawner.CreateFallbackProjectile 영역 Rigidbody2D 영역 5 라인 제거 → `33eaa55` 시점 Static vs Kinematic Trigger 발화 정합 복원 (DebuffStackLimit 정정 영역 그대로 유지). **헌법급 feedback `feedback_new_code_existing_system_dependency_unmeasured` 신설** (신규 코드 영역 기존 시스템 의존성 미실측 금지·재발 차단 3 단계 의무). **(5) 근본 fix 3 2026-05-09 EerieVillage `fe65592`**: PD 2차 재검증 결과 ("판정 X 또는 효과 X") → 본 PM 진단 — **결함 1**: A01·A02·A03·A14·A15 영역 DebuffStackLimit 무차별 3 적용 (본 PM Phase 2-C placeholder 무차별 채움) → StatusApplier 가드 통과 → 의도 외 DebuffStack 트리거. **결함 2**: ProjectileSpawner.CreateFallbackProjectile Rigidbody2D 부재 → Trigger 판정 안정성 부족. **PD 결정 "3 동시 진행해"** — 옵션 3 양 결함 동시 적용. 5 asset DebuffStackLimit 3→0 + Rigidbody2D Kinematic 추가 (gravityScale 0·CollisionDetectionMode2D.Continuous). pm-auditor Conditional Pass + **Major 1 (헌법급 feedback `feedback_scriptable_object_field_blanket_fill.md` 신설·C39-10 위반·근층 원인 명문화)** + Improvement 2. **PD 1차 재검증**: Player 사망 X 정합·**잔존 투사체 1개 영구 노출** (PD 첨부 이미지). **근본 원인 2**: `Resources/Skills/Projectiles/Default` prefab 부재 → `LoadProjectilePrefab` fallback이 `new GameObject`로 Scene 영역 GameObject 생성·반환 → `Object.Instantiate(prefab,...)`가 이를 prefab으로 사용 → 사본은 정상 SelfDestruct·**원본 Scene GameObject는 Initialize 미호출·영구 잔존**. **fix (옵션 J)**: LoadProjectilePrefab은 Resources prefab만 반환·부재 시 null. Trigger 영역 prefab null 시 `CreateFallbackProjectile` 직접 호출 (Instantiate X·자기 자신 발사체). pm-auditor Pass + Minor 1 (line 65 주석 정합 영역 후속) + Improvement 1. | — | **PM 후속**: PD 2차 Play 재검증 (적 처치 후 Player 정상 + 투사체 발사 후 정상 SelfDestruct + 잔존 투사체 0건) → 정상 시 BT12-Dev-Death 완료 아카이브 이동. Enemy 사망 처리 발화 경로 후속 검증 (이전 Improvement 2 영역). | +| BT12-Dev-Death | 2026-05-09 | **스킬 습득 후 사망 버그 지시** — PD 직접 발화: "스킬 습득 후 일정시간이 지나면 왜 플레이어가 갑자기 죽는거지? 버그를 수정해줘." | **PD Console 수령·진단 결과 영역 본 PM 가설 5회 부정확·BT12-Dev 외 본질 결함 (EnemyDeath.Execute 호출 X)·진단 도구 2차 추가 2026-05-10 PD Console + Inspector 자료 수령 대기** | (1) Projectile.OnTriggerEnter2D에 PlayerController 명시 차단 (defensive proxy·자기 hit 차단). (2) Health.Decrement·DecrementSilent·Die에 Debug.Log + System.Environment.StackTrace 추가 (사망 호출자 추적). **(3) 근본 fix 1 2026-05-09 EerieVillage `b37b4a6`**: HealthIsZero.Execute에 sender 검증 가드 추가 (PlayerController 보유 Health만 PlayerDeath 발화). **인수인계서 가설(EnemyController patrol → PlayerEnemyCollision) 부정** — Player Decrement 로그 부재. **근본 원인 1**: HealthIsZero.Execute가 health sender 검증 없이 무차별 Schedule() 발화. BT12-Dev Phase 2-B 투사체가 사상 처음 Enemy.Health.Decrement → Enemy의 HealthIsZero가 PlayerDeath 직결 노출. **PD 결정 (2026-05-09) "1 즉시 적용해"** — A안 1줄 fix 즉시 적용. pm-auditor Pass + Minor 1 (매니페스트 등록 정정 적용) + Improvement 2. **(4) 근본 fix 2 2026-05-09 EerieVillage `33eaa55`**: ProjectileSpawner fallback Scene GameObject 잔존 fix. **(8) 진단 도구 fix 6 2026-05-10 EerieVillage `d6764ce`** (PD A+B 결정·feedback_pm_root_diagnosis_priority 2차 적용): PD Console 분석 결과 본 PM 가설 5회 누적 부정확 자성. 핵심 발견 — 투사체 hit X·**AttackHitbox(BT7-Dev VS 순수형 자동 근접)** 영역 hit (t=4.15·t=4.66 hp 4→1·1→0). t=5.35 [Projectile][Enter] other=Enemy → Enemy Collider 활성 → **EnemyDeath.Execute 호출 X 영역 확정**. AttackHitbox.cs:75 `Schedule` 호출 영역 Execute 영역 호출 영역 의문 → 진단 Debug.Log 2종 추가: [AttackHitbox][Schedule] (col·enemy·hp·t)·[EnemyDeath][Execute] (enemy·collider.enabled·t). pm-auditor 통과 + Minor 1 (회수 트리거 명시) + Improvement 1 (_collider 동시 캡처) 수용. 회수 의무: PD 사망 원인 확정 직후 본 PM revert commit. **(7) 진단 도구 fix 5 2026-05-09 EerieVillage `d27a63f`** (PD A안 결정·feedback_pm_root_diagnosis_priority 영역 적용): PD 4차 보고 "여전히 적에게 제대로 피격되지 않고 통과하고 있어" → 본 PM 가설 4회 누적 부정확·회귀 1회 → 가설 즉시 중단·실측 우선·진단 Debug.Log 영역 추가. Projectile.OnTriggerEnter2D 영역 8 분기 진입·return·Hit 시점 영역 [Projectile][...] prefix 통일 영역 → PD Play Console 영역 호출 여부·other 정보·Layer·EnemyController·Health 영역 정확 진단 → 근본 원인 확정 후 fix. 회수 의무 명시 (PD Console 수령 + 근본 fix 후 일괄 제거). pm-auditor 통과 (조건부) + 권고 4종 (prefix 통일·가설 X·회수 명시·PD 안내) 수용. **(6) 회귀 정정 fix 4 2026-05-09 EerieVillage `9eebbec`** (C3 자진 고지): fix 3 영역 Kinematic Rigidbody2D 추가가 회귀 유발 — PD 3차 보고 "여전히 적이 플레이어의 투사체에 피격되지 않아". **근본**: Enemy = KinematicObject 상속 영역 Kinematic Rigidbody2D → Projectile Kinematic 영역 추가 시 Kinematic vs Kinematic + useFullKinematicContacts=false (기본값) → OnTriggerEnter2D 발화 X 영역 회귀. **본 PM 자성 #11 (헌법급)**: C39 위반·KinematicObject.cs:76 영역 사전 Read X. **fix**: ProjectileSpawner.CreateFallbackProjectile 영역 Rigidbody2D 영역 5 라인 제거 → `33eaa55` 시점 Static vs Kinematic Trigger 발화 정합 복원 (DebuffStackLimit 정정 영역 그대로 유지). **헌법급 feedback `feedback_new_code_existing_system_dependency_unmeasured` 신설** (신규 코드 영역 기존 시스템 의존성 미실측 금지·재발 차단 3 단계 의무). **(5) 근본 fix 3 2026-05-09 EerieVillage `fe65592`**: PD 2차 재검증 결과 ("판정 X 또는 효과 X") → 본 PM 진단 — **결함 1**: A01·A02·A03·A14·A15 영역 DebuffStackLimit 무차별 3 적용 (본 PM Phase 2-C placeholder 무차별 채움) → StatusApplier 가드 통과 → 의도 외 DebuffStack 트리거. **결함 2**: ProjectileSpawner.CreateFallbackProjectile Rigidbody2D 부재 → Trigger 판정 안정성 부족. **PD 결정 "3 동시 진행해"** — 옵션 3 양 결함 동시 적용. 5 asset DebuffStackLimit 3→0 + Rigidbody2D Kinematic 추가 (gravityScale 0·CollisionDetectionMode2D.Continuous). pm-auditor Conditional Pass + **Major 1 (헌법급 feedback `feedback_scriptable_object_field_blanket_fill.md` 신설·C39-10 위반·근층 원인 명문화)** + Improvement 2. **PD 1차 재검증**: Player 사망 X 정합·**잔존 투사체 1개 영구 노출** (PD 첨부 이미지). **근본 원인 2**: `Resources/Skills/Projectiles/Default` prefab 부재 → `LoadProjectilePrefab` fallback이 `new GameObject`로 Scene 영역 GameObject 생성·반환 → `Object.Instantiate(prefab,...)`가 이를 prefab으로 사용 → 사본은 정상 SelfDestruct·**원본 Scene GameObject는 Initialize 미호출·영구 잔존**. **fix (옵션 J)**: LoadProjectilePrefab은 Resources prefab만 반환·부재 시 null. Trigger 영역 prefab null 시 `CreateFallbackProjectile` 직접 호출 (Instantiate X·자기 자신 발사체). pm-auditor Pass + Minor 1 (line 65 주석 정합 영역 후속) + Improvement 1. | — | **PM 후속**: PD 2차 Play 재검증 (적 처치 후 Player 정상 + 투사체 발사 후 정상 SelfDestruct + 잔존 투사체 0건) → 정상 시 BT12-Dev-Death 완료 아카이브 이동. Enemy 사망 처리 발화 경로 후속 검증 (이전 Improvement 2 영역). | | BT12-MVP-A | 2026-05-08 | **경험치·레벨업·스킬 카드 선택 UI** — PD 직접 지시 2건 (1) 적 처치 → EXP → 레벨업마다 스킬 카드 3개 선택 기능 (2) 레벨업 UI (스킬 효과 추후·UI만). PD 첨부 예시 영역 ("기술 선택" 화면 — 카드 3장 가로·색상 배너·원형 아이콘·동심원·"레벨 N"/"최대"·"확인" 버튼). PD 결정 (β) 채택 — BT12-Dev 보류 일부 해제·BT12-MVP-A 분리 항목 진행. **PD 결정 D안 (2026-05-09)** — 기능 우선·그래픽 디테일 차후 영역. | **D안 완료 2026-05-09** | [Phase 1 완료] `프로젝트/EerieVillage/개발/spec/BT12-MVP-A_설계_v1.md` (~600 라인). [Phase 2-A 완료] EerieVillage `047661c` — 시스템 코드 6 + JSON 테이블. [Phase 2-B 코드 완료] EerieVillage `5b2b753` — UI 컴포넌트 2 + LevelUpManager 통합. **[Phase 2-B asset 5 완료 2026-05-08]** EerieVillage `755a51c` — `Assets/Data/SkillPlaceholders/{A01_jineonbu, A05_hagikjin, P01_bonghwanggyeok, P12_saengmyeongkkot, AW01_cheonbugyeongmun}.asset` (5) + 각 .meta (5) + folder meta 2 = 12 파일. C49 표준 — Phase 1 dev-team-lead Opus 첫 정합 호출 + Phase 2 Sonnet 위임 + Phase 3 PM 검증. **dev-team-lead 자진 고지** — 설계서 v1 §2-4 영역 P01·P12·AW01 BT11-Plan v0.2 정합 X (3건 정정 적용). **설계서 v1 §2-4 + §7-1 정정 완료** (commit 후속). PD Editor 가이드 신규 `BT12-MVP-A_Phase2B_PDEditor가이드.md`. 대화로그 엔트리 10. | — | **PM 후속 대기**: ① Phase 2-B B (Prefab) + C (Scene 통합) — **PD 직접 발화 (2026-05-08): "단계1은 완료. 단계2, 3은 개발팀에서 작업해줘" + "E"** → 옵션 E 채택 (Claude Desktop Unity MCP 위임) → 본 PM 의뢰서 작성 `BT12-MVP-A_Phase2B_ClaudeDesktop의뢰서.md` (~16K) → PD Claude Desktop 새 세션 영역 의뢰서 첨부 영역 작업 진행 → EerieVillage commit·push → 본 worktree PM 보고 ② Phase 3 dev-team-lead 통합 검증 (Phase 1 + 2-A + 2-B asset + Prefab + Scene + BT5-Dev/BT7-Dev 회귀) ③ **단계 4 PD Play 검증** (적 처치 → EXP → 레벨업 → UI 노출 → 카드 선택 → 게임 재개) ④ 기획팀 별도 안건 — `01_카드_풀.md` line 114 P12 = "도약강화" 잔존 정정 (`02_스킬_효과_컨셉.md` line 381·418 영역 동기화 X) ⑤ icon sprite asset 5장 별도 작업 ⑥ 완료 아카이브 이동. (PD Editor 가이드 영역 = 옵션 D 보류 영역·차기 영역 활용 가능) | | BT12-Dev | 2026-04-24 23:00 | **스킬 시스템 설계 (C43 "개발팀" 호칭 직접 수령 + C49 시범 적용)** — PD 직접 지시 "개발팀은 기획서를 토대로 스킬 시스템 설계 진행". 기획서 v0.2 (`프로젝트/EerieVillage/기획/content/02_스킬_효과_컨셉.md` 액티브 6카테고리·패시브 5카테고리·각성 4패턴) + CSV v0.3 60종 (`프로젝트/EerieVillage/기획/content/02_스킬_효과_컨셉_v0.3.csv` UTF-8 BOM) 토대. C49 표준 프로세스 시범 적용 (개발팀장 Opus 설계 → 클라이언트팀 Sonnet 구현 → 개발팀장 검증) **[Phase 2-A 완료 2026-05-09]** Skills 13 파일 신규 EerieVillage `87710ba` (Interfaces 4 + Data 4 + Runtime 4 + Events 1). **[Phase 2-B 투사체 완료 2026-05-09]** Effectors 7 파일 신규 + SkillFireEvent 정정 EerieVillage `2f2790c` (Sonnet 자율 push·feedback `feedback_pm_sonnet_subagent_unauthorized_push.md` 신설). **[Phase 2-C 투사체 6 asset 완료 2026-05-09]** PD 결정 "(a)안" — 본 PM 직접 placeholder 수치 작성. EerieVillage `c01f25a` (14 파일·A01·A02·A03·A08·A14·A15 ActiveSkillData ScriptableObject). DisplayName 한글만 (한자 X). 차후 balance-designer 정식 수치. SOT 채택 = PD 본문 (A16 사신 강림·A17 오발탄·A18 죽음의 가시). Phase 2 분할 = (b) 5분할 + b-1 카테고리 6분할. **[Phase 2-D BT12-MVP-A 통합 정정 완료 2026-05-09]** EerieVillage `d53150b` — 6 파일 수정 + 9 .meta 보충. LevelUpManager._pool 제거 → SkillRuntimeFactory.RandomDraw3() · SkillSelectionUI/SkillCardSlot ActiveSkillData 시그니처 전환 · PlayerController Awake PlayerSkillInventory 자동 부착 · Projectile Layer Enemy fallback (Minor 1·proxy) · SkillRuntimeFactory.RandomDraw3 신규. Sonnet 의뢰서 "git add·commit·push 절대 금지" 명시 (feedback `feedback_pm_sonnet_subagent_unauthorized_push.md` 정합). Compile error 0건. pm-auditor Pass + Minor 1. | **진행중** | **[Phase 1 완료 2026-04-24]** 개발팀장 Opus 직접 설계 완결 — `프로젝트/EerieVillage/개발/spec/스킬_시스템_설계_v1.md` (1074 라인, 14 섹션). §1 아키텍처 4계층 · §2 인터페이스 4종(`ISkillRuntime`·`IActiveSkill`·`IPassiveSkill`·`IAwakeningSkill`) + ScriptableObject 3종(`ActiveSkillData`·`PassiveSkillData`·`AwakeningSkillData`) + `PlayerSkillInventory`·`PlayerStats` · §3 CSV→ScriptableObject→Runtime→Health.Decrement 데이터 흐름 + 카테고리 문자열 매핑 · §4 VS 순수형 자동 발동 사이클 (OnTime·OnHit·OnKill + `ActiveSkillRuntime.Tick(deltaTime)` 독립 Cooldown) · §5 `AwakeningManager` 3 조건 동시 충족 + 4 패턴 Dispatcher + 다중 각성 선택 UI · §6 카테고리 매핑 6+5+4 (B는 BT7-Dev `AttackHitbox` 재활용 · 나머지 5 효과 발동기 신설) · §7 Phase 2-A~E 작업 단위 분해 (스크립트 25개·테스트 10건·asset 60개) · §10 BT7-Dev 통합 영역 (Health·AttackHitbox·PlayerAttackTicker·PlayerController 완전 보존 · `Health.OnDamagedEvent` 확장 필요 명시) · §11 기각안 5건 + 대화로그 추가 2건 (총 7건 C32 초과). 대화로그 `공유/대화로그/EerieVillage/2026-04-24.md` `[BT12-Dev Phase 1 완료] 개발팀장 스킬 시스템 설계 v1 (1074 라인)` 엔트리 완결. **C48 3자문 전수 통과**로 Phase 2 클라이언트팀 Sonnet Task는 본 Task에서 호출하지 않고 **PM 차원 별도 위임** 권고 (C48·C49·C50 정합) | **기획서 확정 대기** (PD 2026-04-25 직접 지시 — "기획서 확정되기 전까지 작업 대기") | **재개 트리거**: 기획팀 v0.3 또는 v1.0 확정 + balance-designer 60종 수치 확정 + narrative-designer 카드명 세계관 재매핑 결정 → C50 Phase 2 사전 승인 옵션(a/b/c/d) PD 결정 → 분할 시 Phase 2-A~E 순차 진행 (인터페이스·SO → 중앙 컴포넌트 → 효과 발동기 → 60장 .asset → EditMode 테스트) → Phase 3 개발팀장 검증 → 완료 아카이브. **선행 차단 블로커**: `paths.local.json.UNITY_PROJECT_ROOT: __SET_PER_PC__` 미설정 — 재개 시 PD PC 경로 설정 필요. Phase 1 산출물 1074 라인 설계 문서는 보존 | | BT7-Dev | 2026-04-24 | **BT7-Plan 개발 집행 Phase 1** — VS 순수형 자동 발동(공격 버튼 제거, PlayerAttackTicker 주기 타이머) + 하트 분할 시스템(Health.maxHearts·QuartersPerHeart·IncreaseMaxHearts·Heal·Decrement(int)) + EditMode 테스트 갱신(10→13) + AttackHitbox 쿼터 단위 피해 통합 + TODO 주석(EnemyController.attackDamage balance v0.2 대기) | **진행중** | Unity 편집 6파일 · BT 산출물 2파일 · 백업 6종. **Unity 외부 레포 `D:/NerdNavis/EerieVillage/`**: `Assets/Scripts/Gameplay/{PlayerAttack.cs(개정), PlayerAttackTicker.cs(신설)+.meta}`·`Assets/Scripts/Mechanics/{Health.cs(전면개정), PlayerController.cs(Attack입력제거·Facing public), AttackHitbox.cs(Decrement(damage)통합)}`·`Assets/Settings/InputSystem_Actions.inputactions(Attack액션·바인딩 완전 제거)`·`Assets/Tests/Editor/PlayerAttackTests.cs(10→13)`. **BT 레포**: `프로젝트/EerieVillage/개발/06_BT7-Plan_VS순수형_재구조.md`(신설) · `공유/개발팀_백업/EerieVillage/*.bak_20260424_1551.*`(6종). PD 수동 검증 2종(Asset import+EditMode Runner 실행·Player.prefab에 PlayerAttackTicker 부착+Play 검증) | — | **PM 수행 대기**: pm-auditor 감사 → BT worktree commit → Unity 외부 레포는 PD Editor 실행 시 GitAutoSync 자동 push → Play 검증 결과(13 tests green + 자동 공격 발동 확인) 수령 → balance/01 v0.2 확정 후 후속 Phase(EnemyController·적 ATK 테이블·HUD 하트 UI) 분리 착수 → 완료 아카이브 이동 | diff --git a/공유/대화로그/EerieVillage/2026-05-10.md b/공유/대화로그/EerieVillage/2026-05-10.md new file mode 100644 index 0000000..981144b --- /dev/null +++ b/공유/대화로그/EerieVillage/2026-05-10.md @@ -0,0 +1,137 @@ +# EerieVillage 대화로그 — 2026-05-10 + +--- + +## 엔트리 1 (신설). BT12-Dev PD Console 분석 + 본 PM 가설 5회 부정확 자성 + AttackHitbox·EnemyDeath 진단 도구 추가 (PD A+B) + +**시각**: 2026-05-10 신 세션 (`vigilant-cray-45cc32` worktree·전 세션 진단 도구 직후 일자 변경) +**주체**: 총괄PM 직접 (단순 반복 카탈로그 v1·~5K) + pm-auditor 사전 감사 통과 + Minor 1 + Improvement 1 +**대상**: BT12-Dev-Death 후속 — PD Console 분석 + 본 PM 가설 5회 누적 부정확 자성 + EnemyDeath 사망 처리 X 근본 진단 도구 2차 추가 +**유형**: PD A+B 동시 결정 → 본 PM A 진단 도구 즉시 적용 + B PD 자료 능동 요청 + +### PD 직접 발화 (2026-05-09~10) + +> 5차 보고: "여전히 적이 죽지 않아" +> Console 공유 (스크린샷) +> 본 PM 진단 보고 후: "A+B 진행해" — A 진단 Debug.Log 추가 + B PD Enemy.prefab Inspector·Animator Controller 자료 공유 동시 + +### PD Console 정확 분석 (가설 X·실측) + +| 시각 | 이벤트 | 호출자 | +|------|--------|--------| +| t=4.15 | Health@Enemy Decrement(damage=3) hp 4→1 | **AttackHitbox** (BT7-Dev 자동 근접·`[Projectile][Enter] other=Enemy` 부재) | +| t=4.43 | [Projectile][Enter] other=Player → Return PlayerController | Projectile (Player 차단·정합) | +| t=4.66 | Health@Enemy Decrement(damage=3) hp 1→0 | **AttackHitbox** (즉사) — line 70 `!IsAlive` true → line 75 `Schedule` 호출 의무 | +| t=5.35 | [Projectile][Enter] other=Enemy layer=14 → isEnemy=True → **Health not alive hp=0** | Projectile (Enemy 영역 살아있음·Collider 활성) | + +**핵심 발견** (코드 실측 + Console 정합): +- **투사체는 Enemy를 hit X** +- **AttackHitbox(BT7-Dev VS 순수형 자동 근접 공격)** 영역 hit +- **t=5.35 영역 Enemy._collider 활성** = **EnemyDeath.Execute 호출 X 영역 확정** (line 20 `_collider.enabled = false` 적용 X) + +### 본 PM 가설 5회 누적 부정확 자성 (자진 고지·feedback 환기) + +| 회차 | 가설 | 결과 | +|------|------|------| +| 1 | HealthIsZero sender 가드 | ✅ Player 사망 X 정합 | +| 2 | 잔존 투사체 옵션 J | ✅ 정합 | +| 3 | DebuffStackLimit + Rigidbody2D 추가 | ❌ Rigidbody2D 회귀 유발 | +| 4 | Rigidbody2D 제거·"이전 시점 복원" 가정 | ❌ 여전히 피격 X | +| 5 | "투사체 사망 처리 경로 부재" 옵션 A·B·C 권고 | ❌ **투사체 hit X·AttackHitbox hit·잘못된 진단** | + +**적용 feedback**: `feedback_pm_root_diagnosis_priority` (헌법급) 2차 적용 — 가설 즉시 중단·실측 우선·진단 도구 우선·PD 능동 자료 수령. + +### A 진단 Debug.Log 추가 (옵션) + +`Assets/Scripts/Mechanics/AttackHitbox.cs:75` 직전: +```csharp +Debug.Log($"[AttackHitbox][Schedule] col={col.name} enemy={(enemy != null ? enemy.name : "NULL")} hp={health.CurrentHP} t={Time.time:F2}"); +``` + +`Assets/Scripts/Gameplay/EnemyDeath.cs:16` 진입 (Improvement 1·_collider 동시 캡처): +```csharp +Debug.Log($"[EnemyDeath][Execute] enemy={(enemy != null ? enemy.name : "NULL")} collider={(enemy != null && enemy._collider != null ? enemy._collider.enabled.ToString() : "NULL")} t={Time.time:F2}"); +``` + +→ Schedule 호출 영역 + Execute 호출 영역 + collider 상태 영역 정확 진단. + +### B PD 자료 능동 요청 (병렬·실측 정확화) + +| # | 자료 | +|---|------| +| 1 | **Enemy.prefab Inspector 스크린샷** — Layer (14)·Components (Rigidbody2D type·Collider2D 영역 root + 자식·EnemyController·Health·Animator) | +| 2 | **Enemy.controller (Animator Controller) Parameters 스크린샷** — `dead`·`death`·`hit` parameter 등재 영역 | +| 3 | **Console 영역 [AttackHitbox][Schedule]·[EnemyDeath][Execute] 출력 영역** — A 적용 후 PD Play 영역 결과 | + +### 결정·근거·영향 (pm-auditor 권고 4종 수용) + +**결정**: PD A+B 동시 — A 본 PM 진단 도구 추가 (~3K) + B PD Inspector·Controller 자료 공유 동시. + +**근거**: 본 PM 가설 5회 누적 부정확 (회귀 1회) → feedback_pm_root_diagnosis_priority 2차 의무 영역 진단 도구 우선·PD 능동 자료 수령 영역 정확 진단. + +**영향**: +- 회귀 위험 0건 (Debug.Log만 추가·기존 분기 변경 X) +- PD Console 영역 [AttackHitbox][Schedule] 출력 여부 + [EnemyDeath][Execute] 출력 여부 영역 정확 진단 +- B Inspector 자료 영역 자식 collider·Animator parameter·Layer 영역 검증 + +### pm-auditor 사전 감사 결과 (통과 + Minor 1 + Improvement 1) + +| 등급 | 영역 | 본 PM 적용 | +|------|------|---------| +| 통과 | C2·C5·C19-2·C28·C42-7 J·회귀 위험 0건·prefix 통일·feedback 의무 적용 | — | +| Minor 1 | 회수 트리거·책임·commit 메시지 PD 지시 로그·대화로그 영역 명시 | ✅ 본 엔트리 + PD 지시 로그 영역 명시 | +| Improvement 1 | EnemyDeath.Execute 진입 영역 _collider.enabled 동시 캡처 | ✅ 채택 (정합 검증 영역 분량 최소) | + +### 회수 의무 명시 (Minor 1·헌법급 명문화) + +| 항목 | 내용 | +|------|------| +| **회수 트리거** | PD 사망 원인 확정 직후 (또는 PD 종결 선언) | +| **회수 책임** | 본 PM (집행 PM·dev-team-lead 폐기 영역) | +| **회수 commit 메시지** | `revert(BT12-Dev): AttackHitbox·EnemyDeath 진단 Debug.Log 회수` | +| **회수 대상** | AttackHitbox.cs:75 직전 1줄 + EnemyDeath.cs:16 진입 1줄 (총 2줄) | +| **회수 시점** | `[Projectile]` 진단 (Projectile.cs 8 분기) 영역 동시 회수 검토 (별도 commit 또는 통합) | + +### EerieVillage commit `d6764ce` (본 PM 직접 push) + +- 2 파일 수정 (AttackHitbox.cs + EnemyDeath.cs ·각 1줄 추가) · 7 insertions · 0 deletions +- main 영역 push 정합 (`d27a63f..d6764ce`) +- staging 정합 + +### 본 PM 자성 신규 1건 (가설 누적 부정확) + +| # | 자성 | +|---|------| +| **12** | **가설 5회 누적 부정확** — feedback_pm_root_diagnosis_priority 2차 적용 영역. 본 PM 가설 영역 코드·Console 실측 선행 X 영역 추정 영역 가설. 5차 옵션 A·B·C 권고 영역 = 투사체 hit 가정 자체 오류 (Console 실측 영역 AttackHitbox hit 영역 정합). PD가 Console 영역 능동 공유 영역 영역 본 PM 진단 정정 영역. **재발 차단**: 가설 작성 직전 PD Console 영역 능동 수령 + 코드 실측 + StackTrace 영역 호출자 영역 직접 확인 의무 (3 단계 실측). | + +### 산출물 + +- **EerieVillage** (commit `d6764ce`): + - `Assets/Scripts/Mechanics/AttackHitbox.cs` (line 75 직전 진단 Debug.Log 1줄·회수 의무 주석) + - `Assets/Scripts/Gameplay/EnemyDeath.cs` (line 16 진입 진단 Debug.Log 1줄·회수 의무 주석) +- **BurningTimes** (본 commit): + - 본 엔트리 1 (2026-05-10 신규 일자) + - PD 지시 로그 BT12-Dev-Death 영역 fix 6 (진단 도구 2차) 행 갱신·진행 상태 갱신 + +### 관련 규칙·자산 + +- **C2** 근본 해결 (proxy 영역 X·진단 도구 = 근본 원인 확정 도구·feedback 2차 적용) +- **C3** 이슈 은폐 X (가설 5회 누적 부정확 자진 고지) +- **C5·C44** 정직성·팩트 우선 (Console + 코드 실측 영역 본 PM 가설 부정 자진 고지) +- **C19-2** PD A+B 명시 = C1 승인 정합 +- **C28** 코드 수정 무승인 외 — PD 직접 지시 영역 +- **C35-9** 매니페스트 등록 정합 +- **C36** PM 자율 외연 (PD A+B 명시·방향·원칙 변경 X) +- **C42-7 J 그룹** 작업 전 시스템 반영 실측 (Console + 코드 Read 정합) +- **C49** 단순 반복 카탈로그 v1 +- **C50** 분량 (~5K·PD 사전 승인 30~50K 영역 정합) +- **feedback `feedback_pm_root_diagnosis_priority`** 2차 적용 (가설 5회 누적 부정확) +- **feedback `feedback_new_code_existing_system_dependency_unmeasured`** 정합 (참조 클래스 정의 Read 정합) + +### 후속 (PM 의무·회수 의무) + +- **PD A 결과 — Editor Refresh + Play → Console 영역 `[AttackHitbox][Schedule]`·`[EnemyDeath][Execute]` 출력 영역 결과 공유** +- **PD B 결과 — Enemy.prefab Inspector + Enemy.controller Parameters 스크린샷 공유** +- **양 자료 수령 후 본 PM 정확 fix 진행 → 사망 원인 확정 → 진단 도구 회수 (Projectile + AttackHitbox + EnemyDeath 통합)** +- **BT12-Dev-Death 완료 아카이브 이동** (사망 처리 정합 + Animator parameter 영역 후속 별도 안건 분리 가능) +- balance-designer 60종 정식 수치·Enemy 사망 처리 발화 경로·line 65 주석 (이전 후속)