## ✅ Fixed Issues ### 1. `local` keyword tokenization (commit 9aab64f7) - Added Stage-3 gate for LOCAL/TRY/CATCH/THROW keywords - LOCAL now only active when NYASH_PARSER_STAGE3=1 ### 2. `env.local.get` keyword conflict - File: `lang/src/compiler/entry/compiler_stageb.hako:21-23` - Problem: `.local` in member access tokenized as `.LOCAL` keyword - Fix: Commented out `env.local.get("HAKO_SOURCE")` line - Fallback: Use `--source` argument (still functional) ### 3. `flow` keyword missing - Added FLOW to TokenType enum (`src/tokenizer/kinds.rs`) - Added "flow" → TokenType::FLOW mapping (`src/tokenizer/lex_ident.rs`) - Added FLOW to Stage-3 gate (requires NYASH_PARSER_STAGE3=1) - Added FLOW to parser statement dispatch (`src/parser/statements/mod.rs`) - Added FLOW to declaration handler (`src/parser/statements/declarations.rs`) - Updated box_declaration parser to accept BOX or FLOW (`src/parser/declarations/box_definition.rs`) - Treat `flow FooBox {}` as syntactic sugar for `box FooBox {}` ### 4. Module namespace conversion - Renamed `lang.compiler.builder.ssa.local` → `localvar` (avoid keyword) - Renamed file `local.hako` → `local_ssa.hako` - Converted 152 path-based using statements to namespace format - Added 26+ entries to `nyash.toml` [modules] section ## ⚠️ Remaining Issues ### Stage-B selfhost compiler performance - Stage-B compiler not producing output (hangs/times out after 10+ seconds) - Excessive PHI debug output suggests compilation loop issue - Needs investigation: infinite loop or N² algorithm in hako compiler ### Fallback JSON version mismatch - Rust fallback (`--emit-mir-json`) emits MIR v1 JSON (schema_version: "1.0") - Smoke tests expect MIR v0 JSON (`"version":0, "kind":"Program"`) - stageb_helpers.sh fallback needs adjustment ## Test Status - Parse errors: FIXED ✅ - Keyword conflicts: FIXED ✅ - Stage-B smoke tests: STILL FAILING ❌ (performance issue) 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
40 lines
1.6 KiB
Rust
40 lines
1.6 KiB
Rust
/*!
|
|
* child_env.rs — Runner helper utilities (OOB strict, quiet exit policies)
|
|
*/
|
|
|
|
pub fn pre_run_reset_oob_if_strict() {
|
|
if crate::config::env::oob_strict_fail() {
|
|
crate::runtime::observe::reset();
|
|
}
|
|
}
|
|
|
|
pub fn post_run_exit_if_oob_strict_triggered() -> ! {
|
|
if crate::config::env::oob_strict_fail() && crate::runtime::observe::oob_seen() {
|
|
eprintln!("[gate-c][oob-strict] Out-of-bounds observed → exit(1)");
|
|
std::process::exit(1);
|
|
}
|
|
// If not strict or no OOB, return to caller path; caller should exit(…) itself.
|
|
// This function is defined as diverging only when it actually exits above; otherwise it does nothing.
|
|
// To keep signature simple for callers, they should not rely on this returning.
|
|
std::process::exit(0)
|
|
}
|
|
|
|
/// Apply a consistent child environment for selfhost/core wrapper executions.
|
|
/// - Forces JSON-only quiet pipe
|
|
/// - Disables plugins to avoid host-side side effects
|
|
/// - Disables file-based using resolution (namespace-first policy)
|
|
/// - Skips nyash.toml env injection to reduce drift
|
|
pub fn apply_core_wrapper_env(cmd: &mut std::process::Command) {
|
|
// Remove noisy or recursive toggles
|
|
cmd.env_remove("NYASH_USE_NY_COMPILER");
|
|
cmd.env_remove("NYASH_CLI_VERBOSE");
|
|
// Enforce quiet JSON capture
|
|
cmd.env("NYASH_JSON_ONLY", "1");
|
|
// Restrict environment to avoid plugin/using drift
|
|
cmd.env("NYASH_DISABLE_PLUGINS", "1");
|
|
cmd.env("NYASH_SKIP_TOML_ENV", "1");
|
|
cmd.env("NYASH_USING_AST", "0");
|
|
cmd.env("NYASH_ALLOW_USING_FILE", "0");
|
|
cmd.env("HAKO_ALLOW_USING_FILE", "0");
|
|
}
|