Skip to content

A Discord bot for querying documentation for the LÖVE API.

License

Notifications You must be signed in to change notification settings

Sheepolution/love-docs-bot

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

99 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

LÖVE Docs

A Discord bot for querying documentation for the LÖVE API.

Invite the bot

How to use

Use love>api [query] to search through the LÖVE and Lua API. You can edit your message to update the bot's message.

Mod Commands

love>prefix [prefix]

Change the prefix.

love>channel add/remove

Add or remove the channel where this command is used to the list of channels where the bot is active. If no channels have been added the bot can be used in all channels.

love>role [role]

Restrict access to the bot to members with a certain role. Use love>role everyone if you want to remove the role restriction.

Example usage

Libraries

Besides the LÖVE API, LÖVE Docs also supports querying through libraries.

How to use

Use love>lib [query] to search for a library.

Use love>lib [library] [query] to search through a library's documentation.

Most of the libraries that are on awesome-love2d are included.

You can make a pull request to add documentation for your or someone else's library.

Adding a library

You can add a library by extending DocsLibs.json. The JSON is structured as followed:

{
    "name": "step",
    "author": "Sheepolution",
    "url": "https://github.com/sheepolution/step",
    "description": "A small immediate mode timer module that makes it easier to have an action execute with a certain interval or after a delay.",

    // Optional. "." by default. Should be either "." or ":".
    "callType": ".", 

    // Optional.
    "api": [
        {
            "name": "every",

            // Optional.
            "arguments": "duration, [max_duration]", 
            "description": "Creates a timer which returns true every `duration` seconds. If `max_duration` is set the duration will be a random float between `duration` and `max_duration` every loop.",

            // Optional. True by default.
            "callable": true,

            // Optional.
            "example": "timer = step.every(3)\nif timer:update(dt) then\n  print(\"This will be printed every 3 seconds\")\nend"
        },
        {
            // By default the function will be shown as the library's name + the function's name.
            // By putting a "." or ":" in your function's name the library's name will not be used.
            // This way you can also use a different callType. You can put the library's name in the function's name in that case.
            "name": "timer:reset",
            "description": "Resets the timer.",
        },
    ]
}

About

A Discord bot for querying documentation for the LÖVE API.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published