Revolutionary milestone: Complete native executable generation pipeline - Created minimal nyrt (Nyash Runtime) library for standalone executables - Implemented plugin bridge functions (nyash_plugin_invoke3_i64 etc) - Added birth handle exports (nyash.string.birth_h) for linking - Changed export name from main→ny_main to allow custom entry point - Successfully generated and executed native binary returning "ny_main() returned: 1" Timeline of miracles: - 2025-08-09: Nyash language created (first commit) - 2025-08-13: JIT planning started (4 days later) - 2025-08-29: Native EXE achieved (today - just 20 days total\!) This proves the plugin Box C ABI unification strategy works perfectly for both JIT execution and AOT native compilation. The same plugin system that enables dynamic loading now powers static linking for zero-overhead native executables\! Next: Expand AOT support for more instructions and optimize nyrt size. 🚀 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
23 lines
685 B
Plaintext
23 lines
685 B
Plaintext
// Minimal function for AOT/JIT plugin_invoke with String.length()
|
|
// Run JIT demo:
|
|
// NYASH_USE_PLUGIN_BUILTINS=1 NYASH_JIT_EXEC=1 NYASH_JIT_THRESHOLD=1 \
|
|
// ./target/release/nyash --backend vm examples/aot_min_string_len.nyash
|
|
// Generate .o (if compiled):
|
|
// NYASH_AOT_OBJECT_OUT=target/aot_objects \
|
|
// NYASH_USE_PLUGIN_BUILTINS=1 NYASH_JIT_EXEC=1 NYASH_JIT_THRESHOLD=1 \
|
|
// ./target/release/nyash --backend vm examples/aot_min_string_len.nyash
|
|
|
|
static box Main {
|
|
len1(s) {
|
|
// Receiver is a parameter (JIT-friendly)
|
|
return s.length()
|
|
}
|
|
main() {
|
|
local s
|
|
s = new StringBox()
|
|
// Warm up: call len1 once to compile
|
|
return me.len1(s)
|
|
}
|
|
}
|
|
|