Home Hacker News Show HN: Tack, a fast lightweight scripting language for games and embedding https://ift.tt/3HvqCcI
Show HN: Tack, a fast lightweight scripting language for games and embedding https://ift.tt/3HvqCcI
Wandereraenny May 15, 2023 0
Show HN: Tack, a fast lightweight scripting language for games and embedding https://ift.tt/LtnIYWo Hi HN! Tack is a scripting language I've been working on sporadically for the past year or so, and intensely for the past few weeks. It originated out of a desire for something that was like Lua, but with a more familiar syntax, and without some of the other surprises in Lua such as the 1-indexed tables. It's also been a great learning project, and a very satisfying challenge! While the current version is early beta at best, I hope to continue working on it and maybe see some adoption. Despite the relative lack of optimization, I'm very pleased with the performance so far - although I haven't done a huge amount of benchmarking, it seems to be significantly faster than the stock Lua 5.4 interpreter for the quicksort test, and the btrees test (copied from the Computer Language Benchmarks Game). The language is designed for embedding in C++ programs, and is written in C++ more or less from scratch including the handwritten recursive descent parser, and a register-based compiler/interpreter. The only dependency other than the standard library is my C++ adaptation of the khash library used for the object type - a from-scratch hashmap seemed not worth the trouble. Quick code example - more examples in the repo! fn quicksort(arr) { const n = #arr if n <= 1 { return arr } " find the midpoint " let l = min(arr) let r = max(arr) if r == l { return arr } const mid = (l + r) / 2 " split array into upper and lower " const upper = filter(arr, fn(x) { return x < mid }) const lower = filter(arr, fn(x) { return x >= mid }) " recursively sort the upper and lower sub-arrays and join the result" return quicksort(lower) + quicksort(upper) } let A = [] for i in 0, 1000000 { A << random() } let before = clock() let B = quicksort(A) let after = clock() print("Time taken: ", after - before, "seconds") Building requires just cmake and a C++20 compiler - tested with MSVC 2022, g++11 on WSL and Clang 15 on M1 https://craftinginterpreters.com was a great help with implementing closures, as I had gone down a blind alley with my first approach for locating the closed-over variables. However I have taken a slightly different approach towards boxing. As I do intend to use this for some small games myself going forward, there is a standard library already, and plans to expand it. I also intend to release a GLFW-based mini game framework along with precompiled binaries, so hobbyists (and younger relatives!) may use it without needing a full compiler toolchain. I would love if anyone is interested enough to try it out! James https://github.com/PlumeCat/tack May 14, 2023 at 11:09PMRelated Posts
- Job posted to Hacker News: Motion (YC W20) Is Hiring Senior Front End Engineers
- Job posted to Hacker News: Legion Health (YC S21) Is Hiring a Technical Product Marketing Lead
- Job posted to Hacker News: Great Question (YC W21) is hiring senior Rails engineers in Australia
- Job posted to Hacker News: Supabase (YC S20) Is Hiring an Auth Engineer (Remote)
- Job posted to Hacker News: Lead Animation Engineer – Gym Class (YC W22) Is Hiring
- Job posted to Hacker News: Substack (YC W18) is hiring machine learning engineers
- Job posted to Hacker News: Tesorio (YC S15) Is Hiring a Senior GenAI/LLM Engineer (100% Remote)
- Job posted to Hacker News: Imbue (Formerly Generally Intelligent) (YC S17) Is Hiring an Engineering Manager
Subscribe to:
Post Comments
(
Atom
)
Post a Comment