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: Openbase (YC S20) Is Hiring
- Show HN: I built a service to help companies reduce AWS spend by 50% https://ift.tt/xSNzdblgt
- Job posted to Hacker News: Skio is hiring founding engineers in NYC (above market equity)
- Show HN: We built unit/integration test results aggregator https://ift.tt/yP30L9a
- Show HN: I'm building a new political party (feedback welcome!) https://ift.tt/jcYt7LmDa
- Job posted to Hacker News: Cosmic (YC W19) Is Hiring
- Show HN: The first smart interactive chair for standing desks https://ift.tt/1d2eVcQ3O
- Show HN: Grafana Incident, smart incident management for your teams https://ift.tt/gGR6yMpSH
Subscribe to:
Post Comments
(
Atom
)
Post a Comment