-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathasm-blox.info
803 lines (591 loc) · 24.8 KB
/
asm-blox.info
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
723
724
725
726
727
728
729
730
731
732
733
734
735
736
737
738
739
740
741
742
743
744
745
746
747
748
749
750
751
752
753
754
755
756
757
758
759
760
761
762
763
764
765
766
767
768
769
770
771
772
773
774
775
776
777
778
779
780
781
782
783
784
785
786
787
788
789
790
791
792
793
794
795
796
797
798
799
800
801
802
803
This is asm-blox.info, produced by makeinfo version 4.8 from
asm-blox.texi.
File: asm-blox.info, Node: Top, Next: Introduction, Up: (dir)
Asm-Blox User Manual
********************
Copyright (C) 2020-2021 Zachary Romero <zkry@posteo.org>
You can redistribute this document and/or modify it under the
terms of the GNU General Public License as published by the Free
Software Foundation, either version 3 of the License, or (at your
option) any later version.
This document is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
* Menu:
* Introduction::
* Installation::
* Getting Started::
* Gameplay::
* WAT Command Set::
* Module Blocks::
* Editing Commands::
* Customizations::
--- The Detailed Node Listing ---
Getting Started
* Puzzle Selection::
* Saved Puzzles and Backups::
Gameplay
* Overview::
* Execution::
WAT Command Set
* Execution Model of WAT Cells::
* Stack Commands::
* Numeric Commands::
* Boolean Operations::
* Comparison Operations::
* Other Operations::
* Port Operations::
* Blocks and Loops::
Module Blocks
* Stack Cells::
* Heap Cells::
* Controller Cells and Editor Problems::
* Legacy YAML-defined Modules::
Editing Commands
* Undo and Redo::
* Advanced editing::
File: asm-blox.info, Node: Introduction, Next: Installation, Prev: Top, Up: Top
1 Introduction
**************
Asm-Blox is an attempt to make Emacs more exciting by merging it with
trendy topics, namely blocks (a la Minecraft), and WASM (have like what
Rust can do!). Asm-blox is an attempt to combine these elements
together in a an exciting game package, taking inspiration from the
budding genre of programming puzzle games.
The game tasks you with writing a program in an idealized version of
WebAssembly Text to solve a simple programming puzzle. Puzzles range
in difficulty and at first you'll try to get use to the unusual
instructions later using what you've learned in conjunction with
pre-made utility components to solve even more complex problems.
File: asm-blox.info, Node: Installation, Next: Getting Started, Prev: Introduction, Up: Top
2 Installation
**************
This package is installable under the identifier "asm-blox" on MELPA.
File: asm-blox.info, Node: Getting Started, Next: Gameplay, Prev: Installation, Up: Top
3 Getting Started
*****************
* Menu:
* Puzzle Selection::
* Saved Puzzles and Backups::
File: asm-blox.info, Node: Puzzle Selection, Next: Saved Puzzles and Backups, Up: Getting Started
3.1 Puzzle Selection
====================
By running `asm-blox' you can open the _puzzle selection page_. On
this page you can see a list of all of the puzzles with their
difficulty and description. You will also see the puzzles previously
created on the right side of the screen. Pressing `RET' when the point
is on any one of them will load said puzzle.
File: asm-blox.info, Node: Saved Puzzles and Backups, Prev: Puzzle Selection, Up: Getting Started
3.2 Saved Puzzles and Backups
=============================
Puzzles are saved in the directory indicated by the variable
`asm-blox-save-directory-name'. Puzzles are saved as they are edited
(ie 12 boxes with text in them). In the case that the file is saved in
a bad format it may become corrupted. In this case there are backups
saved each time the file is ran which end in `.backup.txt'. When a
puzzle is completed, a file with the extension `.win.txt' is saved.
File: asm-blox.info, Node: Gameplay, Next: WAT Command Set, Prev: Getting Started, Up: Top
4 Gameplay
**********
* Menu:
* Overview::
* Execution::
File: asm-blox.info, Node: Overview, Next: Execution, Up: Gameplay
4.1 Overview
============
The gameboard consists of three rows and four columns in which the user
will enter their solution. Each box will be referred to as a _code
cell_. Code cells can contain WAT or a module. The following is an
example of a WAT cell:
+--------------------+
|(left)(ne (get 0) |
| (const ?<)) |
|(ne(get 0) |
| (const ?>))(and) |
|(block(block |
| (br_if 0) |
| (send down)(down) |
| (br 1)) |
| (send right) |
| (right)) |
|(clr) |
| |
+--------------------+
In later sections, I will go over the meanings of the various
commands. Arrows entering the box are the box's _input ports_, The
arrows goign out are the box's _output ports_. On the edges of the
gameboard you will see some labeled arrows. The input of the puzzle
will come through these ports. Labeled arrows going out of a box is
where you have to send your answer.
The following is an example of a module cell:
+--------------------+
|(module heap |
| :size 100 |
| :set-port up |
| :seek-port left |
| :peek-port up |
| :offset-port left) |
| |
| |
| |
| |
+--------------------+
File: asm-blox.info, Node: Execution, Prev: Overview, Up: Gameplay
4.2 Execution
=============
By pressing `C-c C-c' (`asm-blox-start-execution') you can execute the
current puzzle. This opens up a new buffer where the puzzle's inputs
and outputs will become visible. The following keybindings will then
be available to you in an execution buffer:
* `n' (`asm-blox-execution-next-command') will perform one step of
execution.
* `N' (`asm-blox--execution-next-multiple-commands') will perform
the number of steps defined by the variable.
`asm-blox-multi-step-ct'.
* `r' (`asm-blox--execution-run') will run the program until it
finishes, an error occurs, or is stopped.
* `q' (`quit-window') will stop execution.
Submitting the wrong answer will cause execution to stop as well as
any runtime error.
File: asm-blox.info, Node: WAT Command Set, Next: Module Blocks, Prev: Gameplay, Up: Top
5 WAT Command Set
*****************
The following is a complete description of all the available WAT
commands in the game. *Note_that the commands are case insensitive*
* Menu:
* Execution Model of WAT Cells::
* Stack Commands::
* Numeric Commands::
* Boolean Operations::
* Comparison Operations::
* Other Operations::
* Port Operations::
* Blocks and Loops::
File: asm-blox.info, Node: Execution Model of WAT Cells, Next: Stack Commands, Up: WAT Command Set
5.1 Execution Model of WAT Cells
================================
Cells run on a stack-based architecture. Each command will consume
zero to two items from the stack and push zero or one item. Each cell
has a stack size of four. Any element past that will cause a
_stack-overflow error_. If the stack doesn't have enough items, a
_stack-underflow errors_ occurs.
Many commands can have nested operations. These are indicated by a
_..._ in the following sections. When forms are nested, they will run
before the parent item pushing their items onto the stack before the
parent command is executed. For example, the following instruction
executes as would be expected in Lisp (`(+ 10 (- 20))'):
`(add (const 10) (neg (const 20)))'
File: asm-blox.info, Node: Stack Commands, Next: Numeric Commands, Prev: Execution Model of WAT Cells, Up: WAT Command Set
5.2 Stack Commands
==================
* `const' _number_: Pushes _number_ onto the stack. Note that
numbers may be in the form of a ASCII character (ex. `?a' for the
character a)
* `set' _stack-offset_: Sets the stack item at _stack-offset_ to the
value at the top of the stack, popping it.
* `inc' _stack-offset_ _..._: Increment the value on the stack at
_stack-offset_. *NOTE_* To increment the value at the top of the
stack use `(inc -1)'.
* `dec' _stack-offset_: Decrement the value of the stack at
_stack-offset_. *NOTE_* To decrement the value at the top of the
stack use `(dec -1)'.
* `clr': Clear the entire stack.
* `dup': Duplicate the stack. Note: this will overflow the stack if
there is more than two items on the stack.
* `drop' _..._: Pop the item off the top of the stack.
File: asm-blox.info, Node: Numeric Commands, Next: Boolean Operations, Prev: Stack Commands, Up: WAT Command Set
5.3 Numeric Commands
====================
* `add' _..._: Remove the top two items on the stack, add them, and
push the result on the stack.
* `sub' _..._: Remove the top two items on the stack, subtract the
upper item from the lower one and add the item back on the stack.
* `mul' _..._: Remove the top two items on the stack, multiply them
and push the result on the stack.
* `div' _..._: Remove the top two items on the stack, divide the
lower item by the upper item and push the _quotient_ on the stack.
* `rem' _..._: Remove the top two items on the stack, divide the
lower item by the upper item and push the _remainder_ on the stack.
* `neg' _..._: Remove the top item from the stack and invert its
sign.
File: asm-blox.info, Node: Boolean Operations, Next: Comparison Operations, Prev: Numeric Commands, Up: WAT Command Set
5.4 Boolean Operations
======================
asm-blox has no notion of true or false. The number 0 is used for
false and any other number is true.
* `and' _..._: Remove the top two items on the stack, pushing 1 if
they are both true, 0 otherwise.
* `or' _..._: Remove the top two items on the stack, pushing 1 if
either of them is true, 0 otherwise.
* `not' _..._: Remove the top item from the stack and push its
inverted truth value onto the stack.
File: asm-blox.info, Node: Comparison Operations, Next: Other Operations, Prev: Boolean Operations, Up: WAT Command Set
5.5 Comparison Operations
=========================
Note that all comparison operations compare from bottom to top of the
stack. This means that an operation such as `(lt (const 1) (const
3))' will be true.
* `lt' _..._: Pop two items on stack and push 1 if the bottom item
is _less than_ the top, 0 otherwise.
* `gt' _..._: Pop two items on stack and push 1 if the bottom item
is _greater than_ the top, 0 otherwise.
* `ge' _..._: Pop two items on stack and push 1 if the bottom item
is _greater than or equal to_ the top, 0 otherwise.
* `le' _..._: Pop two items on stack and push 1 if the bottom item
is _less than or equal to_ the top, 0 otherwise.
* `eq' _..._: Pop two items on stack and push 1 if the bottom item
is _equal_ the top, 0 otherwise.
* `ne' _..._: Pop two items on stack and push 1 if the bottom item
is _not equal to_ the top, 0 otherwise.
* `lz' _..._: Pop one items on stack and push 1 if it is less than
zero, 0 otherwise.
* `gz' _..._: Pop one items on stack and push 1 if it is greater
than zero, 0 otherwise.
File: asm-blox.info, Node: Other Operations, Next: Port Operations, Prev: Comparison Operations, Up: WAT Command Set
5.6 Other Operations
====================
* `nop': Do nothing
File: asm-blox.info, Node: Port Operations, Next: Blocks and Loops, Prev: Other Operations, Up: WAT Command Set
5.7 Port Operations
===================
The following commands are used to interact with the port network.
Note that commands like `(up)' and `(down)' are given for convenience.
* `send' _port_ _..._: Send the item off the top of the stack to
_port_ if it empty. If the port is full, block.
* `get' _port_: Push the item from _port_ onto the stack.
* `up': Push the item from the _up_ port onto the stack.
* `down': Push the item from the _down_ port onto the stack.
* `left': Push the item from the _left_ port onto the stack.
* `right': Push the item from the _right_ port onto the stack.
File: asm-blox.info, Node: Blocks and Loops, Prev: Port Operations, Up: WAT Command Set
5.8 Blocks and Loops
====================
WAT cells come with two methods of control-flow: `loop' and `block'.
If you're familiar with WAT the logic works similar.
The commands `br' and `br_if' are the two commands to work with
`block' and `loop'. A `br' command will either skip to the end of a
`block' or loop to the top of a `loop'. A `br' must specify which
block or loop it is referring to via a number. Consider the following
example:
(block ; 2
(block ; 1
(block ; 0
(br <block ID>))))
The <block ID> above can be either 0, 1, or 2 since it is contained
in three nested blocks. If <block ID> was set to 1, then control flow
would jump past the middle block. If <block ID> was 2 then the control
would pass all of the blocks.
Let's consider another example with `loop'. Suppose we want to send
the numbers from 0 to 10 to the down port. We could write the
following code:
(const 0) ; 1
(loop ; 2
(send down (get 0)) ; 3
(set 0 (add (get 0)
(const 1))) ; 4
(ne (get 0) (const 10)) ; 5
(br_if 0)) ; 6
1. Initialize the top of the stack to 0.
2. Setup a loop
3. Send the value at the bottom of the stack down.
4. Set the value at the bottom of the stack to be 1 plus its current
value.
5. Push 1 if the item at the bottom of the stack is not equal to zero
6. If true (ie 1) is on the top of the stack, jump to the loop.
`block', `loop', `br' and `br_if' can be combined to create a wide
variety of constructs. For example, consider the following which
mimics an if-else branch:
;; IF UP > 10
;; THEN
;; SEND 10 LEFT
;; ELSE
;; SEND 20 RIGHT
;; END
(block ; block 1
(block ; block 0
(gt (up)
(const 10))
(br_if 0) ; ELSE clause:
(send right
(const 20))
(br 1))
; THEN clause:
(send left
(const 10)))
Here two nested blocks are defined. The comparison `gt' is
performed. If the result is TRUE, the `(br_if 0)' activates and goes
to the *end* of block 0, running the `(send left (const 10))' clause.
If the result is FALSE, the `br_if' command is not ran, and the `(send
right (const 20))' is ran. Note that we need to have the `(br 1)'
command so that the control flow doesn't go down to the THEN clause.
Summary of commands:
* `block': Setup a block. Any `br' command pointing to this block
will jump past the end of the block.
* `loop': Setup a block. Any `br' command pointing to this block
will jump to the beginning of this block.
* `br': Unconditionally jump to a block.
* `br_if': Consume the top item of the stack, jumping if true,
continuing if false.
File: asm-blox.info, Node: Module Blocks, Next: Editing Commands, Prev: WAT Command Set, Up: Top
6 Module Blocks
***************
Module cells can be constructed in addition to WAT blocks to add
pre-made processes which add essential functionality to solve some
problems. The current available types of module blocks includes:
Stack, Heap, and Controller.
Module blocks are written using a s-expression definition. The spec
is as follows: (module _module-kind_ _...specification_).
* Menu:
* Stack Cells::
* Heap Cells::
* Controller Cells and Editor Problems::
* Legacy YAML-defined Modules::
File: asm-blox.info, Node: Stack Cells, Next: Heap Cells, Up: Module Blocks
6.1 Stack Cells
===============
When the kind of a Module Cell is "stack", a stack is created. A stack
reads data from an input source, adding it to an internal data store,
and makes it available to an external port. The following is an
example of a stack.
+--------------------+
|(module stack |
| :input-port down |
| :output-port right |
| :size 20) |
| |
| |
| |
| |
| |
| |
+--------------------+
The following are spec properties of a stack module:
* `:input-port': any value sent here will be added to the top of the
stack.
* `:input-ports': multiple input port specifications in an
s-expression. Can not be used with `input-port'. ex.
`:input-ports (up left)'
* `:output-port': if another cell reads from here, it will be popped
off the stack.
* `:size': the maximum amount of elements that can be on the stack
before a stack-overflow error occurs. The maximum size of a stack
is 999.
* `:size-port': the port to which the current amount of elements on
the stack is written to.
File: asm-blox.info, Node: Heap Cells, Next: Controller Cells and Editor Problems, Prev: Stack Cells, Up: Module Blocks
6.2 Heap Cells
==============
Heap cells are created by creating a module with `heap' as its kind.
Heaps provide you with an array of memory for your cells to read and
write to. The following is an example of a heap cell:
+--------------------+
|(module heap |
| :read-port down |
| :write-port down |
| :seek-port left |
| :offset-port left |
| :set-port up |
| :peek-port up) |
| |
| |
| |
+--------------------+
* `:read-port' (out): from this port you can read the value at the
current address. By reading this value, the current address will
increase by one. Note that end of file is indicated by the value
-999.
* `:write-port' (in): writing a value to this port will store a value
at the current address. After writing a value, the current
address will increase by one.
* `:offset-port' (out): from this port you can read the current
offset into memory.
* `:seek-port' (in): by writing a value to this port, you can set the
offset into memory.
* `:peek-port' (out): this port will have the data at the current
offset. Reading from this port will not move the offset.
* `:set-port' (in): this port will set the data at the current
offset. Writing to this port will not move the offset
* `:size': You may configure the size of the heap with this
variable. The maximum size allowed is 999.
File: asm-blox.info, Node: Controller Cells and Editor Problems, Next: Legacy YAML-defined Modules, Prev: Heap Cells, Up: Module Blocks
6.3 Controller Cells and Editor Problems
========================================
Some problems require the special Asm-blox Editor integration. These
problems, when executed, will show an editor with the expected output
under it. Your goal in these problems is to get the editor to match
the target text. You can interact with the editor via Controller
cells. A controller cell is a Module cell with a value of "controller"
for the `kind' position. By configuring the ports on the Controller
cell you can move the point and insert text, sort of like how you would
in Emacs itself. You can have multiple controllers in a game.
The following is an example of a controller cell:
+--------------------+
|(module controller |
| :input-port left |
| :set-point-port |
| down |
| :point-port up) |
| |
| |
| |
| |
| |
+--------------------+
Controller cells allow you to set the following properties on the
`spec':
* `:input-port': Data sent to this input point will be written to the
buffer at the current point. ASCII characters with a value of 32
through 126 can be printed. You may also send ASCII 10 (?) for a
newline, 8 (?) or -1 for a backwards delete and -2 for a forwards
delete.
* `:set-point-port': Data sent to this input port will set the
position of the port. A value past the bounds of the buffer will
bring the point to the beginning (position 1) or the end of the
buffer.
* `:char-at-port': This output port will contain the character in
front of the point.
* `:point-port': This output port will contain the current point
position.
File: asm-blox.info, Node: Legacy YAML-defined Modules, Prev: Controller Cells and Editor Problems, Up: Module Blocks
6.4 Legacy YAML-defined Modules
===============================
In previous versions of the `asm-blox' software, modules were able to
be created via YAML statements. Currently this is not recommended and
may be removed in future versions of `asm-blox'.
The following is an example of a YAML block:
+--------------------+
|apiVersion: v1 |
|kind: Heap |
|spec: |
| size: 100 |
| setPort: up |
| seekPort: left |
| peekPort: up |
| offsetPort: left |
| |
| |
| |
| |
+--------------------+
A YAML block has three top level items: `apiVersion', `kind', and
`spec'. `kind' must be either `Stack', `Heap', or `Controller'. The
spec is the same stated above but with the keys in snake case (ex.
`:seek-port' becomes `seekPort').
File: asm-blox.info, Node: Editing Commands, Next: Customizations, Prev: Module Blocks, Up: Top
7 Editing Commands
******************
The following commands may be helpful when editing asm-blox code:
* `asm-blox-start-execution' (bound `C-c C-c'): compile the code
cells and create an execution buffer.
* `asm-blox-move-beginning-of-line' (bound `C-a'): Move the point to
the beginning of a code cell line if in a cell, to the beginning
of the line otherwise.
* `asm-blox-move-end-of-line' (bound `C-e'): Move the point to the
end of a code cell line if in a cell, to the end of the buffers
line otherwise.
* `asm-blox-beginning-of-buffer' (bound `M-<'): Move the point to
the end of a code cell if in a cell, to the end of the buffer
otherwise.
* `asm-blox-end-of-buffer' (bound `M->'): Move the point to the end
of a code cell if in a cell, to the end of the buffer otherwise.
* `asm-blox-next-cell' (bound `<tab>'): Move the point to the end of
the next code cell.
* `asm-blox-prev-cell' (bound `<backtab>'): Move the point to the
end of the previous code cell.
* Menu:
* Undo and Redo::
* Advanced editing::
File: asm-blox.info, Node: Undo and Redo, Next: Advanced editing, Up: Editing Commands
7.1 Undo and Redo
=================
Asm-blox support undo and redo on a per-cell basis.
* `asm-blox-undo' (bound `s-z', remap `undo'): undo a previous
action in the current code cell.
* `asm-blox-redo' (bound `s-y'): redo a previous undo in the current
code cell.
File: asm-blox.info, Node: Advanced editing, Prev: Undo and Redo, Up: Editing Commands
7.2 Advanced editing
====================
* `asm-blox-shift-box-up' (bound `<M-up>'): Swap the current code
cell with the one above the current one.
* `asm-blox-shift-box-down' (bound `<M-down>'): Swap the current
code cell with the one below the current one.
* `asm-blox-shift-box-left' (bound `<M-left>'): Swap the current
code cell with the one to the left of the current one.
* `asm-blox-shift-box-right' (bound `<M-right>'): Swap the current
code cell with the one to the right of the current one.
* `asm-blox-kill-region' (bound `<C-w>'): kill the highlighted
region of the current code cell. Note that the two ends of the
region must be in the same code cell.
* `asm-blox-copy-region' (bound `<M-w>'): copy the highlighted
region of the current code cell. Note that the two ends of the
region must be in the same code cell.
* `asm-blox-yank' (bound `C-y'); paste the yanked region to the
current code cell.
File: asm-blox.info, Node: Customizations, Prev: Editing Commands, Up: Top
8 Customizations
****************
The following customization options exist
* `asm-blox-save-directory-name': The name of the directory in which
all puzzles will be saved. Note that you can effectively start
from scratch, clearing your progress, by setting this to a new,
empty directory.
Tag Table:
Node: Top77
Node: Introduction1426
Node: Installation2200
Node: Getting Started2401
Node: Puzzle Selection2594
Node: Saved Puzzles and Backups3058
Node: Gameplay3633
Node: Overview3791
Node: Execution5280
Node: WAT Command Set6129
Node: Execution Model of WAT Cells6591
Node: Stack Commands7441
Node: Numeric Commands8431
Node: Boolean Operations9317
Node: Comparison Operations9925
Node: Other Operations11165
Node: Port Operations11356
Node: Blocks and Loops12098
Node: Module Blocks14976
Node: Stack Cells15586
Node: Heap Cells16912
Node: Controller Cells and Editor Problems18565
Node: Legacy YAML-defined Modules20510
Node: Editing Commands21573
Node: Undo and Redo22774
Node: Advanced editing23151
Node: Customizations24234
End Tag Table