die "Missing player_names" if not ref $params{player_names} eq 'ARRAY';
die "Missing player_names" if not @{$params{player_names}};
$self->{player}=[];
- $self->{current_player}=0;
- my $player_counter=0;
for my $player_name (@{$params{player_names}})
{
- $player_counter++;
$self->add_player(&create_player(name=>$player_name,rank=>undef,active=>1));
}
- $self->{active_player_count}=$player_counter;
- $self->{player_count}=$player_counter;
- $self->{round}=1;
+ $self->{callbacks}=$params{callbacks};
+ $self->init();
+ return $self;
+}
+
+
+sub init
+{
+ my $self=shift;
+ $self->{round}=0;
$self->{max_shoots_per_player}=3;
$self->{current_shoot_count}=0;
- $self->{callbacks}=$params{callbacks};
+ $self->{current_player}=0;
+ $self->{player_count}=@{$self->{player}};
+ $self->{active_player_count}=$self->{player_count};
$self->callback('init');
- return $self;
}
sub reset_game
{
my $self=shift;
+ my @sort_player = sort { $b->{rank} <=> $a->{rank} } @{$self->{player}};
+ $self->{player}=[];
+ for my $player (@sort_player)
+ {
+ $self->add_player(&create_player(name=>$player->{name},rank=>undef,active=>1));
+ }
+ $self->init();
}
sub callback
if ($mult =~/^\d$/)
{
die "Unexpected input" if not $number=~/^\d+$/;
+ next if not $self->{current_shoot_count} < $self->{max_shoots_per_player};
$self->shoot($mult,$number);
} elsif ($mult eq 'btn') {
$self->next_player();
pop @history;
$self= pop @history;
$self->callback('undo');
+ } elsif ($mult eq 'reset') {
+ $self->reset_game();
+ } elsif ($mult eq 'quit') {
+ return;
+ } else {
+ # shitty input
+ next;
}
push @history, Clone::clone($self);
$self->callback('before_shoot');
my $self=shift;
$self->callback('before_next_player');
$self->{current_shoot_count}=0;
- ($self->{current_player},my $new_round)=get_next_active_player($self->{player},$self->{current_player});
+ ($self->{current_player},my $new_round)=$self->get_next_active_player();
$self->shout("player");
$self->shout($self->get_current_player()->{name});
$self->next_round() if $new_round;
sub get_next_active_player
{
- my ($players_ref,$current_player)=@_;
+ my $self=shift;
+ my $players_ref = $self->{player};
+ my $current_player = $self->{current_player};
my $num_players=@$players_ref;
my $new_round=0;
do
$current_player++;
if($current_player>=$num_players)
{
- die "Error no remaining active players" if $new_round;
+ $self->reset_game() if $new_round;
$current_player=0;
$new_round=1;
}
}
- while (not $players_ref->[$current_player]{active});
+ while (not $self->{player}->[$current_player]{active});
return ($current_player,$new_round);
}
+sub finish_player_round
+{
+ my $self=shift;
+ $self->{current_shoot_count} = $self->{max_shoots_per_player};
+}
+
sub next_round
{
my $self=shift;
return $self->callback('next_round');
}
+sub win
+{
+ my $self=shift;
+ $self->shout('win');
+ $self->deactivate_current_player($self->{player_count}-$self->{active_player_count}+1);
+ if ($self->{active_player_count}==1)
+ {
+ $self->next_player();
+ $self->shout('lose');
+ $self->deactivate_current_player($self->{player_count}-$self->{active_player_count}+1);
+ }
+}
+
+sub lose
+{
+ my $self=shift;
+ $self->shout('lose');
+ $self->deactivate_current_player($self->{active_player_count});
+ if ($self->{active_player_count}==1)
+ {
+ $self->next_player();
+ $self->shout('win');
+ $self->deactivate_current_player($self->{active_player_count});
+ }
+}
+
sub deactivate_current_player
{
my $self=shift;
sub end_game
{
my $self=shift;
+ $self->shout('end_game');
return $self->callback('end_game');
}