A bot for Euphoria created by @myhandsaretypingwords that creates other bots.
@BotBot uses Python 3.
To install: python3 setup.py install
To run: botbot
The easiest way to make one-time configuration changes is through the command-line options.
The command-line options are:
Short form | Long form | Description | Default value |
---|---|---|---|
-h |
--help |
Show a help message and exit | |
-r ROOM |
--room ROOM |
Room in Euphoria where @BotBot should reside | testing |
-p PASSWORD |
--password PASSWORD |
Password for room if necessary | None |
-n NICKNAME |
--nickname NICKNAME |
Custom nickname for @BotBot | BotBot |
-s SNAPSHOT_DIR |
--snapshot-dir SNAPSHOT_DIR |
Directory where snapshots will be read and written | None |
These are also all described in @BotBot's help text, which you can view using botbot --help
.
You can also create a JSON file containing your custom configuration.
Default configuration values are in defaults.json
. If a setting is not specified in your configuration file, it
defaults to the value shown in defaults.json
.
The configuration file is specified as the first positional argument, as in botbot /path/to/config.json
.
The possible options that can be specified in the configuration file are as follows:
JSON key | Description | Default value |
---|---|---|
"room" |
Room in Euphoria where @BotBot should reside | "testing" |
"password" |
Password for room if necessary | null |
"nickname" |
Custom nickname for @BotBot | "BotBot" |
"helpText" |
Custom help text for @BotBot; shown when someone sends !help @BotBot |
See defaults.json . |
"shortHelpText" |
Custom short help text for @BotBot; shown when someone sends !help |
See defaults.json . |
"snapshotDirectory" |
Directory where snapshots will be read and written | null |
Command-line options take precedence over the configuration file, which takes precedence over the default settings.
For any given configurable setting:
- If there is a command-line option specifying that setting, that value is used.
- Otherwise, if there is a value in the specified configuration file, that value is used.
- Otherwise, the default value is used.
For your convenience, certain files may be placed right inside the repository without interfering
with git. These files have been added to the .gitignore
file.
config.json
This file is intended to be your own custom configuration file. It should be located in the root of the repository for it to be ignored by git.snapshots/
Asnapshots
directory is included in the repository, which contains a single file,snapshots.txt
. Any other file inside the directory should be ignored by git. Therefore, this directory is a good place to use as a snapshot directory.
Create a bot with @BotName with some code.
!createbot @BotName CODE
Same as the previous but specify the room to put the bot in.
!createbot &room @BotName CODE
List all the bots that are currently running and have been created by @BotBot.
!list @BotBot
Kill a bot with the name @BotName.
!kill @BotName
Pause a bot with the name @BotName.
!pause @BotName
Get the UUID of a bot with the name @BotName.
!uuid @BotName
Kill a bot with the UUID 00112233-4455-6677-8899-aabbccddeeff.
!ukill 00112233-4455-6677-8899-aabbccddeeff
Kill all the bots created by @BotBot.
!killall @BotBot
Take a snapshot of the state of @BotBot.
!save @BotBot
Load the latest snapshot.
!load @BotBot latest
Load a snapshot with a specific file name.
!load @BotBot FILENAME
Restart @BotBot.
!restart @BotBot
Regex -> Response
Regex -> [List, of, responses, from, which, to, randomly, choose]
Regex -> {Multiple, responses, to, a, single, message}
Regex 1 -> Response 1; Regex 2 -> Response 2
These response methods can also be nested:
Regex -> [a, {b, c}]
Arguments can be left out. Simply use an empty string as the response, and no message will be displayed.
This can be useful in lists; for example, [Lorem ipsum,,,]
would display "Lorem ipsum" in response to the trigger only 1/4 of the time.
Message sender
(sender)
to include the sender's name with spaces(@sender)
to include an at-mention of the sender
@BotBot has several anti-spam features to stop spammy bots that it creates.
- Bots may not interact with @BotBot.
- Bots may not send the
!ping
command. - Bots may not
!restore
,!pause
, or!kill
other bots. - Bots that are triggered more than 10 times in 5 seconds are automatically paused.
For those of you who don't know, "regex" stands for "regular expression", and is a way of doing pattern matching.
You can find a good tutorial and reference here.
View the @BotBot wiki for a comprehensive guide on how to use @BotBot, including a guide on how to write @BotBot code and a list of features and restrictions that bots created with @BotBot have.
Good luck on your journey to becoming a bot programmer.
There is always an instance of @BotBot up in &bots for you to program.
If you need help, you can ask @myhandsaretypingwords, @jedevc, or any of the other awesome Euphorians in &programming for help with any bot-related questions.
Have fun, and please be respectful!
@BotBot complies with the Euphorian bot standards.