2020-07-23 21:10:33 +02:00
|
|
|
# Plang
|
|
|
|
|
|
|
|
<!-- md-toc-begin -->
|
|
|
|
* [About](#about)
|
2020-07-23 21:37:34 +02:00
|
|
|
* [The Plang Language](#the-plang-language)
|
|
|
|
* [`plang` command](#plang-command)
|
|
|
|
* [`plangrepl` command](#plangrepl-command)
|
|
|
|
* [PBot built-in Plang functions](#pbot-built-in-plang-functions)
|
|
|
|
* [factget](#factget)
|
|
|
|
* [factset](#factset)
|
|
|
|
* [factappend](#factappend)
|
|
|
|
* [userget](#userget)
|
2020-07-23 21:10:33 +02:00
|
|
|
<!-- md-toc-end -->
|
|
|
|
|
|
|
|
## About
|
2020-07-23 21:53:38 +02:00
|
|
|
The Plang plugin provides a scripting interface to PBot. It has access to PBot
|
2020-07-23 21:10:33 +02:00
|
|
|
internal APIs and state.
|
|
|
|
|
2020-07-23 21:37:34 +02:00
|
|
|
## The Plang Language
|
2020-07-23 21:10:33 +02:00
|
|
|
The scripting language is [Plang](https://github.com/pragma-/Plang). It was
|
|
|
|
written specifically for PBot, but is powerful enough to be used as a general-purpose
|
|
|
|
scripting language embedded into any Perl application.
|
|
|
|
|
|
|
|
This document describes PBot's Plang plugin. To learn how to use the Plang scripting
|
2020-07-23 21:18:53 +02:00
|
|
|
language, see the [Plang documentation](https://github.com/pragma-/Plang/blob/master/README.md).
|
2020-07-23 21:10:33 +02:00
|
|
|
|
2020-07-23 21:37:34 +02:00
|
|
|
## `plang` command
|
2020-07-23 21:10:33 +02:00
|
|
|
Use the `plang` command to run a Plang script.
|
|
|
|
|
|
|
|
Usage: `plang <code>`
|
|
|
|
|
2020-07-23 21:37:34 +02:00
|
|
|
## `plangrepl` command
|
2020-07-23 21:10:33 +02:00
|
|
|
The `plangrepl` command is identical to the `plang` command, except the environment
|
|
|
|
is preserved in-between commands and the types of values is output along with the value.
|
|
|
|
|
2020-07-23 21:37:34 +02:00
|
|
|
## PBot built-in Plang functions
|
|
|
|
[Plang](https://github.com/pragma-/Plang) lets you add custom built-in functions.
|
|
|
|
Several have been added for PBot; they are described here.
|
2020-07-23 21:10:33 +02:00
|
|
|
|
2020-07-23 21:37:34 +02:00
|
|
|
### factget
|
2020-09-04 01:41:19 +02:00
|
|
|
factget(channel: String, keyword: String, meta: String = "action") -> String
|
2020-07-23 21:10:33 +02:00
|
|
|
|
|
|
|
Use the `factget` function to retrieve metadata from factoids.
|
|
|
|
|
|
|
|
The `factget` function takes three paramaters: `channel`, `keyword` and `meta`. The `meta`
|
|
|
|
parameter can be omitted and will default to `"action"`.
|
|
|
|
|
|
|
|
The `factget` function returns a `String` containing the value of the factoid metadata key.
|
|
|
|
|
2020-07-23 21:37:34 +02:00
|
|
|
### factset
|
2020-09-04 01:41:19 +02:00
|
|
|
factset(channel: String, keyword: String, text: String) -> String
|
2020-07-23 21:10:33 +02:00
|
|
|
|
|
|
|
Use the `factset` function to set the `action` metadata value for factoids.
|
|
|
|
|
|
|
|
The `factset` function takes three parameters: `channel`, `keyword` and `text`.
|
|
|
|
|
|
|
|
The `factset` function returns a `String` containing the value of `text`.
|
|
|
|
|
2020-07-23 21:37:34 +02:00
|
|
|
### factappend
|
2020-09-04 01:41:19 +02:00
|
|
|
factappend(channel: String, keyword: String, text: String) -> String
|
2020-07-23 21:10:33 +02:00
|
|
|
|
|
|
|
Use the `factappend` function to append text to the `action` metadata for factoids.
|
|
|
|
|
|
|
|
The `factappend` function takes three parameters: `channel`, `keyword` and `text`.
|
|
|
|
|
|
|
|
The `factappend` function returns a `String` containing the value of factoid's `action`
|
|
|
|
metadata with `text` appended.
|
|
|
|
|
2020-07-23 21:37:34 +02:00
|
|
|
### userget
|
2020-09-04 01:41:19 +02:00
|
|
|
userget(name: String) -> Map
|
2020-07-23 21:10:33 +02:00
|
|
|
|
|
|
|
Use the `userget` function to retrieve user metadata.
|
|
|
|
|
|
|
|
The `userget` function takes one parameter: `name`.
|
|
|
|
|
|
|
|
The `userget` function returns a `Map` containing all the metadata of the user, or
|
|
|
|
`nil` if there is no user matching `name`.
|
|
|
|
|
|
|
|
See the [Plang Map documentation](https://github.com/pragma-/Plang#map) for a refresher on using Plang maps.
|
|
|
|
|
|
|
|
Examples:
|
|
|
|
|
|
|
|
<pragma-> !plang userget('pragma-')
|
2020-07-25 18:31:24 +02:00
|
|
|
<PBot> { channels: "global", hostmasks: "*!*@unaffiliated/pragmatic-chaos", botowner: 1 }
|
2020-07-23 21:10:33 +02:00
|
|
|
|
|
|
|
<pragma-> !plang userget('pragma-')['botowner']
|
|
|
|
<PBot> 1
|
2020-07-27 07:54:01 +02:00
|
|
|
|
|
|
|
<pragma-> !plang if userget('pragma-')['botowner'] then print('Greetings master!') else print('Hello mortal.')
|
|
|
|
<PBot> Greetings master!
|