# PBot Documentation ## Table of Contents * [QuickStart](QuickStart.md#quickstart) * [Installation](QuickStart.md#installation) * [Installing Perl](QuickStart.md#installing-perl) * [Installing CPAN modules](QuickStart.md#installing-cpan-modules) * [Installing PBot](QuickStart.md#installing-pbot) * [git (recommended)](QuickStart.md#git-recommended) * [Download zip archive](QuickStart.md#download-zip-archive) * [Initial Setup](QuickStart.md#initial-setup) * [Clone data-directory](QuickStart.md#clone-data-directory) * [Configuration](QuickStart.md#configuration) * [Recommended settings for IRC Networks](QuickStart.md#recommended-settings-for-irc-networks) * [Starting PBot](QuickStart.md#starting-pbot) * [Usage](QuickStart.md#usage) * [Overriding directories](QuickStart.md#overriding-directories) * [Overriding registry](QuickStart.md#overriding-registry) * [First-time start-up](QuickStart.md#first-time-start-up) * [Using default Freenode settings](QuickStart.md#using-default-freenode-settings) * [Using custom settings](QuickStart.md#using-custom-settings) * [Regular start-up](QuickStart.md#regular-start-up) * [Additional configuration](QuickStart.md#additional-configuration) * [Creating your bot owner admin account](QuickStart.md#creating-your-bot-owner-admin-account) * [Adding other users and admins](QuickStart.md#adding-other-users-and-admins) * [Adding channels](QuickStart.md#adding-channels) * [Further Reading](QuickStart.md#further-reading) * [Commands](QuickStart.md#commands) * [Factoids](QuickStart.md#factoids) * [Plugins](QuickStart.md#plugins) * [Modules](QuickStart.md#modules) * [Plugins](Plugins.md#plugins) * [About](Plugins.md#about) * [Plang](Plugins/Plang.md) * [Quotegrabs](Plugins/Quotegrabs.md) * [Commands](Commands.md#commands) * [Command interpreter](Commands.md#command-interpreter) * [Command invocation](Commands.md#command-invocation) * [Addressing output to users](Commands.md#addressing-output-to-users) * [Inline invocation](Commands.md#inline-invocation) * [Chaining](Commands.md#chaining) * [Piping](Commands.md#piping) * [Substitution](Commands.md#substitution) * [Variables](Commands.md#variables) * [Selectors](Commands.md#selectors) * [Background processing](Commands.md#background-processing) * [Types of commands](Commands.md#types-of-commands) * [Built-in commands](Commands.md#built-in-commands) * [Creating new built-in commands](Commands.md#creating-new-built-in-commands) * [Plugins](Commands.md#plugins) * [Functions](Commands.md#functions) * [Factoids](Commands.md#factoids) * [Code Factoids](Commands.md#code-factoids) * [Modules](Commands.md#modules) * [Commands documented here](Commands.md#commands-documented-here) * [version](Commands.md#version) * [help](Commands.md#help) * [uptime](Commands.md#uptime) * [my](Commands.md#my) * [date](Commands.md#date) * [weather](Commands.md#weather) * [Commands documented elsewhere](Commands.md#commands-documented-elsewhere) * [Administrative commands](Commands.md#administrative-commands) * [Logging in and out of PBot](Commands.md#logging-in-and-out-of-pbot) * [User management commands](Commands.md#user-management-commands) * [Channel management commands](Commands.md#channel-management-commands) * [Module management commands](Commands.md#module-management-commands) * [Plugin management commands](Commands.md#plugin-management-commands) * [Command metadata](Commands.md#command-metadata) * [Event queue](Commands.md#event-queue) * [Process management](Commands.md#process-management) * [Registry commands](Commands.md#registry-commands) * [Miscellaneous admin commands](Commands.md#miscellaneous-admin-commands) * [Factoid commands](Commands.md#factoid-commands) * [Adding/removing factoids](Commands.md#addingremoving-factoids) * [Displaying factoids](Commands.md#displaying-factoids) * [Editing factoids](Commands.md#editing-factoids) * [Factoid metadata](Commands.md#factoid-metadata) * [Information about factoids](Commands.md#information-about-factoids) * [Administrative](Admin.md#administrative) * [Logging in and out](Admin.md#logging-in-and-out) * [login](Admin.md#login) * [logout](Admin.md#logout) * [User management commands](Admin.md#user-management-commands) * [useradd](Admin.md#useradd) * [userdel](Admin.md#userdel) * [userset](Admin.md#userset) * [userunset](Admin.md#userunset) * [User metadata list](Admin.md#user-metadata-list) * [Listing users](Admin.md#listing-users) * [User capabilities](Admin.md#user-capabilities) * [Introduction](Admin.md#introduction) * [cap](Admin.md#cap) * [Listing capabilities](Admin.md#listing-capabilities) * [Grouping capabilities](Admin.md#grouping-capabilities) * [Giving capabilities to users](Admin.md#giving-capabilities-to-users) * [Checking user capabilities](Admin.md#checking-user-capabilities) * [Listing users who have a capability](Admin.md#listing-users-who-have-a-capability) * [User capabilities list](Admin.md#user-capabilities-list) * [Channel management commands](Admin.md#channel-management-commands) * [join](Admin.md#join) * [part](Admin.md#part) * [chanadd](Admin.md#chanadd) * [chanrem](Admin.md#chanrem) * [chanset](Admin.md#chanset) * [chanunset](Admin.md#chanunset) * [chanlist](Admin.md#chanlist) * [Channel metadata list](Admin.md#channel-metadata-list) * [ignore](Admin.md#ignore) * [unignore](Admin.md#unignore) * [blacklist](Admin.md#blacklist) * [op](Admin.md#op) * [deop](Admin.md#deop) * [voice](Admin.md#voice) * [devoice](Admin.md#devoice) * [mode](Admin.md#mode) * [ban/mute](Admin.md#banmute) * [unban/unmute](Admin.md#unbanunmute) * [invite](Admin.md#invite) * [kick](Admin.md#kick) * [Module management commands](Admin.md#module-management-commands) * [load](Admin.md#load) * [unload](Admin.md#unload) * [Listing modules](Admin.md#listing-modules) * [Plugin management commands](Admin.md#plugin-management-commands) * [plug](Admin.md#plug) * [unplug](Admin.md#unplug) * [replug](Admin.md#replug) * [pluglist](Admin.md#pluglist) * [Command metadata commands](Admin.md#command-metadata-commands) * [cmdset](Admin.md#cmdset) * [cmdunset](Admin.md#cmdunset) * [Command metadata list](Admin.md#command-metadata-list) * [Event queue management](Admin.md#event-queue-management) * [eventqueue](Admin.md#eventqueue) * [Process management commands](Admin.md#process-management-commands) * [ps](Admin.md#ps) * [kill](Admin.md#kill) * [Miscellaneous commands](Admin.md#miscellaneous-commands) * [export](Admin.md#export) * [refresh](Admin.md#refresh) * [reload](Admin.md#reload) * [sl](Admin.md#sl) * [die](Admin.md#die) * [Factoids](Factoids.md#factoids) * [About](Factoids.md#about) * [Special commands](Factoids.md#special-commands) * [/say](Factoids.md#say) * [/me](Factoids.md#me) * [/call](Factoids.md#call) * [/msg](Factoids.md#msg) * [/code](Factoids.md#code) * [Supported languages](Factoids.md#supported-languages) * [Special variables](Factoids.md#special-variables) * [testargs example](Factoids.md#testargs-example) * [Setting a usage message](Factoids.md#setting-a-usage-message) * [poll/vote example](Factoids.md#pollvote-example) * [SpongeBob Mock meme example](Factoids.md#spongebob-mock-meme-example) * [Using command-piping](Factoids.md#using-command-piping) * [Improving SpongeBob Mock meme](Factoids.md#improving-spongebob-mock-meme) * [Formatting and editing lengthy Code Factoids](Factoids.md#formatting-and-editing-lengthy-code-factoids) * [Special variables](Factoids.md#special-variables-1) * [$args](Factoids.md#args) * [$arg[n]](Factoids.md#argn) * [$arg[n:m]](Factoids.md#argnm) * [$arglen](Factoids.md#arglen) * [$channel](Factoids.md#channel) * [$nick](Factoids.md#nick) * [$randomnick](Factoids.md#randomnick) * [$0](Factoids.md#0) * [List variables](Factoids.md#list-variables) * [Expansion modifiers](Factoids.md#expansion-modifiers) * [action_with_args](Factoids.md#action_with_args) * [add_nick](Factoids.md#add_nick) * [Channel namespaces](Factoids.md#channel-namespaces) * [Adding/removing factoids](Factoids.md#addingremoving-factoids) * [factadd](Factoids.md#factadd) * [factrem](Factoids.md#factrem) * [forget](Factoids.md#forget) * [factalias](Factoids.md#factalias) * [Displaying factoids](Factoids.md#displaying-factoids) * [fact](Factoids.md#fact) * [factshow](Factoids.md#factshow) * [Editing factoids](Factoids.md#editing-factoids) * [factchange](Factoids.md#factchange) * [factmove](Factoids.md#factmove) * [factundo](Factoids.md#factundo) * [factredo](Factoids.md#factredo) * [Factoid metadata](Factoids.md#factoid-metadata) * [factset](Factoids.md#factset) * [factunset](Factoids.md#factunset) * [Factoid metadata List](Factoids.md#factoid-metadata-list) * [Information about factoids](Factoids.md#information-about-factoids) * [factfind](Factoids.md#factfind) * [factinfo](Factoids.md#factinfo) * [factlog](Factoids.md#factlog) * [factset](Factoids.md#factset-1) * [count](Factoids.md#count) * [histogram](Factoids.md#histogram) * [top20](Factoids.md#top20) * [Registry](Registry.md#registry) * [About](Registry.md#about) * [Types of values](Registry.md#types-of-values) * [Creating array values](Registry.md#creating-array-values) * [Overriding Registry values per-channel](Registry.md#overriding-registry-values-per-channel) * [Overriding Registry values via command-line](Registry.md#overriding-registry-values-via-command-line) * [Registry commands](Registry.md#registry-commands) * [regset](Registry.md#regset) * [regunset](Registry.md#regunset) * [regchange](Registry.md#regchange) * [regshow](Registry.md#regshow) * [regfind](Registry.md#regfind) * [regsetmeta](Registry.md#regsetmeta) * [regunsetmeta](Registry.md#regunsetmeta) * [Editing Registry file](Registry.md#editing-registry-file) * [Metadata list](Registry.md#metadata-list) * [List of known Registry items](Registry.md#list-of-known-registry-items) * [Channel-specific Registry items](Registry.md#channel-specific-registry-items) * [Modules](Modules.md#modules) * [About](Modules.md#about) * [Creating modules](Modules.md#creating-modules) * [Documentation for built-in modules](Modules.md#documentation-for-built-in-modules) * [cc](Modules.md#cc) * [Usage](Modules.md#usage) * [Supported Languages](Modules.md#supported-languages) * [Default Language](Modules.md#default-language) * [Disallowed system calls](Modules.md#disallowed-system-calls) * [Program termination with no output](Modules.md#program-termination-with-no-output) * [Abnormal program termination](Modules.md#abnormal-program-termination) * [C and C++ Functionality](Modules.md#c-and-c-functionality) * [Using the preprocessor](Modules.md#using-the-preprocessor) * [main() Function Unnecessary](Modules.md#main-function-unnecessary) * [Embedding Newlines](Modules.md#embedding-newlines) * [Printing in binary/base2](Modules.md#printing-in-binarybase2) * [Using the GDB debugger](Modules.md#using-the-gdb-debugger) * [Interactive Editing](Modules.md#interactive-editing) * [Some Examples](Modules.md#some-examples) * [english](Modules.md#english) * [expand](Modules.md#expand) * [prec](Modules.md#prec) * [paren](Modules.md#paren) * [faq](Modules.md#faq) * [cfact](Modules.md#cfact) * [cjeopardy](Modules.md#cjeopardy) * [hint](Modules.md#hint) * [what](Modules.md#what) * [w](Modules.md#w) * [filter](Modules.md#filter) * [score](Modules.md#score) * [rank](Modules.md#rank) * [reset](Modules.md#reset) * [qstats](Modules.md#qstats) * [qshow](Modules.md#qshow) * [c99std](Modules.md#c99std) * [c11std](Modules.md#c11std) * [man](Modules.md#man) * [google](Modules.md#google) * [define](Modules.md#define) * [dict](Modules.md#dict) * [foldoc](Modules.md#foldoc) * [vera](Modules.md#vera) * [udict](Modules.md#udict) * [wdict](Modules.md#wdict) * [acronym](Modules.md#acronym) * [math](Modules.md#math) * [calc](Modules.md#calc) * [qalc](Modules.md#qalc) * [compliment](Modules.md#compliment) * [insult](Modules.md#insult) * [excuse](Modules.md#excuse) * [horoscope](Modules.md#horoscope) * [quote](Modules.md#quote) * [Anti-Abuse](AntiAbuse.md#anti-abuse) * [Flood control](AntiAbuse.md#flood-control) * [Message flood](AntiAbuse.md#message-flood) * [Join flood](AntiAbuse.md#join-flood) * [Enter key abuse](AntiAbuse.md#enter-key-abuse) * [Nick flood](AntiAbuse.md#nick-flood) * [Anti-away/Nick-control](AntiAbuse.md#anti-awaynick-control) * [Anti-auto-rejoin control](AntiAbuse.md#anti-auto-rejoin-control) * [Opping/Deopping](AntiAbuse.md#oppingdeopping) * [Virtual Machine](VirtualMachine.md#virtual-machine) * [About](VirtualMachine.md#about) * [Creating a new virtual machine](VirtualMachine.md#creating-a-new-virtual-machine) * [Configuring the virtual machine](VirtualMachine.md#configuring-the-virtual-machine) * [Installing Linux in the virtual machine](VirtualMachine.md#installing-linux-in-the-virtual-machine) * [Configuring Linux for PBot Communication](VirtualMachine.md#configuring-linux-for-pbot-communication) * [Hardening the PBot virtual machine](VirtualMachine.md#hardening-the-pbot-virtual-machine) * [Frequently Asked Questions](FAQ.md#frequently-asked-questions) * [How do I change my password?](FAQ.md#how-do-i-change-my-password) * [How do I make PBot remember my `date` timezone?](FAQ.md#how-do-i-make-pbot-remember-my-date-timezone) * [How do I make PBot remember my `weather` location?](FAQ.md#how-do-i-make-pbot-remember-my-weather-location) * [How do I change the bot trigger?](FAQ.md#how-do-i-change-the-bot-trigger) * [How do I whitelist a user?](FAQ.md#how-do-i-whitelist-a-user)