Skip to content

Simple, cross-platform, user-friendly spaghetti alternative. Production-ready, feel free to open issues.

Notifications You must be signed in to change notification settings

Ksawi999/spaghetti-lite

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

spaghetti-lite

Simple, cross-platform, user-friendly spaghetti alternative. Production-ready, feel free to open issues.

setup

Paste spaghetti-lite folder wherever you want. It will work no matter where it is but it's recommended to keep it in "The Powder Toy" folder. If you installed spaghetti-lite to custom folder, it's recommended to write loadfile("spaghetti-lite/loader.lua")(path) in tpt console (required only after every startup of tpt), where path is path to spaghetti-lite parent folder (for example "C:\Lua"). You can use loadfile("spaghetti-lite/loader.lua")() with no arguments if you installed spaghetti-lite to default path to ensure compatibility with included files, also being able to easily use require() instead of loadfile()(), although it's not required for spaghetti-lite to work.

usage

Type loadfile("spaghetti-lite/init.lua")(x, y, "path.to.init", [param1], [param2]) in tpt console, where (x, y) are the coordinates of the top-left corner of the output. param1 and param2 are build parameters. This command automatically calls loader.lua so you don't have to call it as long as spaghetti-lite is in the default path.

old method

Type loadfile("spaghetti-lite/plot.lua")().create_parts(x, y, loadfile("path/to/init.lua")().build(params)) in tpt console, where (x, y) are the coordinates of the top-left corner of the output and params are build parameters. Generated files are in most cases named generated.lua or init.lua, but spaghetti-lite ships also with r2_adapter.lua and termination.lua.
If you used loader.lua, you can also use the shorter version:
require("plot").create_parts(x, y, require("path.to.init").build(params)).
Files named generated.lua have to be used directly (without .build()) so use loadfile("spaghetti-lite/plot.lua")().create_parts(x, y, loadfile("path/to/generated.lua")()) or require("plot").create_parts(x, y, require("path.to.generated").build(params)) respectively.

These commands work with the default spaghetti too, although they require much harder setup.

params

Some scripts require additional parameters. To dispel doubts, they're listed here for every function included in spaghetti-lite.

file build function params description
r3/init.lua build() core_count, height_order, [machine_id] builds r3 with core_count cores, height_order tall RAM with id of machine_id (last param is optional and is 1337 by default)
r3/bus/r2_adapter.lua build() control_ba, data_ba builds r3->r2 output adapter
r3/bus/termination.lua build() none builds termination
r3/core/generated.lua none none builds core
r3/rread/generated.lua none none builds rread
r3term/init.lua build() none builds r3 terminal

There are also some additional params hidden in lua files, but for better compatibility provided files come directly from R316 repo (modified just to handle placement inside of spaghetti-lite, but original ones could work as well). You can also get asm examples here and the tptasm from here

About

Simple, cross-platform, user-friendly spaghetti alternative. Production-ready, feel free to open issues.

Topics

Resources

Stars

Watchers

Forks

Languages