Stage-B: route FlowEntry context (using/extern) and default Stage-B entry

This commit is contained in:
nyash-codex
2025-11-01 03:03:51 +09:00
parent c868667e26
commit 1f415e733c
6 changed files with 29 additions and 11 deletions

View File

@ -9,12 +9,27 @@ static box FlowEntryBox {
emit_v0_from_ast(ast_json, prefer_cfg) {
return PipelineV2.lower_stage1_to_mir(ast_json, prefer_cfg)
}
// Emit v0 with using context (alias/module maps) — prefer this when names need resolution
// Emit v0 with using contextalias/module maps
emit_v0_from_ast_with_usings(ast_json, prefer_cfg, usings_json, modules_json) {
print("[DEBUG FlowEntry] emit_v0_from_ast_with_usings called")
local result = PipelineV2.lower_stage1_to_mir_with_usings(ast_json, prefer_cfg, usings_json, modules_json)
print("[DEBUG FlowEntry] result=" + result)
return result
return PipelineV2.lower_stage1_to_mir_with_usings(ast_json, prefer_cfg, usings_json, modules_json)
}
// Emit v0 with optional using / extern metadataStageB entry
emit_v0_from_ast_with_context(ast_json, prefer_cfg, usings_json, modules_json, externs_json) {
local used_with_usings = 0
local out = null
if usings_json != null && usings_json != "" && usings_json != "[]" {
out = PipelineV2.lower_stage1_to_mir_with_usings(ast_json, prefer_cfg, usings_json, modules_json)
if out != null { used_with_usings = 1 }
}
if out == null {
out = PipelineV2.lower_stage1_to_mir(ast_json, prefer_cfg)
}
if externs_json != null && externs_json != "" && externs_json != "[]" && used_with_usings == 0 {
local j1 = PipelineV2.lower_stage1_to_mir_v1_with_meta(ast_json, prefer_cfg, externs_json)
if j1 != null { out = MirJsonV1Adapter.to_v0(j1) }
}
return out
}
// Emit v1 → v0 互換 JSONunified mir_call を一旦生成して適応)。自己ホスト実行向け