- Add MIR26 doc≡code sync test (tests/mir_instruction_set_sync.rs) - Quiet snapshots; filter plugin/net logs; golden all green - Delegate VM phi selection to LoopExecutor (borrow-safe) - ResultBox migration: remove legacy box_trait::ResultBox paths - VM BoxRef arithmetic fallbacks via toString().parse::<i64>() - Bridge BoxCall(InstanceBox) to Class.method/arity in VM - Fix Effects purity (READ -> readonly, not pure) - Mark Catch as CONTROL to prevent DCE; Try/Catch test green - Add env-gated debug logs (effects, verifier, mir-printer, trycatch, ref, bin) - Update CURRENT_TASK with progress and next steps
83 lines
2.2 KiB
Rust
83 lines
2.2 KiB
Rust
/*!
|
|
* Nyash Rust Implementation - Everything is Box in Memory Safe Rust
|
|
*
|
|
* This is the main entry point for the Rust implementation of Nyash,
|
|
* demonstrating the "Everything is Box" philosophy with Rust's ownership system.
|
|
*
|
|
* The main function serves as a thin entry point that delegates to the CLI
|
|
* and runner modules for actual processing.
|
|
*/
|
|
|
|
// Core modules
|
|
pub mod box_trait;
|
|
pub mod boxes;
|
|
pub mod box_factory; // 🏭 Unified Box Factory Architecture (Phase 9.78)
|
|
pub mod stdlib;
|
|
pub mod environment;
|
|
pub mod tokenizer;
|
|
pub mod ast;
|
|
pub mod parser;
|
|
pub mod interpreter;
|
|
pub mod instance_v2; // 🎯 Phase 9.78d: Simplified InstanceBox implementation
|
|
pub mod core; // core::model (shared models)
|
|
pub mod channel_box;
|
|
pub mod finalization;
|
|
pub mod exception_box;
|
|
pub mod method_box;
|
|
pub mod scope_tracker; // VM scope lifecycle
|
|
pub mod operator_traits;
|
|
pub mod box_arithmetic; // 🚀 Moved from box_trait.rs for better organization
|
|
pub mod value; // 🔥 NyashValue Revolutionary System
|
|
pub mod type_box; // 🌟 TypeBox revolutionary system
|
|
pub mod messaging; // 🌐 P2P Communication Infrastructure
|
|
pub mod transport; // 🌐 P2P Communication Infrastructure
|
|
|
|
// 🚀 MIR Infrastructure
|
|
pub mod mir;
|
|
|
|
// 🚀 Backend Infrastructure
|
|
pub mod backend;
|
|
|
|
// 📊 Performance Benchmarks
|
|
pub mod benchmarks;
|
|
|
|
// 🚀 Refactored modules for better organization
|
|
pub mod cli;
|
|
pub mod runner;
|
|
|
|
// BID-FFI / Plugin System (prototype)
|
|
pub mod bid;
|
|
|
|
// Configuration system
|
|
pub mod config;
|
|
|
|
// Runtime system (plugins, registry, etc.)
|
|
pub mod runtime;
|
|
pub mod debug;
|
|
|
|
use nyash_rust::cli::CliConfig;
|
|
use runner::NyashRunner;
|
|
|
|
/// Thin entry point - delegates to CLI parsing and runner execution
|
|
fn main() {
|
|
// Parse command-line arguments
|
|
let config = CliConfig::parse();
|
|
|
|
// Create and run the execution coordinator
|
|
let runner = NyashRunner::new(config);
|
|
runner.run();
|
|
}
|
|
|
|
#[cfg(test)]
|
|
mod tests {
|
|
use super::*;
|
|
use box_trait::{StringBox, BoxCore, NyashBox};
|
|
|
|
#[test]
|
|
fn test_main_functionality() {
|
|
// This test ensures the module structure is correct
|
|
let string_box = StringBox::new("test".to_string());
|
|
assert_eq!(string_box.to_string_box().value, "test");
|
|
}
|
|
}
|