Files
hakorune/docs/research/ai-dual-mode-development/conversations/02_architect_advice.md
Moe Charm 4e1b595796 AI協調開発研究ドキュメントの完成と Phase 10.9-β 進捗
【AI協調開発研究】
- AI二重化モデルの学術論文draft完成(workshop_paper_draft.md)
- 「隠れた危機」分析とbirthの原則哲学化
- TyEnv「唯一の真実」協調会話を保存・研究資料に統合
- papers管理構造の整備(wip/under-review/published分離)

【Phase 10.9-β HostCall進捗】
- JitConfigBox: relax_numeric フラグ追加(i64→f64コアーション制御)
- HostcallRegistryBox: 署名検証・白黒リスト・コアーション対応
- JitHostcallRegistryBox: Nyash側レジストリ操作API
- Lower統合: env直読 → jit::config::current() 参照に統一
- 数値緩和設定: NYASH_JIT_HOSTCALL_RELAX_NUMERIC/Config.set_flag

【検証サンプル拡充】
- math.sin/cos/abs/min/max 関数スタイル(examples/jit_math_function_style_*.nyash)
- 境界ケース: 署名不一致・コアーション許可・mutating拒否サンプル
- E2E実証: String.length→allow, Array.push→fallback, math関数の署名一致観測

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-08-28 12:09:09 +09:00

3.0 KiB
Raw Blame History

俯瞰AIArchitect ChatGPT5のアドバイス

コンテキスト

にゃー「これがアドバイザーchatgpt5の内容」

俯瞰AIの分析

わかった。ここはMIRのBoxCall引数配線を直すのが本丸。観測の強化は"ついで"に入れておく。 理由Registry/Policy/Lower はもう利く。今詰まってるのは MIR→Lower に args が落ちてない一点。ここを刺すと native_f64=1math.* が即通る。


決定

  1. 先に MIR側で BoxCall の引数を正しく生成(最小差分)。
  2. 併せて Events に argc/arg_types を追加(デバッグ保険)。

① MIR修正最小パッチ雛形

IR定義確認

// ir.rs
pub enum Inst {
    // 既存:
    // ...
    BoxCall { target: Sym, recv: Option<Value>, args: Vec<Value>, dst: Option<Value> }, // ← args 必須
}

MIR Builder式の降ろし先を1点集中

// src/mir/builder/expr.rs
fn lower_call_expr(&mut self, e: &CallExpr) -> Value {
    // 1) 受け手recvとターゲット解決math.* は recv=None, target="math.sin" 等)
    let (target, recv, arg_exprs) = match e.kind {
        CallKind::Method { ref recv, ref name, ref args } => {
            (Sym::from_method(name), Some(self.lower_expr(recv)), args)
        }
        CallKind::Func   { ref path,  ref args } => {
            (Sym::from_path(path), None, args)
        }
    };

    // 2) 引数を **必ず** Vec<Value> に積む(ここが今回の本丸)
    let mut argv = Vec::with_capacity(arg_exprs.len());
    for a in arg_exprs {
        argv.push(self.lower_expr(a));
    }

    // 3) 結果レジスタを用意して BoxCall 生成
    let dst = self.new_temp();
    self.push(Inst::BoxCall { target, recv, args: argv, dst: Some(dst) });
    dst
}

② LowerCoercion と Registry/Policy/Events の順序)

// src/jit/lower/builder.rs
fn lower_boxcall(&mut self, inst: &Inst) -> LowerResult {
    // Registry で署名確認i64→f64 許容)
    match self.registry.check_with_coercion(target, &observed, self.cfg.native_f64) {
        Check::AllowCoerceF64(sig, mask) => {
            // mask[i]==true なら i64→f64 にキャスト挿入
            let mut coerced = Vec::with_capacity(args.len());
            for (i, &v) in args.iter().enumerate() {
                coerced.push(if mask[i] { self.cast_i64_to_f64(v) } else { v });
            }
            JitEventsBox::hostcall(func, target.as_str(), "ro", "allow(coerce_f64)");
            self.emit_hostcall_ro(target, recv, &coerced, dst, sig)
        }
        // ...
    }
}

分析の特徴

  1. 問題の本質を一行で表現

    • 「MIR→Lower に args が落ちてない一点」
  2. 解決策の明確さ

    • 最小差分での修正方法を具体的に提示
    • コード例で実装イメージを共有
  3. 副次的改善も忘れない

    • 「観測の強化は"ついで"に」
    • argc/arg_types追加でデバッグ保険