Skip to content
forked from sparr/pico8lib

Library of useful functions and tables for Lua programming for the PICO-8 fantasy console

License

Notifications You must be signed in to change notification settings

chronoDave/pico8lib

 
 

Repository files navigation

PICO8lib

The PICO-8 is a fantasy console with limited space for programs and data, programmed in a flavor of Lua with a very small standard library. This repository is meant to serve as a collection of useful functions and tables built, curated, and optimized by the pico8 developer community.

The focus of this repository is on game-agnostic code and functions. Most of the code you will find here is applicable to any type of game or game engine, and represents code you might generally expect to find in the lua standard library (string, table, math, etc) or in a more comprehensive console I/O library (drawing, memory access, etc).

What you will not find here is code related to gameplay implementation, such as actor and component frameworks, rendering engines, or game rule logic. I would like to add this sort of content in the future, but it will require significant additional organization and documentation efforts above and beyond those requires for the current contents of the repo.

Utility Functions

  • strings - Manipulating and creating strings
  • tables - Manipulating and creating tables
  • functions - Manipulating and creating functions
  • math - Mathematical operations, mostly on numbers
  • number - Non-mathematical maniuplation of numbers
  • json - JSON(ish) parser
  • graphics - Drawing and sprite manipulation
  • physics - Collision functions, etc
  • memory - Reading, writing, manipulating memory

Classes

Other

  • snippets - inline snippets to mix with your own code
  • boilerplate - mostly empty pico8 cart with profiling and comments

Conventions

Code is not minified for character count; that is a job for a minifier if desired or necessary. I try to aim for 3-5 character identifiers in moderate to complex functions, 1-3 characters in simple functions.

Functions and variables are local where possible, for performance reasons. Thanks to zep for giving it to us as a free token!

Some functions are provided in multiple variations, optimized for tokens, size, speed, and/or functionality. Every function should have at least a token-optimized version. Some functions have lines or blocks commented with variations.

-- inline[t,c] marks code that could be inlined to save t tokens and c characters, usually at the cost of cpu or memory.

-- remove[t,c] marks code that can be removed, usually at the cost of reduced functionality or code safety.

Contributing

PRs are welcome! I am looking to collect a variety of best-of-breed examples of common library functions. Additional (or any) tests would also be helpful.

The best place to chat with other PICO-8 developers is on the PICO-8 Discord.

Related Projects and Links

Libraries

Game engine implementations

Well engineered cart collections

Coding tips

Documentation

About

Library of useful functions and tables for Lua programming for the PICO-8 fantasy console

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Lua 100.0%