NAME

Bot::Backbone::Service::OFun::Dice - Tools for rolling dice, flipping coins, choosing, and shuffling

VERSION

version 0.142230

SYNOPSIS

# in your bot config
service dice => (
service => 'OFun::Dice',
);
dispatcher chatroom => as {
redispatch_to 'dice';
};
# in chat
alice> !roll
bot> Rolled 4
alice> !roll 2d4+3
bot> Rolled 7
alice> !flip
bot> Flipped 1 times: heads
alice> !flip 4
bot> Flipped 4 times: tails, tails, tails, heads
alice> !choose 2 alice bob chuck dick ed
bot> I choose ed, chuck
alice> !choose alice bob chuck dick ed
bot> I choose dick
alice> !shuffle alice bob chuck dick ed
bot> I choose bob, alice, ed, dick, chuck

DESCRIPTION

This service provides a number of tools related to randomly generating numbers, coin flips, choosing items, etc.

DISPATCHER

!roll

!roll
!roll 2d6
!roll 4d20+12

Generates a dice roll. If no arguments are given, it's the same as rolling a single 6-sided die. If you specify dice notation, it will roll the dice specified.

!flip

!flip
!flip 5

Flips a coin or several. If no arguments are given, it will flip a single coin and report the outcome. If a number is given, it will flip that many coins.

!choose

!choose 3 a b c d e
!choose a b c d e

Choose 1 or more items from a list. If the first argument is a number, it will choose that many items from the list. If the first argument is not a number, it will choose a single item.

!shuffle

!shuffle a b c d e

This is identical to:

!choose 5 a b c d e

It choose all items, but shuffles them in the process.

METHODS

roll_dice

Implements the !roll and !flip commands.

flip_coin

Implements the !flip command by passing "d2" as the dice notation to "roll_dice".

choose_n

Implements the !choose and !shuffle commands.

choose_all

Implements the !shuffle command by counting the number of arguments and asking "choose_n" to pick that many items.

AUTHOR

Andrew Sterling Hanenkamp <hanenkamp@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2014 by Qubling Software LLC.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.