Files
hakorune/src/box_operators/helpers.rs
nyash-codex f9d100ce01 chore: Phase 25.1 完了 - LoopForm v2/Stage1 CLI/環境変数削減 + Phase 26-D からの変更
Phase 25.1 完了成果:
-  LoopForm v2 テスト・ドキュメント・コメント完備
  - 4ケース(A/B/C/D)完全テストカバレッジ
  - 最小再現ケース作成(SSAバグ調査用)
  - SSOT文書作成(loopform_ssot.md)
  - 全ソースに [LoopForm] コメントタグ追加

-  Stage-1 CLI デバッグ環境構築
  - stage1_cli.hako 実装
  - stage1_bridge.rs ブリッジ実装
  - デバッグツール作成(stage1_debug.sh/stage1_minimal.sh)
  - アーキテクチャ改善提案文書

-  環境変数削減計画策定
  - 25変数の完全調査・分類
  - 6段階削減ロードマップ(25→5、80%削減)
  - 即時削除可能変数特定(NYASH_CONFIG/NYASH_DEBUG)

Phase 26-D からの累積変更:
- PHI実装改善(ExitPhiBuilder/HeaderPhiBuilder等)
- MIRビルダーリファクタリング
- 型伝播・最適化パス改善
- その他約300ファイルの累積変更

🎯 技術的成果:
- SSAバグ根本原因特定(条件分岐内loop変数変更)
- Region+next_iパターン適用完了(UsingCollectorBox等)
- LoopFormパターン文書化・テスト化完了
- セルフホスティング基盤強化

Co-Authored-By: Claude <noreply@anthropic.com>
Co-Authored-By: ChatGPT <noreply@openai.com>
Co-Authored-By: Task Assistant <task@anthropic.com>
2025-11-21 06:25:17 +09:00

64 lines
1.8 KiB
Rust

//! Helper functions and type conversion utilities for Box operators
//!
//! This module contains utility functions used across the operator system,
//! primarily for type conversion and validation.
use crate::box_trait::{NyashBox, StringBox};
/// Concatenate two boxes by converting both to strings
///
/// This function provides the fallback behavior for addition operations
/// when type-specific arithmetic is not available - it converts both
/// operands to strings and concatenates them.
///
/// # Arguments
///
/// * `left` - The left operand
/// * `right` - The right operand
///
/// # Returns
///
/// A StringBox containing the concatenated string representation
/// of both operands.
///
/// # Example
///
/// ```rust
/// let left = IntegerBox::new(42);
/// let right = BoolBox::new(true);
/// let result = concat_result(&left, &right);
/// // result will be StringBox("42true")
/// ```
#[inline]
pub fn concat_result(left: &dyn NyashBox, right: &dyn NyashBox) -> Box<dyn NyashBox> {
let l = left.to_string_box();
let r = right.to_string_box();
Box::new(StringBox::new(format!("{}{}", l.value, r.value)))
}
/// Check if a repetition count is within safe limits
///
/// This function validates that string repetition operations stay within
/// reasonable bounds to prevent memory exhaustion attacks.
///
/// # Arguments
///
/// * `times` - The number of repetitions requested
///
/// # Returns
///
/// `true` if the repetition count is safe (0-10,000), `false` otherwise.
///
/// # Example
///
/// ```rust
/// assert!(can_repeat(5)); // OK
/// assert!(can_repeat(10000)); // OK (at limit)
/// assert!(!can_repeat(10001)); // Too many
/// assert!(!can_repeat(-1)); // Negative
/// ```
#[inline]
pub fn can_repeat(times: i64) -> bool {
(0..=10_000).contains(&times)
}