3
0
mirror of https://github.com/pragma-/pbot.git synced 2025-01-25 19:44:26 +01:00

Battleship: no-arg challenge issues open-ended challenge

This commit is contained in:
Pragmatic Software 2018-07-01 18:46:58 -07:00
parent 5e45e7a741
commit 117b7c2348

View File

@ -127,7 +127,16 @@ sub battleship_cmd {
} }
if (not length $arguments) { if (not length $arguments) {
return "Usage: battleship challenge <nick>"; $self->{current_state} = 'accept';
$self->{state_data} = { players => [], counter => 0 };
my $id = $self->{pbot}->{messagehistory}->{database}->get_message_account($nick, $user, $host);
my $player = { id => $id, name => $nick, missedinputs => 0 };
push @{$self->{state_data}->{players}}, $player;
$player = { id => -1, name => undef, missedinputs => 0 };
push @{$self->{state_data}->{players}}, $player;
return "/msg $self->{channel} $nick has made an open challenge! Use `accept` to accept their challenge.";
} }
my $challengee = $self->{pbot}->{nicklist}->is_present($self->{channel}, $arguments); my $challengee = $self->{pbot}->{nicklist}->is_present($self->{channel}, $arguments);
@ -151,14 +160,20 @@ sub battleship_cmd {
} }
when ('accept') { when ('accept') {
if ($self->{current_state} ne 'accept') {
return "/msg $nick This is not the time to use `accept`.";
}
my $id = $self->{pbot}->{messagehistory}->{database}->get_message_account($nick, $user, $host); my $id = $self->{pbot}->{messagehistory}->{database}->get_message_account($nick, $user, $host);
my $player = $self->{state_data}->{players}->[1]; my $player = $self->{state_data}->{players}->[1];
if ($player->{id} == $id) { # open challenge
if ($self->{current_state} ne 'accept') { if ($player->{id} == -1) {
return "/msg $nick This is not the time to use `accept`."; $player->{id} = $id;
} $player->{name} = $nick;
}
if ($player->{id} == $id) {
$player->{accepted} = 1; $player->{accepted} = 1;
return "/msg $self->{channel} $nick has accepted $self->{state_data}->{players}->[0]->{name}'s challenge!"; return "/msg $self->{channel} $nick has accepted $self->{state_data}->{players}->[0]->{name}'s challenge!";
} else { } else {
@ -266,11 +281,11 @@ sub battleship_cmd {
} }
if ($self->{state_data}->{current_player} != $player) { if ($self->{state_data}->{current_player} != $player) {
return "$nick: It is not your turn to bomb!"; return "$nick: It is not your turn to attack!";
} }
if ($self->{player}->[$player]->{done}) { if ($self->{player}->[$player]->{done}) {
return "$nick: You have already bombed this turn."; return "$nick: You have already attacked this turn.";
} }
if ($arguments !~ m/^[a-zA-Z][0-9]+$/) { if ($arguments !~ m/^[a-zA-Z][0-9]+$/) {
@ -961,13 +976,21 @@ sub accept {
$state->{tocked} = 1; $state->{tocked} = 1;
if (++$state->{counter} > $state->{max_count}) { if (++$state->{counter} > $state->{max_count}) {
$self->send_message($self->{channel}, "$state->{players}->[1]->{name} has failed to accept $state->{players}->[0]->{name}'s challenge."); if ($state->{players}->[1]->{id} == -1) {
$self->send_message($self->{channel}, "Nobody has accepted $state->{players}->[0]->{name}'s challenge.");
} else {
$self->send_message($self->{channel}, "$state->{players}->[1]->{name} has failed to accept $state->{players}->[0]->{name}'s challenge.");
}
$state->{result} = 'stop'; $state->{result} = 'stop';
$state->{players} = []; $state->{players} = [];
return $state; return $state;
} }
$self->send_message($self->{channel}, "$state->{players}->[1]->{name}: $state->{players}->[0]->{name} has challenged you! Use `accept` to accept their challenge."); if ($state->{players}->[1]->{id} == -1) {
$self->send_message($self->{channel}, "$state->{players}->[0]->{name} has made an open challenge! Use `accept` to accept their challenge.");
} else {
$self->send_message($self->{channel}, "$state->{players}->[1]->{name}: $state->{players}->[0]->{name} has challenged you! Use `accept` to accept their challenge.");
}
} }
$state->{result} = 'wait'; $state->{result} = 'wait';