Compare commits

..

No commits in common. "main" and "rollcake" have entirely different histories.

View file

@ -16,34 +16,14 @@ USAGE = '''@ me to roll RPG dice. Examples:
@**Rollcake** void 3
*(Voidheart Symphony city roll, stress gauge 3: 2d6, check if either/both are above 3)*
@**Rollcake** fate 1
*(Fate, rating +1: 4 fate dice, add +1 to total)*
'''
PBTA_RE = re.compile(r'(pbta|apoc(alypse)?|void(heart)? castle)\s+(?P<mod>[-+]?[0-9])(\s+(?P<adv>adv|dis))?')
FITD_RE = re.compile(r'(fitd|forged)\s+(?P<rating>[0-9])\b')
SBR_RE = re.compile(r'(sbr|res(istance)?)\s+(?P<pool>[0-9])(\s+(?P<risk>risk|dang))?')
VOID_RE = re.compile(r'(void(heart)?( city)?)\s+(?P<stress>[0-6])(\s+(?P<adv>adv|dis))?')
FATE_RE = re.compile(r'fate\s+(?P<rating>[-+]?[0-9])')
DICE_RE = re.compile(r'\b(?P<count>[0-9]*)d(?P<sides>[0-9]+)\s*(?P<mod>[-+][0-9]+)?')
FATE_LADDER = [
'Horrifying',
'Catastrophic',
'Terrible',
'Poor',
'Mediocre',
'Average',
'Fair',
'Good',
'Great',
'Superb',
'Fantastic',
'Epic',
'Legendary',
]
def roll(count, sides):
return [random.randint(1, sides) for i in range(count)]
@ -174,25 +154,6 @@ def handle_roll(content):
)
)
fate = FATE_RE.search(content)
if fate:
rating = int(fate.group('rating') or '0')
results = [random.randint(-1, 1) for i in range(4)]
total = sum(results) + rating
ladder_entry = total + 4
if ladder_entry >= 0 and ladder_entry < len(FATE_LADDER):
effort = FATE_LADDER[ladder_entry]
else:
effort = ''
return '**{:+d}{}**\nRolls: {}'.format(
total,
' ' + effort if effort else '',
', '.join(
'`{}`'.format('+' if d == 1 else '-' if d == -1 else ' ')
for d in results
)
)
return USAGE
class RollcakeHandler(object):