marble-machinations/README.md

101 lines
2 KiB
Markdown
Raw Normal View History

2024-10-06 00:57:24 +02:00
# marble machinations
(working title)
logic mostly like https://git.crispypin.cc/CrispyPin/marble
2024-10-06 12:39:36 +02:00
## todo
(more levels)
story/lore
timestamps in solutions and blueprints
multiple input/output sets
tooltips
lock tile types for early levels to make it less overwhelming
make a gui alternative to pressing R to rotate between tile variants
scroll level list
scroll blueprint list
make marble movement more consistent (`>o o<` depends on internal marble order)
2024-10-06 12:39:36 +02:00
decide on marble data size (u32 or byte?)
blueprint rotation?
2024-10-06 12:39:36 +02:00
## file hierarchy
2024-10-06 00:57:24 +02:00
```
- assets/
- levels/
- 00_zeroes.json
- 01_cat.json
- 02_parse.json
- 99_sandbox.json
- user/
2024-10-06 00:57:24 +02:00
- solutions/
- 00_zeroes/
- solution_0.json
- solution_1.json
- 01_cat/
2024-10-06 00:57:24 +02:00
- solution_0.json
- solution_3.json
2024-10-06 00:57:24 +02:00
- blueprints
- blueprint_0.json
```
## formats
### level
2024-10-06 00:57:24 +02:00
`00_zeroes.json`
```json
{
2024-10-06 12:39:36 +02:00
"id": "00_zeroes",
"sortorder": 5,
2024-10-06 12:39:36 +02:00
"name": "Zeroes",
"description": "learn how to output data",
"init_board": null,
"inputs": [],
"outputs": [0, 0, 0, 0, 0, 0, 0, 0],
"input_is_text": false,
"output_is_text": false
2024-10-06 00:57:24 +02:00
}
```
### solution
2024-10-06 00:57:24 +02:00
`00_zeroes/solution_0.json`
```json
{
"level_id": "00_zeroes",
2024-10-06 12:39:36 +02:00
"solution_id": "solution_0",
"name": "unnamed 1",
"board": "oo\nP*\n|-",
"score": {
"cycles": 8,
"tiles": 6,
"area": 6,
}
2024-10-06 00:57:24 +02:00
}
```
### blueprint
2024-10-06 00:57:24 +02:00
`blueprints/blueprint_0.json`
```json
{
"id": "blueprint_0",
"name": "zero_printer",
"board": "o -B I\n> * < \n"
2024-10-06 00:57:24 +02:00
}
```
## levels
### intro, basic mechanics
- output a zero
- output two numbers in sequence
- output zeroes forever (looping)
- copy the input
- copy only odd input numbers
### 0-terminated list processing
- calculate list length
- count instances of 5 in a list
- copy the second list (ignore input until first zero)
- reverse a list
### user-friendly numbers
- convert a number to decimal ascii
- parse an ascii number
- convert text to lowercase
### advanced list processing
- index a list
- search a list
- add two lists element-wise
- sort list