ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/kgsueme/kgsueme/game.pl
(Generate patch)

Comparing kgsueme/kgsueme/game.pl (file contents):
Revision 1.52 by pcg, Thu Jun 12 21:03:03 2003 UTC vs.
Revision 1.56 by pcg, Thu Jun 12 23:24:53 2003 UTC

199 $self = $self->SUPER::new(@_); 199 $self = $self->SUPER::new(@_);
200 200
201 $self->listen($self->{conn}); 201 $self->listen($self->{conn});
202 202
203 $self->{window} = new Gtk2::Window 'toplevel'; 203 $self->{window} = new Gtk2::Window 'toplevel';
204 my $title = $self->{channel} ? $self->owner->as_string." ".$self->opponent_string : "Game Window";
205 $self->{window}->set_title("KGS Game $title");
206 gtk::state $self->{window}, "game::window", undef, window_size => [600, 500]; 204 gtk::state $self->{window}, "game::window", undef, window_size => [600, 500];
207 205
208 $self->{window}->signal_connect(delete_event => sub { 206 $self->{window}->signal_connect(delete_event => sub {
209 $self->part; 207 $self->part;
210 $self->destroy; 208 $self->destroy;
750 748
751sub event_update_game { 749sub event_update_game {
752 my ($self) = @_; 750 my ($self) = @_;
753 $self->SUPER::event_update_game; 751 $self->SUPER::event_update_game;
754 752
753 my $title = $self->{channel} ? $self->owner->as_string . " " . $self->opponent_string : "Game Window";
754 $self->{window}->set_title("KGS Game $title");
755 $self->{title}->set_text ($title);
756
755 $self->{user}[BLACK] = $self->{user1}; 757 $self->{user}[BLACK] = $self->{user1};
756 $self->{user}[WHITE] = $self->{user2}; 758 $self->{user}[WHITE] = $self->{user2};
757 759
758 # show board 760 # show board
759 761
760 $self->{left}->remove ($_) for $self->{left}->get_children; 762 $self->{left}->remove ($_) for $self->{left}->get_children;
761 if ($self->is_valid) { 763 if ($self->is_valid) {
762 $self->{left}->add ($self->{boardbox}); 764 $self->{left}->add ($self->{boardbox});
763 (delete $self->{challenge})->destroy if $self->{challenge}; 765 (delete $self->{challenge})->destroy if $self->{challenge};
764 } else { 766 } else {
766 } 768 }
767 $self->{left}->show_all; 769 $self->{left}->show_all;
768 770
769 # view text 771 # view text
770 772
771 $text = "\n<header>Game Update</header>"; 773 my @ga;
772
773 $text .= "\nType: " . (util::toxml $gametype{$self->type}) 774 $ga[0] = "\nType: " . (util::toxml $gametype{$self->type})
774 . " (" . (util::toxml $gameopt{$self->option}) . ")"; 775 . " (" . (util::toxml $gameopt{$self->option}) . ")";
775 $text .= "\nFlags:"; 776 $ga[1] = "\nFlags:";
776 $text .= " valid" if $self->is_valid; 777 $ga[1] .= " valid" if $self->is_valid;
777 $text .= " adjourned" if $self->is_adjourned; 778 $ga[1] .= " adjourned" if $self->is_adjourned;
778 $text .= " scored" if $self->is_scored; 779 $ga[1] .= " scored" if $self->is_scored;
779 $text .= " saved" if $self->is_saved; 780 $ga[1] .= " saved" if $self->is_saved;
780 781
781 $text .= "\nWhite: <user>" . (util::toxml $self->{user2}->as_string) . "</user>";
782 $text .= "\nBlack: <user>" . (util::toxml $self->{user1}->as_string) . "</user>";
783 $text .= "\nOwner: <user>" . (util::toxml $self->{user3}->as_string) . "</user>" if $self->{user3}->is_valid; 782 $ga[2] = "\nOwner: <user>" . (util::toxml $self->{user3}->as_string) . "</user>" if $self->{user3}->is_valid;
783
784 $ga[3] = "\nPlayers: <user>" . (util::toxml $self->{user2}->as_string) . "</user>"
785 . " vs. <user>" . (util::toxml $self->{user1}->as_string) . "</user>"
786 if $self->is_valid;
784 787
785 if ($self->is_valid) { 788 if ($self->is_valid) {
786 $text .= "\nHandicap: " . $self->{handicap}; 789 $ga[4] = "\nHandicap: " . $self->{handicap};
787 $text .= "\nKomi: " . $self->{komi}; 790 $ga[5] = "\nKomi: " . $self->{komi};
788 $text .= "\nSize: " . $self->size_string; 791 $ga[6] = "\nSize: " . $self->size_string;
789 } 792 }
790 793
791 if ($self->is_scored) { 794 if ($self->is_scored) {
792 $text .= "\nResult: " . $self->score_string; 795 $ga[7] = "\nResult: " . $self->score_string;
796 }
797
798 $text = "\n<infoblock><header>Game Update</header>";
799 for (0..7) {
800 if ($self->{gatext}[$_] ne $ga[$_]) {
801 $text .= $ga[$_];
802 }
803 }
804 $text .= "</infoblock>";
805
806 $self->{gatext} = \@ga;
793 } 807
794
795 $self->{text}->append_text ("<infoblock>$text</infoblock>"); 808 $self->{text}->append_text ($text);
796} 809}
797 810
798sub event_update_rules { 811sub event_update_rules {
799 my ($self, $rules) = @_; 812 my ($self, $rules) = @_;
800 813
801 $self->{userpanel}[$_]->configure ($self->{user}[$_], $rules) 814 $self->{userpanel}[$_]->configure ($self->{user}[$_], $rules)
802 for BLACK, WHITE; 815 for BLACK, WHITE;
816
817 sound::play 3, "gamestart";
803 818
804 my $text = "\n<header>Game Rules</header>"; 819 my $text = "\n<header>Game Rules</header>";
805 820
806 $text .= "\nRuleset: " . $ruleset{$rules->{ruleset}}; 821 $text .= "\nRuleset: " . $ruleset{$rules->{ruleset}};
807 822
824} 839}
825 840
826sub inject_resign_game { 841sub inject_resign_game {
827 my ($self, $msg) = @_; 842 my ($self, $msg) = @_;
828 843
844 sound::play 3, "resign";
845
829 $self->{text}->append_text ("\n<infoblock><header>Resign</header>" 846 $self->{text}->append_text ("\n<infoblock><header>Resign</header>"
830 . "\n<user>" 847 . "\n<user>"
831 . (util::toxml $self->{user}[$msg->{player}]->as_string) 848 . (util::toxml $self->{user}[$msg->{player}]->as_string)
832 . "</user> resigned.</infoblock>"); 849 . "</user> resigned.</infoblock>");
833} 850}

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines