fixed some minor bugs and added !retract
This commit is contained in:
parent
25369f43be
commit
e3a009b65f
91
wolfgame.py
91
wolfgame.py
@ -21,7 +21,7 @@ def connect_callback(cli):
|
|||||||
cli.identify(botconfig.PASS)
|
cli.identify(botconfig.PASS)
|
||||||
cli.join(botconfig.CHANNEL)
|
cli.join(botconfig.CHANNEL)
|
||||||
cli.msg("ChanServ", "op "+botconfig.CHANNEL)
|
cli.msg("ChanServ", "op "+botconfig.CHANNEL)
|
||||||
|
|
||||||
vars.LAST_PING = 0 # time of last !ping
|
vars.LAST_PING = 0 # time of last !ping
|
||||||
vars.ROLES = {"person" : []}
|
vars.ROLES = {"person" : []}
|
||||||
vars.PHASE = "none" # "join", "day", or "night"
|
vars.PHASE = "none" # "join", "day", or "night"
|
||||||
@ -53,7 +53,7 @@ def reset(cli):
|
|||||||
for deadguy in vars.DEAD:
|
for deadguy in vars.DEAD:
|
||||||
cli.mode(chan, "-q", "{0} {0}!*@*".format(deadguy))
|
cli.mode(chan, "-q", "{0} {0}!*@*".format(deadguy))
|
||||||
vars.DEAD = []
|
vars.DEAD = []
|
||||||
|
|
||||||
vars.ROLES = {"person" : []}
|
vars.ROLES = {"person" : []}
|
||||||
|
|
||||||
|
|
||||||
@ -177,7 +177,7 @@ def stats(cli, nick, chan, rest):
|
|||||||
message = []
|
message = []
|
||||||
for role in ("wolf", "seer", "harlot"):
|
for role in ("wolf", "seer", "harlot"):
|
||||||
count = len(vars.ROLES.get(role,[]))
|
count = len(vars.ROLES.get(role,[]))
|
||||||
if count > 1:
|
if count > 1 or count == 0:
|
||||||
message.append("\u0002(0}\u0002 {1}".format(count, vars.plural(role)))
|
message.append("\u0002(0}\u0002 {1}".format(count, vars.plural(role)))
|
||||||
else:
|
else:
|
||||||
message.append("\u0002{0}\u0002 {1}".format(count, role))
|
message.append("\u0002{0}\u0002 {1}".format(count, role))
|
||||||
@ -189,9 +189,9 @@ def stats(cli, nick, chan, rest):
|
|||||||
", ".join(message[0:-1]),
|
", ".join(message[0:-1]),
|
||||||
message[-1],
|
message[-1],
|
||||||
vb))
|
vb))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def hurry_up(cli):
|
def hurry_up(cli):
|
||||||
if vars.PHASE != "day": return
|
if vars.PHASE != "day": return
|
||||||
|
|
||||||
@ -199,7 +199,7 @@ def hurry_up(cli):
|
|||||||
pl = vars.list_players()
|
pl = vars.list_players()
|
||||||
avail = len(pl) - len(vars.WOUNDED)
|
avail = len(pl) - len(vars.WOUNDED)
|
||||||
votesneeded = avail // 2 + 1
|
votesneeded = avail // 2 + 1
|
||||||
|
|
||||||
found_dup = False
|
found_dup = False
|
||||||
max = (0, "")
|
max = (0, "")
|
||||||
for votee, voters in iter(vars.VOTES.items()):
|
for votee, voters in iter(vars.VOTES.items()):
|
||||||
@ -216,7 +216,7 @@ def hurry_up(cli):
|
|||||||
cli.msg(chan, "The sun is almost setting.")
|
cli.msg(chan, "The sun is almost setting.")
|
||||||
for plr in pl:
|
for plr in pl:
|
||||||
vars.VOTES[plr] = [None] * (votesneeded - 1)
|
vars.VOTES[plr] = [None] * (votesneeded - 1)
|
||||||
|
|
||||||
def chk_decision(cli):
|
def chk_decision(cli):
|
||||||
chan = botconfig.CHANNEL
|
chan = botconfig.CHANNEL
|
||||||
pl = vars.list_players()
|
pl = vars.list_players()
|
||||||
@ -235,17 +235,17 @@ def chk_decision(cli):
|
|||||||
@checks
|
@checks
|
||||||
@cmd("!votes")
|
@cmd("!votes")
|
||||||
def show_votes(cli, nick, chan, rest):
|
def show_votes(cli, nick, chan, rest):
|
||||||
if not vars.VOTES.values():
|
if vars.PHASE != "day":
|
||||||
cli.msg(chan, nick+": No votes yet.")
|
|
||||||
return
|
|
||||||
elif vars.PHASE != "day":
|
|
||||||
cli.notice(nick, "Voting is only during the day.")
|
cli.notice(nick, "Voting is only during the day.")
|
||||||
return
|
return
|
||||||
|
elif not vars.VOTES.values():
|
||||||
|
cli.msg(chan, nick+": No votes yet.")
|
||||||
|
return
|
||||||
if None in [x for voter in vars.VOTES.values() for x in voter]:
|
if None in [x for voter in vars.VOTES.values() for x in voter]:
|
||||||
cli.msg(chan, (nick+": Tiebreaker conditions. Whoever "+
|
cli.msg(chan, (nick+": Tiebreaker conditions. Whoever "+
|
||||||
"receives the next vote will be lynched."))
|
"receives the next vote will be lynched."))
|
||||||
return
|
return
|
||||||
|
|
||||||
votelist = ["{0}: {1} ({2})".format(votee,
|
votelist = ["{0}: {1} ({2})".format(votee,
|
||||||
len(vars.VOTES[votee]),
|
len(vars.VOTES[votee]),
|
||||||
" ".join(vars.VOTES[votee]))
|
" ".join(vars.VOTES[votee]))
|
||||||
@ -260,7 +260,7 @@ def show_votes(cli, nick, chan, rest):
|
|||||||
"to vote.").format(nick, len(pl), votesneeded, avail))
|
"to vote.").format(nick, len(pl), votesneeded, avail))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def chk_win(cli):
|
def chk_win(cli):
|
||||||
""" Returns True if someone won """
|
""" Returns True if someone won """
|
||||||
|
|
||||||
@ -282,7 +282,7 @@ def chk_win(cli):
|
|||||||
return False
|
return False
|
||||||
else:
|
else:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
if vars.DAY_START_TIME:
|
if vars.DAY_START_TIME:
|
||||||
now = datetime.now()
|
now = datetime.now()
|
||||||
td = now - vars.DAY_START_TIME
|
td = now - vars.DAY_START_TIME
|
||||||
@ -291,7 +291,7 @@ def chk_win(cli):
|
|||||||
now = datetime.now()
|
now = datetime.now()
|
||||||
td = now - vars.NIGHT_START_TIME
|
td = now - vars.NIGHT_START_TIME
|
||||||
vars.NIGHT_TIMEDELTA += td
|
vars.NIGHT_TIMEDELTA += td
|
||||||
|
|
||||||
daymin, daysec = vars.DAY_TIMEDELTA.seconds // 60, vars.DAY_TIMEDELTA.seconds % 60
|
daymin, daysec = vars.DAY_TIMEDELTA.seconds // 60, vars.DAY_TIMEDELTA.seconds % 60
|
||||||
nitemin, nitesec = vars.NIGHT_TIMEDELTA.seconds // 60, vars.NIGHT_TIMEDELTA.seconds % 60
|
nitemin, nitesec = vars.NIGHT_TIMEDELTA.seconds // 60, vars.NIGHT_TIMEDELTA.seconds % 60
|
||||||
total = vars.DAY_TIMEDELTA + vars.NIGHT_TIMEDELTA
|
total = vars.DAY_TIMEDELTA + vars.NIGHT_TIMEDELTA
|
||||||
@ -301,7 +301,7 @@ def chk_win(cli):
|
|||||||
"\u0002{4:0<2}:{5:0<2}\u0002 was night. ").format(tmin, tsec,
|
"\u0002{4:0<2}:{5:0<2}\u0002 was night. ").format(tmin, tsec,
|
||||||
daymin, daysec,
|
daymin, daysec,
|
||||||
nitemin, nitesec))
|
nitemin, nitesec))
|
||||||
|
|
||||||
roles_msg = []
|
roles_msg = []
|
||||||
for role in ("wolf", "seer", "harlot", "village drunk", "traitor"):
|
for role in ("wolf", "seer", "harlot", "village drunk", "traitor"):
|
||||||
if len(vars.ORIGINAL_ROLES[role]) == 0:
|
if len(vars.ORIGINAL_ROLES[role]) == 0:
|
||||||
@ -321,16 +321,16 @@ def chk_win(cli):
|
|||||||
if vars.CURSED:
|
if vars.CURSED:
|
||||||
roles_msg.append("The cursed villager was \u0002{0}\u0002.".format(vars.CURSED))
|
roles_msg.append("The cursed villager was \u0002{0}\u0002.".format(vars.CURSED))
|
||||||
cli.msg(chan, " ".join(roles_msg))
|
cli.msg(chan, " ".join(roles_msg))
|
||||||
|
|
||||||
reset(cli)
|
reset(cli)
|
||||||
# TODO: Reveal roles here
|
# TODO: Reveal roles here
|
||||||
return True
|
return True
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def del_player(cli, nick, forced_death):
|
def del_player(cli, nick, forced_death):
|
||||||
""" Returns False if one side won. """
|
""" Returns False if one side won. """
|
||||||
|
|
||||||
cli.mode(botconfig.CHANNEL, "-v", "{0} {0}!*@*".format(nick))
|
cli.mode(botconfig.CHANNEL, "-v", "{0} {0}!*@*".format(nick))
|
||||||
vars.del_player(nick)
|
vars.del_player(nick)
|
||||||
ret = True
|
ret = True
|
||||||
@ -413,7 +413,7 @@ def transition_day(cli):
|
|||||||
cli.msg(chan, ("The villagers must now vote for whom to lynch. "+
|
cli.msg(chan, ("The villagers must now vote for whom to lynch. "+
|
||||||
'Use "!lynch <nick>" to cast your vote. 3 votes '+
|
'Use "!lynch <nick>" to cast your vote. 3 votes '+
|
||||||
'are required to lynch.'))
|
'are required to lynch.'))
|
||||||
|
|
||||||
if vars.DAY_TIME_LIMIT > 0: # Time limit enabled
|
if vars.DAY_TIME_LIMIT > 0: # Time limit enabled
|
||||||
t = threading.Timer(vars.DAY_TIME_LIMIT, hurry_up, [cli])
|
t = threading.Timer(vars.DAY_TIME_LIMIT, hurry_up, [cli])
|
||||||
vars.TIMERS[1] = t
|
vars.TIMERS[1] = t
|
||||||
@ -448,6 +448,7 @@ def vote(cli, nick, chan, rest):
|
|||||||
vars.VOTES[voters].remove(nick)
|
vars.VOTES[voters].remove(nick)
|
||||||
if not vars.VOTES[voters] and voters != voted:
|
if not vars.VOTES[voters] and voters != voted:
|
||||||
del vars.VOTES[voters]
|
del vars.VOTES[voters]
|
||||||
|
break
|
||||||
if voted not in vars.VOTES.keys():
|
if voted not in vars.VOTES.keys():
|
||||||
vars.VOTES[voted] = [nick]
|
vars.VOTES[voted] = [nick]
|
||||||
else:
|
else:
|
||||||
@ -461,6 +462,26 @@ def vote(cli, nick, chan, rest):
|
|||||||
cli.notice(nick, "\u0002{0}\u0002 is currently not playing.".format(rest))
|
cli.notice(nick, "\u0002{0}\u0002 is currently not playing.".format(rest))
|
||||||
|
|
||||||
|
|
||||||
|
@checks
|
||||||
|
@cmd("!retract")
|
||||||
|
def retract(cli, nick, chan, rest):
|
||||||
|
if vars.PHASE != "day":
|
||||||
|
cli.notice(nick, ("Lynching is only allowed during the day. "+
|
||||||
|
"Please wait patiently for morning."))
|
||||||
|
return
|
||||||
|
|
||||||
|
candidates = vars.VOTES.keys()
|
||||||
|
for voters in list(candidates):
|
||||||
|
if nick in vars.VOTES[voters]:
|
||||||
|
vars.VOTES[voters].remove(nick)
|
||||||
|
if not vars.VOTES[voters]:
|
||||||
|
del vars.VOTES[voters]
|
||||||
|
cli.msg(chan, "\u0002{0}\u0002 retracted his/her vote.".format(nick))
|
||||||
|
break
|
||||||
|
else:
|
||||||
|
cli.notice(nick, "You haven't voted yet.")
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@checks
|
@checks
|
||||||
@pmcmd("!kill", "kill")
|
@pmcmd("!kill", "kill")
|
||||||
@ -534,20 +555,21 @@ def relay(cli, nick, rest):
|
|||||||
|
|
||||||
def transition_night(cli):
|
def transition_night(cli):
|
||||||
vars.PHASE = "night"
|
vars.PHASE = "night"
|
||||||
|
|
||||||
# Reset daytime variables
|
# Reset daytime variables
|
||||||
vars.VOTES = {}
|
vars.VOTES = {}
|
||||||
if vars.TIMERS[1]: # cancel daytime-limit timer
|
if vars.TIMERS[1]: # cancel daytime-limit timer
|
||||||
vars.TIMERS[1].cancel()
|
vars.TIMERS[1].cancel()
|
||||||
vars.TIMERS[1] = None
|
vars.TIMERS[1] = None
|
||||||
vars.WOUNDED = []
|
vars.WOUNDED = []
|
||||||
|
|
||||||
# Reset nighttime variables
|
# Reset nighttime variables
|
||||||
vars.VICTIM = "" # nickname of kill victim
|
vars.VICTIM = "" # nickname of kill victim
|
||||||
vars.SEEN = [] # list of seers that have had visions
|
vars.SEEN = [] # list of seers that have had visions
|
||||||
vars.NIGHT_START_TIME = datetime.now()
|
vars.NIGHT_START_TIME = datetime.now()
|
||||||
|
|
||||||
daydur_msg = ""
|
daydur_msg = ""
|
||||||
|
|
||||||
if vars.NIGHT_TIMEDELTA: # transition from day
|
if vars.NIGHT_TIMEDELTA: # transition from day
|
||||||
td = vars.NIGHT_START_TIME - vars.DAY_START_TIME
|
td = vars.NIGHT_START_TIME - vars.DAY_START_TIME
|
||||||
vars.DAY_START_TIME = None
|
vars.DAY_START_TIME = None
|
||||||
@ -556,11 +578,7 @@ def transition_night(cli):
|
|||||||
daydur_msg = "Day lasted \u0002{0:0>2}:{1:0>2}. ".format(min,sec)
|
daydur_msg = "Day lasted \u0002{0:0>2}:{1:0>2}. ".format(min,sec)
|
||||||
|
|
||||||
chan = botconfig.CHANNEL
|
chan = botconfig.CHANNEL
|
||||||
cli.msg(chan, (daydur_msg + "It is now nighttime. All players "+
|
|
||||||
"check for PMs from me for instructions. "+
|
|
||||||
"If you did not receive one, simply sit back, "+
|
|
||||||
"relax, and wait patiently for morning."))
|
|
||||||
|
|
||||||
if vars.NIGHT_TIME_LIMIT > 0:
|
if vars.NIGHT_TIME_LIMIT > 0:
|
||||||
t = threading.Timer(vars.NIGHT_TIME_LIMIT, transition_day, [cli])
|
t = threading.Timer(vars.NIGHT_TIME_LIMIT, transition_day, [cli])
|
||||||
vars.TIMERS[0] = t
|
vars.TIMERS[0] = t
|
||||||
@ -593,6 +611,13 @@ def transition_night(cli):
|
|||||||
for d in vars.ROLES["village drunk"]:
|
for d in vars.ROLES["village drunk"]:
|
||||||
cli.msg(d, 'You have been drinking too much! You are the \u0002village drunk\u0002.')
|
cli.msg(d, 'You have been drinking too much! You are the \u0002village drunk\u0002.')
|
||||||
|
|
||||||
|
cli.msg(chan, (daydur_msg + "It is now nighttime. All players "+
|
||||||
|
"check for PMs from me for instructions. "+
|
||||||
|
"If you did not receive one, simply sit back, "+
|
||||||
|
"relax, and wait patiently for morning."))
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@cmd("!start")
|
@cmd("!start")
|
||||||
def start(cli, nick, chan, rest):
|
def start(cli, nick, chan, rest):
|
||||||
villagers = vars.list_players()
|
villagers = vars.list_players()
|
||||||
@ -652,8 +677,8 @@ def start(cli, nick, chan, rest):
|
|||||||
for person in vars.ROLES["gunner"]:
|
for person in vars.ROLES["gunner"]:
|
||||||
villagers.append(person)
|
villagers.append(person)
|
||||||
del vars.ROLES["gunner"]
|
del vars.ROLES["gunner"]
|
||||||
|
|
||||||
vars.ROLES["villager"] = villagers
|
vars.ROLES["villager"] = villagers
|
||||||
|
|
||||||
cli.msg(chan, ("{0}: Welcome to Werewolf, the popular detective/social party "+
|
cli.msg(chan, ("{0}: Welcome to Werewolf, the popular detective/social party "+
|
||||||
"game (a theme of Mafia).").format(", ".join(vars.list_players())))
|
"game (a theme of Mafia).").format(", ".join(vars.list_players())))
|
||||||
|
Loading…
Reference in New Issue
Block a user