X-Git-Url: https://git.nubati.net/cgi-bin/gitweb.cgi?p=e-DoKo.git;a=blobdiff_plain;f=include%2Fgame.php;h=02d6f9658c222e43e4e7de1c769382632d75b2cb;hp=eb66a987157c6bcd98ddbcf57f0ce343e7e7fcca;hb=9597b99442a783621315839880966d68a2fd460f;hpb=8550cac6f9bedbd9219d898f7b3de731bf1cb2b2 diff --git a/include/game.php b/include/game.php index eb66a98..02d6f96 100644 --- a/include/game.php +++ b/include/game.php @@ -43,7 +43,9 @@ if(!$myid) global $GAME,$RULES,$CARDS; -/* get some information from the DB */ +/************************************** + * get some information from the DB + **************************************/ $gameid = DB_get_gameid_by_hash($me); $myname = DB_get_name('hash',$me); $mystatus = DB_get_status_by_hash($me); @@ -79,6 +81,9 @@ if( $gamestatus == 'pre' ) { /* always need to use Schweinchen to figure out for example who has poverty */ $ok=1; + /* unless the gametype is set and we know that we are in poverty were schweinchen is not valid */ + if( in_array( $gametype,array('poverty','dpoverty') )) + $ok=0; } else { @@ -114,11 +119,8 @@ if($ok) */ set_gametype('normal'); -/* put everyting in a form */ -echo "
\n"; - /* handle user notes (only possible while game is running)*/ -if( $mystatus!='gameover' ) +if( $mystatus!='gameover' ) if(myisset('note')) { $note = $_REQUEST['note']; @@ -127,19 +129,21 @@ if( $mystatus!='gameover' ) DB_insert_note($note,$gameid,$myid); }; -/* make sure that we don't show the notes to the wrong person - * (e.g. other people looking at an old game) - */ -if( $mystatus != 'gameover' || - ( $mystatus == 'gameover' && - isset($_SESSION['id']) && - $myid == $_SESSION['id'])) - output_user_notes($myid,$gameid,$mystatus); - /* handle calls, output a comment to show when the call was made */ /* initialize comments */ $comment = ''; +/* get information needed to submit comment */ +$playid = DB_get_current_playid($gameid); + +/* set comment */ +if($comment != '') + DB_insert_comment($comment,$playid,$myid); +/* clear up */ +unset($comment); +/* end check for calls */ + + /* check for calls, set comment */ if(myisset('call') && $_REQUEST['call'] == '120' && can_call(120,$me)) { @@ -170,61 +174,58 @@ if(myisset('call') && $_REQUEST['call'] == '0' && can_call(0,$me)) $comment .= "Zero"; } -/* get information needed to submit comment */ -$playid = DB_get_current_playid($gameid); - -/* set comment */ -if($comment != '') - DB_insert_comment($comment,$playid,$myid); -/* clear up */ -unset($comment); -/* end check for calls */ - -/* output extra division in case this game is part of a session */ +/***************************************************************** + * output extra division in case this game is part of a session + *****************************************************************/ if($session) { echo "
\n"; - echo '
'._('Rules').': '; + + /* output rule set */ + echo "
\n "._('Rules').":\n"; switch($RULES['dullen']) { case 'none': - echo " \""._('no\n"; break; + echo " \""._('no\n"; break; case 'firstwins': - echo " \""._('ten\n"; break; + echo " \""._('ten\n"; break; case 'secondwins': - echo " \""._('second\n"; break; + echo " \""._('second\n"; break; } switch($RULES['schweinchen']) { case 'none': - echo " \""._('no\n"; break; case 'both': - echo " \""._('two\n"; break; case 'second': - echo " \"".('second\n"; break; case 'secondaftercall': - echo " \""._('second\n"; break; } switch($RULES['call']) { case '1st-own-card': - echo " \""._('1st-own-card')."\"\n"; break; + echo " \""._('1st-own-card')."\"\n"; break; case '5th-card': - echo " \""._('5th-card')."\"\n"; break; + echo " \""._('5th-card')."\"\n"; break; case '9-cards': - echo " \""._('9-cards')."\"\n"; break; + echo " \""._('9-cards')."\"\n"; break; } - echo "
\n"; - echo ' '._('10ofhearts').": {$RULES['dullen']}
\n"; - echo ' '._('schweinchen').": {$RULES['schweinchen']}
\n"; - echo ' '._('call').": {$RULES['call']}
\n"; - echo ' '._('lowtrump').": {$RULES['lowtrump']}
\n"; - echo "
\n
\n"; + echo "
\n"; + echo ' '._('10ofhearts').": {$RULES['dullen']}
\n"; + echo ' '._('schweinchen').": {$RULES['schweinchen']}
\n"; + echo ' '._('call').": {$RULES['call']}
\n"; + echo ' '._('lowtrump').": {$RULES['lowtrump']}
\n"; + echo "
\n
\n"; /* show score */ @@ -280,19 +281,40 @@ if($session) else $next = NULL; + /* check for solo, add game type to session number */ + echo " Game $session.$j"; + if($GT !='normal') + echo " ($GT)"; if(isset($_SESSION['id']) && $_SESSION['id']==$myid) { if($previous) - echo ""._('previous game')."    \n"; - echo "This is game number $j of $i in session $session.\n"; + echo "   "._('previous')." \n"; if($next) - echo "   "._('next game')." \n"; + echo "   "._('next')." \n"; } - else - echo "This is game number $j of $i in session $session."; + if($j != $i ) + echo "   last \n"; + echo "\n
\n"; } +/* the user has done something, update the timestamp. Use $myid in + * active games and check for session-id in old games (myid might be wrong in that case) + */ +if($mystatus!='gameover') + DB_update_user_timestamp($myid); + else + if(isset($_SESSION['id'])) + DB_update_user_timestamp($_SESSION['id']); + + +/****************************************************************************** + * Output tricks played, table, messages, and cards (depending on game status) + ******************************************************************************/ + +/* put everyting in a form */ +echo "\n"; + /* display the table and the names */ display_table(); @@ -306,18 +328,13 @@ display_table(); * gameover: are we revisiting a game */ -/* the user has done something, update the timestamp. Use $myid in - * active games and check for session-id in old games (myid might be wrong in that case) - */ -if($mystatus!='gameover') - DB_update_user_timestamp($myid); - else - if(isset($_SESSION['id'])) - DB_update_user_timestamp($_SESSION['id']); - switch($mystatus) { case 'start': + /**************************************** + * ask if player wants to join the game * + ****************************************/ + /* don't ask if user has autosetup set to yest */ $skip = 0; if($PREF['autosetup']=='yes') $skip = 1; @@ -326,6 +343,7 @@ switch($mystatus) { /* asks the player, if he wants to join the game */ output_check_want_to_play($me); + echo '
'; break; } else @@ -334,14 +352,13 @@ switch($mystatus) if(!$skip && $_REQUEST['in'] == 'no' ) { /* cancel the game */ - $message = "Hello, \n\n". + $email_message = "Hello, \n\n". "the game has been canceled due to the request of one of the players.\n\n"; $userids = DB_get_all_userid_by_gameid($gameid); foreach($userids as $user) { - $subject = 'Game '.DB_format_gameid($gameid).' canceled'; - mymail($user,$subject,$message); + mymail($user,$gameid,GAME_CANCELED,$email_message); } /* update game status */ @@ -358,9 +375,8 @@ switch($mystatus) DB_set_hand_status_by_hash($me,'init'); - /* check if everyone has reached this stage, send out email */ + /* check if everyone has reached this stage, set player in game-table to the next player */ $userids = DB_get_all_userid_by_gameid($gameid); - $ok = 1; foreach($userids as $user) { $userstat = DB_get_hand_status_by_userid_and_gameid($user,$gameid); @@ -368,36 +384,16 @@ switch($mystatus) { /* whos turn is it? */ DB_set_player_by_gameid($gameid,$user); - $ok = 0; break; } }; - if($ok) - { - /* all done, send out email unless this player is the startplayer */ - $startplayer = DB_get_startplayer_by_gameid($gameid); - if($mypos == $startplayer) - { - /* do nothing, go to next stage */ - } - else - { - /* email startplayer */ - /* - $hash = DB_get_hash_from_game_and_pos($gameid,$startplayer); - $who = DB_get_userid('hash',$hash); - DB_set_player_by_gameid($gameid,$who); - - $message = "It's your turn now in game ".DB_format_gameid($gameid).".\n". - "Use this link to go the game: ".$HOST.$INDEX."?action=game&me=".$hash."\n\n" ; - mymail($who,"Ready, set, go... (game ".DB_format_gameid($gameid).") ",$message); - */ - } - } } } case 'init': - /* here we ask the player if he is sick */ + /*************************** + * check if player is sick * + ***************************/ + $mycards = DB_get_hand($me); $mycards = mysort($mycards,$gametype); @@ -405,7 +401,6 @@ switch($mystatus) { /* output sickness of other playes, in case the already selected and are sitting in front of the current player */ echo "\n