Skip to content
/ p8 Public

🕹️ Compatibility layer to run PICO-8 scripts on the monome norns

License

Notifications You must be signed in to change notification settings

p3r7/p8

Repository files navigation

p8

Compatibility layer to run PICO-8 scripts on the monome norns.

This is not suitable for running full-fledged carts (with sprites, sound...), targeting instead tweetcarts (code fitting in a tweet).

norns.community page (wiki)

lines page (forum)

blog post

Why?

Both platform share similar goals: build a community around sharing small apps written in Lua.

PICO-8 is centered around games, norns around music-making apps.

The PICO-8 community provided some pretty crazy examples of what can be done with basic functions and I thought that one community could benefit from the efforts of the other.

The aim is not to have it embedded systematically in a norns app but instead to quickly steal animation ideas from tweetcart and see how they get rendered on the norns display.

How?

By defining PICO-8 API functions from norns-compatible Lua code (code).

To compare them:

Their display APIs are pretty close to one another.

On the contrary, PICO-8's trigonometric functions behave quite differently from the standard Lua math lib.

Examples

ghosts.lua (original tweetcart by @Alexis_Lessard).

norns_p8_ghosts

confetti.lua (original tweetcart by @von_rostock).

norns_p8_confetti

manga_effect.lua (original tweetcart by @kadoyan).

norns_p8_manga-effect

tree.lua (original tweetcart by @Alexis_Lessard).

norns_p8_tree

pumpkin.lua (original tweetcart by @von_rostock).

norns_p8_pumpkin

cube.lua (original code by @neauoire of 100 rabbits).

norns_p8_cube

Usage

General

Most PICO-8 tweetcarts are not defined using the game loop but a combination of goto and flip instead.

To be executed on norns, they need to be slightly adapted:

  • the label / goto block needs to be moved to a function (typically redraw)
  • this function needs to be called from a metro object

See the Examples for concrete use-cases.

print

PICO-8's print allows printing on the screen.

norns is not happy with having the standard print function redefined.

That's why PICO-8's version got renamed p8print.

Special PICO-8 Lua syntax

PICO-8's Lua differs a bit from standard Lua.

It notably provides additional constructs such as a short form if/else ternary syntax and compound assignment operators (e.g. +=). These instructions should be converted for norns to interpret them.

Refer to this page for more detailed porting instructions.

-- valid PICO-8 Lua
t += 1
if (not b) then i=1 j=2 end
j != 0

-- equivalent Lua
t = t + 1
if (not b) then i=1 else j=2 end
j ~= 0

There is also the @<address> shorthand for peek that would need to be converted to an explicit peek call.

Completeness

Not all of PICO-8 APIs will get implemented.

The following are not yet here but are the next one on the list:

  • fillp (patterned fill)
  • tline (textured line)

These are interesting but seem difficult to implement fully with current norns APIs:

  • clip
  • camera
  • map APIs

These might get implemented in a very loose way:

  • fset / fget
  • sprite sheet fns: sset / sget, spr, sspr

Current implementation of print (p8print) does not handle \n and screen scroll on end of framebuffer.

Current implementation of peek and poke only support interacting with the current color and current text cursor position.

Current implementation of pal doesn't honor the p parameter.

Implementation details

Table manipulation API functions (foreach, all, add, del) stolen from the picolove project (BBS thread).

atan2 implementation taken from @benjamin_soule's PAT Shooter with some improvements.

About

🕹️ Compatibility layer to run PICO-8 scripts on the monome norns

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages