Files
hakorune/tools/hako_check
nyash-codex 140a3d5715 feat(hako_check): Phase 171-2 JsonParserBox integration (37.6% code reduction)
🎉 手書き JSON パーサ大幅削減成功!

🔧 実装内容:
- analysis_consumer.hako: 手書き JSON パーサ削除(266行、37.6%削減)
  - 708行 → 442行
  - 9つの解析メソッド削除
- JsonParserBox 統合(15行実装、95%削減達成)
- using 文追加: tools.hako_shared.json_parser

⚠️ 発見された重大な問題:
- using statement が静的 Box のメソッドを正しく解決できない
- 症状: Unknown method '_skip_whitespace' on InstanceBox
- 根本原因: 静的 Box の using サポートが Phase 15.5+ で必要

📊 現在の状態:
-  コード統合完了(37.6%削減)
-  using 文追加完了
-  コンパイル成功
- ⚠️ 実行時エラー(using 制限のため)

🎯 次のステップ:
- Phase 173 で using system 修正
- 静的 Box のメソッド解決を修正
- JsonParserBox 統合を完全動作させる

📋 ドキュメント:
- 詳細な実装結果を phase171-2_hako_check_integration.md に記録
- using 制限の発見と対応方針を明記
- Option A (推奨): Phase 173 で using system 修正を待つ
- Option B (代替): 一時的にインライン化

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

Co-Authored-By: Claude <noreply@anthropic.com>
2025-12-04 17:03:14 +09:00
..

Hako Check — Diagnostics Contract (MVP)

This tool lints .hako sources and emits diagnostics.

Diagnostics schema (typed)

  • Map fields:
    • rule: string like "HC011"
    • message: string (human-readable, one line)
    • file: string (path)
    • line: int (1-based)
    • severity: string ("error"|"warning"|"info"), optional (default: warning)
    • quickFix: string, optional

Backwards compatibility

  • Rules may still out.push("[HCxxx] ...") with a single-line string.
  • The CLI accepts both forms. String diagnostics are converted to typed internally.

Suppression policy

  • HC012 (dead static box) takes precedence over HC011 (unreachable method).
  • If a box is reported by HC012, HC011 diagnostics for methods in that box are suppressed at aggregation.

Quiet / JSON output

  • When --format json-lsp is used, output is pure JSON (pretty). Combine with NYASH_JSON_ONLY=1 in the runner to avoid extra lines.
  • Non-JSON formats print human-readable lines per finding.

Planned AST metadata (parser_core.hako)

  • boxes[].span_line: starting line of the static box declaration.
  • methods[].arity: parameter count as an integer.
  • boxes[].is_static: boolean.

Notes

  • Prefer AST intake; text scans are a minimal fallback.
  • For tests, use tools/hako_check/run_tests.sh.

Analyzer policy (plugins)

  • Tests/CI/Analyzer run without plugins by default: NYASH_DISABLE_PLUGINS=1 and NYASH_JSON_ONLY=1.
  • File I/O is avoided by passing source text via --source-file <path> <text>.
  • When plugins are needed (dev/prod), set NYASH_FILEBOX_MODE=auto and provide [libraries] in nyash.toml.

Default test env (recommended)

  • NYASH_DISABLE_PLUGINS=1 avoid dynamic plugin path and noise
  • NYASH_BOX_FACTORY_POLICY=builtin_first prefer builtin/ring1 for stability
  • NYASH_DISABLE_NY_COMPILER=1 and HAKO_DISABLE_NY_COMPILER=1 disable inline compiler in tests
  • NYASH_JSON_ONLY=1 stdout is pure JSON (logs go to stderr)

Known Limitations

HC017: Non-ASCII Quotes Detection (Temporarily Skipped)

Status: ⏸️ Skipped until UTF-8 support is available

Reason: This rule requires UTF-8 byte-level manipulation to detect smart quotes (" " ' ') in source code. Nyash currently lacks:

  • Byte array access for UTF-8 encoded strings
  • UTF-8 sequence detection capabilities (e.g., detecting 0xE2 0x80 0x9C for ")
  • Unicode character property inspection methods

Technical Requirements: One of the following implementations is needed:

  • Implement ByteArrayBox with UTF-8 encoding/decoding methods (to_bytes(), from_bytes())
  • Add built-in Unicode character property methods to StringBox (e.g., is_ascii(), char_code_at())
  • Provide low-level byte access methods like string.get_byte(index) or string.byte_length()

Re-enable Timeline: Planned for Phase 22 (Unicode Support Phase) or when ByteArrayBox lands

Test Files:

Implementation File: rules/rule_non_ascii_quotes.hako - Currently returns 0 (disabled) in _has_fancy_quote()

Current Workaround: The test is automatically skipped in run_tests.sh to prevent CI failures until UTF-8 support is implemented.


Rules

  • Core implemented (green): HC011 Dead Methods, HC012 Dead Static Box, HC015 Arity Mismatch, HC016 Unused Alias, HC018 Toplevel local, HC021 Analyzer IO Safety, HC022 Stage3 Gate, HC031 Brace Heuristics
  • Temporarily skipped: HC017 NonASCII Quotes (UTF-8 support required)
  • Pending fixtures update: HC013 Duplicate Method, HC014 Missing Entrypoint

CLI options

  • --rules a,b,c limit execution to selected rules.
  • --skip-rules a,b skip selected.
  • --no-ast (default) avoids AST parser; --force-ast enables AST path (use sparingly while PHI is under polish).

Tips

  • JSON-only output: set NYASH_JSON_ONLY=1 to avoid log noise in stdout; diagnostics go to stdout, logs to stderr.
  • For multiline --source-file payloads, CLI also provides HEX-escaped JSON in NYASH_SCRIPT_ARGS_HEX_JSON for robust transport; the VM prefers HEX→JSON→ARGV.