Uxntal Linter, written in Tal
Go to file
Devine Lu Linvega 0c8061a4b1 Added new recipes 2023-01-18 09:24:34 -08:00
etc Silence static ari muted 2022-12-11 11:10:29 -08:00
src Added new recipes 2023-01-18 09:24:34 -08:00
.build.yml
.gitignore
LICENSE
README.md Added badge 2022-11-11 15:44:50 -08:00
build.sh Updated build script 2022-09-03 13:40:24 -07:00

README.md

Uxnlin

A linter for the Uxntal programming language, written in Uxntal.

Build

You must have the Uxn assembler and emulator.

uxnasm src/uxnlin.tal bin/uxnlin.rom

Usage

The following command will read a tal file and raise warnings if optimizations can be found.

uxncli bin/uxnlin.rom path/to/source.tal

If do not wish to assemble it yourself, you can download uxnlin.rom.

builds.sr.ht status

Manual

  • Skip sections of code by wrapping them inside square brakets.
#01 #02 ADD ( will throw a warning )
[ #0001 #0002 ADD2 ] ( will not throw a warning )

Includes

When Uxnlin encounters an include rune, such as ~src/include.tal, the parser will move on to evaluating the file without coming back. This is designed to follow Drifblim's include chain pattern.

Warnings

  • Redundance: Opcode effects cancel each other.
  • Static-Arithmetic: Arithmetic opcode on two static literals.
  • Static-Duplicate: Two identical static literals.
  • Unkept: Opcode should use non-destructive keep mode.
  • Unsafe: Bitwise opcode used in relative jump.
  • Unstashed: literal was created on the wrong stack.

Extras