Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/peabnuts123/pico8-emmylua-definitions
EmmyLua intellisense definitions for PICO-8
https://github.com/peabnuts123/pico8-emmylua-definitions
autocomplete emmylua pico-8
Last synced: 2 months ago
JSON representation
EmmyLua intellisense definitions for PICO-8
- Host: GitHub
- URL: https://github.com/peabnuts123/pico8-emmylua-definitions
- Owner: peabnuts123
- Created: 2021-03-17T21:08:27.000Z (almost 4 years ago)
- Default Branch: master
- Last Pushed: 2021-03-23T04:01:39.000Z (almost 4 years ago)
- Last Synced: 2024-08-02T14:08:38.854Z (5 months ago)
- Topics: autocomplete, emmylua, pico-8
- Language: Lua
- Homepage:
- Size: 17.6 KB
- Stars: 32
- Watchers: 3
- Forks: 2
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# PICO-8 EmmyLua autocomplete definitions
[EmmyLua](https://emmylua.github.io/) definitions for the PICO-8 API, for autocomplete/intellisense support in code editors where integration with the [EmmyLua Language Server](https://github.com/EmmyLua/EmmyLua-LanguageServer) is supported ([IntelliJ ](https://github.com/EmmyLua/IntelliJ-EmmyLua), [VSCode](https://github.com/EmmyLua/VSCode-EmmyLua)).
![Recording showing multiple examples of autocomplete in action](https://peabnuts123-public-files.s3.amazonaws.com/pico8-api-demo.gif)
## Using
### Prerequisites
You must have an integration with the EmmyLua Language Server set up in your editor. EmmyLua has first-class support for IntelliJ and VSCode, with other setups supported through some configuration. See the [section below](#visual-studio-code) for suggestions if you are using VSCode.
### Installation
Simply place the file `pico8.lua` somewhere in your workspace, I would recommend a folder called `_pico8` or `_api` or something. You may have to change some settings to reference these definitions as a library, but in my experience simply having them in your workspace is enough.
One approach that also makes it easy to update would be to simply clone this repo into your project's directory:
```sh
git clone [email protected]:peabnuts123/pico8-emmylua-definitions.git _pico8
```That way you can run `git pull` if you need to update the definitions. You will have to copy the files manually if you intend to commit them to your project, however.
## Visual Studio Code
If you are using VSCode, I would recommend [this extension](https://github.com/sumneko/lua-language-server), which integrates with the EmmyLua language server as well as providing many Lua code editing features such as Go To Definition, linting and more.
## Contributing
Please let me know if there are any incorrect or missing definitions by opening an [issue](https://github.com/peabnuts123/pico8-emmylua-definitions/issues) or submitting a [pull request](https://github.com/peabnuts123/pico8-emmylua-definitionvs/pulls).
## Future work
Some future work I am considering:
- Automating the generation of these definitions from the [PICO-8 Fandom Wiki](https://pico-8.fandom.com/wiki/Pico-8_Wikia) (where most of these definitions came from)
- Changing the variable names and documentation to be more clear (i.e. author my own documentation)
- Creating a version for each version of PICO-8, managed through git tags