mirror of
https://github.com/pragma-/pbot.git
synced 2025-01-25 19:44:26 +01:00
Simplify README a bit
This commit is contained in:
parent
5a4c52cde0
commit
4e15e3ce18
19
README.md
19
README.md
@ -146,15 +146,13 @@ internal API functions.
|
|||||||
[Learn more.](doc/Plugins/Plang.md)
|
[Learn more.](doc/Plugins/Plang.md)
|
||||||
|
|
||||||
### Extensible
|
### Extensible
|
||||||
PBot is extensible in multiple ways. Additional commands and functionality can be added to PBot in
|
Additional commands and functionality can be added to PBot in the following ways.
|
||||||
the following ways.
|
|
||||||
|
|
||||||
#### Factoids
|
#### Factoids
|
||||||
Factoids are a very special type of command. Anybody interacting with PBot
|
Factoids are a very special type of command. Anybody interacting with PBot
|
||||||
can create, edit, delete and invoke factoids. Factoids can be locked by the
|
can create, edit, delete and invoke factoids.
|
||||||
creator of the factoid to prevent them from being edited by others.
|
|
||||||
|
|
||||||
At its most simple, a factoid merely displays the text the creator sets.
|
A simple factoid merely displays the text the creator sets.
|
||||||
|
|
||||||
<pragma-> !factadd hello /say Hello, $nick!
|
<pragma-> !factadd hello /say Hello, $nick!
|
||||||
<PBot> hello added to global channel.
|
<PBot> hello added to global channel.
|
||||||
@ -163,14 +161,14 @@ At its most simple, a factoid merely displays the text the creator sets.
|
|||||||
<PBot> Hello, pragma-!
|
<PBot> Hello, pragma-!
|
||||||
|
|
||||||
Significantly more complex factoids can be built by using `$variables`, command-substitution,
|
Significantly more complex factoids can be built by using `$variables`, command-substitution,
|
||||||
command-piping, `/code` invocation, and more!
|
command-piping, `/code` invocation, command prefixes such as `/say`, `/me`, `/msg`, and more!
|
||||||
|
|
||||||
PBot factoids include these advanced features:
|
PBot factoids include these advanced features:
|
||||||
|
|
||||||
* [undo/redo history](doc/Factoids.md#factundo)
|
* [undo/redo history](doc/Factoids.md#factundo)
|
||||||
* [changelog history](doc/Factoids.md#factlog)
|
* [changelog history](doc/Factoids.md#factlog)
|
||||||
* [channel namespaces](doc/Factoids.md#channel-namespaces)
|
* [channel namespaces](doc/Factoids.md#channel-namespaces)
|
||||||
* [creating](doc/Factoids.md#factadd) and [modifying](doc/Factoids.md#factchange) contents using your local system editor to edit the contents, optionally including line-breaks and indentation; then pasting the contents to a Web paste site; and finally using the `-url` option to add/edit the factiod.
|
* [creating](doc/Factoids.md#factadd) and [modifying](doc/Factoids.md#factchange) contents using your local system editor. Yes, you can edit the contents, optionally including line-breaks and indentation; then paste to a paste site; and finally use `factadd -url` or `factchange -url` comamnds.
|
||||||
* [advanced `$variable` interpolation](doc/Factoids.md#expansion-modifiers) (`$var:lc` to lowercase contents, `$var:ucfirst` to uppercase first letter, etc)
|
* [advanced `$variable` interpolation](doc/Factoids.md#expansion-modifiers) (`$var:lc` to lowercase contents, `$var:ucfirst` to uppercase first letter, etc)
|
||||||
* [factoid-based variable lists](doc/Factoids.md#list-variables) (e.g., add a factoid `colors` containing "red green blue" and then `!echo $colors` will randomly pick one)
|
* [factoid-based variable lists](doc/Factoids.md#list-variables) (e.g., add a factoid `colors` containing "red green blue" and then `!echo $colors` will randomly pick one)
|
||||||
* [advanced argument processing](doc/Factoids.md#special-variables-1) (indexing, splicing, etc)
|
* [advanced argument processing](doc/Factoids.md#special-variables-1) (indexing, splicing, etc)
|
||||||
@ -181,15 +179,10 @@ PBot factoids include these advanced features:
|
|||||||
For more information, see the [Factoids documentation](doc/Factoids.md).
|
For more information, see the [Factoids documentation](doc/Factoids.md).
|
||||||
|
|
||||||
#### Code Factoids
|
#### Code Factoids
|
||||||
Code Factoids are a special type of factoid that begin with the `/code` command.
|
Code Factoids are a special type of factoid that executes its contents within a sandboxed virtual machine.
|
||||||
|
|
||||||
/code <language> <code>
|
/code <language> <code>
|
||||||
|
|
||||||
That's right! Anybody can create a factoid that can execute arbitrary code in
|
|
||||||
[any language](doc/Factoids.md#supported-languages)! This is one of PBot's most powerful features.
|
|
||||||
|
|
||||||
How is this safe? Because the code is executed safely within a virtual machine sandbox.
|
|
||||||
|
|
||||||
For example, the venerable `rot13` function:
|
For example, the venerable `rot13` function:
|
||||||
|
|
||||||
<pragma-> !factadd rot13 /code sh echo "$@" | tr a-zA-Z n-za-mN-ZA-M
|
<pragma-> !factadd rot13 /code sh echo "$@" | tr a-zA-Z n-za-mN-ZA-M
|
||||||
|
Loading…
Reference in New Issue
Block a user