📚 Phase 15 - セルフホスティング戦略の明確化とEXE-first実装

## 主な変更点

### 🎯 戦略の転換と明確化
- PyVMを開発ツールとして位置づけ(本番経路ではない)
- EXE-first戦略を明確に優先(build_compiler_exe.sh実装済み)
- Phase順序の整理: 15.2(LLVM)→15.3(コンパイラ)→15.4(VM)

### 🚀 セルフホスティング基盤の実装
- apps/selfhost-compiler/にNyashコンパイラMVP実装
  - compiler.nyash: メインエントリー(位置引数対応)
  - boxes/: parser_box, emitter_box, debug_box分離
- tools/build_compiler_exe.sh: ネイティブEXEビルド+dist配布
- Python MVPパーサーStage-2完成(local/if/loop/call/method/new)

### 📝 ドキュメント整備
- Phase 15 README/ROADMAP更新(Self-Hosting優先明記)
- docs/guides/exe-first-wsl.md: WSLクイックスタート追加
- docs/private/papers/: 論文G~L、爆速事件簿41事例収録

### 🔧 技術的改善
- JSON v0 Bridge: If/Loop PHI生成実装(ChatGPT協力)
- PyVM/llvmliteパリティ検証スイート追加
- using/namespace機能(gated実装、Phase 15では非解決)

## 次のステップ
1. パーサー無限ループ修正(未実装関数の実装)
2. EXEビルドとセルフホスティング実証
3. c0→c1→c1'ブートストラップループ確立

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

Co-Authored-By: Claude <noreply@anthropic.com>
This commit is contained in:
Selfhosting Dev
2025-09-15 18:44:49 +09:00
parent 8f11c79f19
commit d90216e9c4
68 changed files with 4521 additions and 1641 deletions

View File

@ -15,7 +15,8 @@ Grammar (subset):
logic := compare (('&&'|'||') compare)*
compare := sum (('=='|'!='|'<'|'>'|'<='|'>=') sum)?
sum := term (('+'|'-') term)*
term := factor (('*'|'/') factor)*
term := unary (('*'|'/') unary)*
unary := '-' unary | factor
factor := INT | STRING | IDENT call_tail* | '(' expr ')' | 'new' IDENT '(' args? ')'
call_tail:= '.' IDENT '(' args? ')' # method
| '(' args? ')' # function call
@ -126,11 +127,17 @@ class P:
rhs=self.term(); lhs={"type":"Binary","op":op,"lhs":lhs,"rhs":rhs}
return lhs
def term(self):
lhs=self.factor()
lhs=self.unary()
while self.cur().kind in ('*','/'):
op=self.cur().kind; self.i+=1
rhs=self.factor(); lhs={"type":"Binary","op":op,"lhs":lhs,"rhs":rhs}
rhs=self.unary(); lhs={"type":"Binary","op":op,"lhs":lhs,"rhs":rhs}
return lhs
def unary(self):
if self.cur().kind=='-':
self.i+=1
rhs=self.unary()
return {"type":"Binary","op":"-","lhs":{"type":"Int","value":0},"rhs":rhs}
return self.factor()
def factor(self):
tok=self.cur()
if self.eat('INT'): return {"type":"Int","value":tok.val}