X-Git-Url: https://git.realraum.at/?a=blobdiff_plain;f=dart%2FDart.pm;h=7352fc241cb9e38f5fcd12f247d73526cbf739d5;hb=d96e3a99d81c498c26e7f000a0bd98953fc40e22;hp=203db46a667b56599b37eff789412887ae4743fc;hpb=7f621c27a3a2ac7a3a14cf655d03782681e35966;p=svn42.git diff --git a/dart/Dart.pm b/dart/Dart.pm index 203db46..7352fc2 100644 --- a/dart/Dart.pm +++ b/dart/Dart.pm @@ -2,6 +2,7 @@ package Dart; use strict; use base 'Exporter'; +use Clone; # new Dart(player_names=>[ 'lala', 'popo' ]); ## Player, Rank, Active, @@ -52,10 +53,13 @@ sub run { my $self=shift; my ($data_in_fh,$sound_out_fh)=@_; + my @history; # $data_in_fh ||= STDIN; # $sound_out_fh ||= STDOUT; $self->{sound_out_fh}=$sound_out_fh; + push @history, Clone::clone($self); + $self->callback('before_shoot'); #while ( my $shoot_data = <$data_in_fh>) while ( my $shoot_data = ) { @@ -68,7 +72,13 @@ sub run $self->shoot($mult,$number); } elsif ($mult eq 'btn') { $self->next_player(); + } elsif ($mult eq 'undo' and $#history) { + pop @history; + $self= pop @history; + $self->callback('undo'); } + push @history, Clone::clone($self); + $self->callback('before_shoot'); } } @@ -89,7 +99,10 @@ sub shoot sub shout_last_shoot { my $self=shift; - if ($self->{current_shoot}{mult} == 2) { + if ($self->{current_shoot}{mult} == 2 && $self->{current_shoot}{number} == 25) { + $self->shout("bullseye"); + return; + } elsif ($self->{current_shoot}{mult} == 2 ) { $self->shout('double'); } elsif ($self->{current_shoot}{mult} == 3) { $self->shout('triple'); @@ -103,8 +116,13 @@ sub shout my $self=shift; my ($what)=@_; my $fh = $self->{sound_out_fh}; - print "$what\n"; - #print $fh "$what\n"; + if ($what eq 25) + { + print "bull\n"; + } else { + print "$what\n"; + } +#print $fh "$what\n"; } sub get_current_player @@ -159,6 +177,34 @@ sub next_round return $self->callback('next_round'); } +sub win +{ + my $self=shift; + $self->deactivate_current_player($self->{player_count}-$self->{active_player_count}+1); + $self->shout('win'); + if ($self->{active_player_count}==1) + { + $self->next_player(); + $self->lose(); + } elsif (not $self->{active_player_count}) { + $self->end_game(); + } +} + +sub lose +{ + my $self=shift; + $self->deactivate_current_player($self->{active_player_count}); + $self->shout('lose'); + if ($self->{active_player_count}==1) + { + $self->next_player(); + $self->win(); + } elsif (not $self->{active_player_count}) { + $self->end_game(); + } +} + sub deactivate_current_player { my $self=shift; @@ -173,6 +219,7 @@ sub deactivate_current_player sub end_game { my $self=shift; + $self->shout('end_game'); return $self->callback('end_game'); }