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.51 by pcg, Tue Jun 10 10:04:36 2003 UTC vs.
Revision 1.54 by pcg, Thu Jun 12 22:10:04 2003 UTC

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

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines