refactor(mir): Remove TypeContext legacy fields (Phase 2-3/7)
完全移行→削除の安全順序(Option C)に従い、TypeContext の deprecated フィールドと sync helpers を完全削除。 ⚠️ 危険ゾーン: TypeFactsBox 等の同名フィールドと混同しないよう、 ファイル単位で手作業移行を実施。 ## Changes - Migrated all MirBuilder access sites to type_ctx.* (manual, 40+ files) - Removed 3 deprecated fields (value_types, value_kinds, value_origin_newbox) - Removed 2 sync helpers (sync_type_ctx_to_legacy, sync_legacy_to_type_ctx) - Verified TypeFactsBox, CalleeGuardBox unchanged (no false positives) ## Tests - cargo test --release --lib: 1029/1033 PASS - TypeFactsBox integration: PASS (borrowed references unchanged) - Deprecation warnings: 456 → 255 (-201, -44%) ## Safety Verification ✅ TypeFactsBox unchanged (still uses &'a BTreeMap borrowed references) ✅ CalleeGuardBox unchanged ✅ CalleeResolverBox unchanged ✅ BoxCompilationContext unchanged Phase 2 Progress: 3/7 contexts complete (43%) - ✅ MetadataContext - ✅ CoreContext - ✅ TypeContext (this commit) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Sonnet 4.5 <noreply@anthropic.com>
This commit is contained in:
@ -112,17 +112,17 @@ pub fn ensure(builder: &mut MirBuilder, v: ValueId, kind: LocalKind) -> ValueId
|
||||
);
|
||||
}
|
||||
// Success: register metadata and cache
|
||||
if let Some(t) = builder.value_types.get(&v).cloned() {
|
||||
builder.value_types.insert(loc, t);
|
||||
if let Some(t) = builder.type_ctx.value_types.get(&v).cloned() {
|
||||
builder.type_ctx.value_types.insert(loc, t);
|
||||
}
|
||||
if let Some(cls) = builder.value_origin_newbox.get(&v).cloned() {
|
||||
builder.value_origin_newbox.insert(loc, cls.clone());
|
||||
if let Some(cls) = builder.type_ctx.value_origin_newbox.get(&v).cloned() {
|
||||
builder.type_ctx.value_origin_newbox.insert(loc, cls.clone());
|
||||
|
||||
// CRITICAL FIX: For receiver kind, if type is missing but origin exists,
|
||||
// infer MirType::Box from origin
|
||||
if kind == LocalKind::Recv && builder.value_types.get(&loc).is_none() {
|
||||
if kind == LocalKind::Recv && builder.type_ctx.value_types.get(&loc).is_none() {
|
||||
builder
|
||||
.value_types
|
||||
.type_ctx.value_types
|
||||
.insert(loc, crate::mir::MirType::Box(cls));
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user