X-Git-Url: https://git.nubati.net/cgi-bin/gitweb.cgi?p=e-DoKo.git;a=blobdiff_plain;f=include%2Fgame.php;h=b8963d2fc5134aac1a1d782a4d4371a82b1b5e3b;hp=bd25e78eff6a36d889e2bee2d685609c88bda4ec;hb=21973b9985f6325315721cba1c4e046fbbe3a1f0;hpb=252c638b8028a86ba8cb5e315b3f13992b6fa77d diff --git a/include/game.php b/include/game.php index bd25e78..b8963d2 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,24 @@ 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) +/* Depending on the situation we set + * cards_status (see functions.php for possible options) */ -if($mystatus!='gameover') - DB_update_user_timestamp($myid); - else - if(isset($_SESSION['id'])) - DB_update_user_timestamp($_SESSION['id']); +$cards_status = CARDS_EMPTY; + +/* Also collect message that should be displayed to the user, so that we can show + * them after showing the table. This makes the html flow more consistent and easier + * tournament change layouts, especially for smaller displays, e.g. mobile phones + */ +$messages = array(); 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 +354,7 @@ switch($mystatus) { /* asks the player, if he wants to join the game */ output_check_want_to_play($me); + $card_status = CARDS_EMPTY; break; } else @@ -334,14 +363,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 +386,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,44 +395,19 @@ 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 */ - $mycards = DB_get_hand($me); - $mycards = mysort($mycards,$gametype); - + /*************************** + * check if player is sick * + ***************************/ if(!myisset('solo','wedding','poverty','nines','lowtrump') ) { - /* output sickness of other playes, in case the already selected and are sitting in front of the current player */ + /* output sickness of other playes, in case they already selected and are sitting in front of the current player */ echo "\n\n"; /* end div trick, end li trick , end tricks*/ /* end displaying sickness */ + $mycards = DB_get_hand($me); output_check_for_sickness($me,$mycards); - echo '
'._('Your cards are').":
\n"; - foreach($mycards as $card) - display_card($card,$PREF['cardset']); - echo "
\n"; + $card_status = CARDS_SHOW; break; } @@ -447,20 +447,17 @@ switch($mystatus) if($Nsickness>1) { - echo "

You selected more than one sickness, please go back ". - "and answer the question again.

"; + $messages[] = "You selected more than one sickness, please go back ". + "and answer the question again."; - echo '
'._('Your cards are').":
\n"; - foreach($mycards as $card) - display_card($card,$PREF['cardset']); - echo "
\n"; + $card_status = CARDS_SHOW; break; } else { /* everything is ok, save what user said and proceed */ - echo "

Processing what you selected in the last step..."; + $messages[] = "Processing what you selected in the last step..."; /* check if this sickness needs to be handled first */ $gametype = DB_get_gametype_by_gameid($gameid); @@ -474,7 +471,7 @@ switch($mystatus) DB_set_solo_by_hash($me,$_REQUEST['solo']); DB_set_sickness_by_hash($me,'solo'); - echo "
Seems like you want to play a {$_REQUEST['solo']} solo. Got it.
\n"; + $messages[] = "
Seems like you want to play a {$_REQUEST['solo']} solo. Got it.
\n"; if($gametype == 'solo' && $startplayer<$mypos) {}/* do nothing, since someone else already is playing solo */ @@ -491,35 +488,34 @@ switch($mystatus) else if($_REQUEST['wedding'] == 'yes') { /* silent solo is set further down */ - echo _("Ok, you don't want to play a silent solo...wedding was chosen.")."
\n"; + $messages[] = _("Ok, you don't want to play a silent solo...wedding was chosen.")."
\n"; DB_set_sickness_by_hash($me,'wedding'); } else if($_REQUEST['poverty'] == 'yes') { - echo _("Don't think you can win with just a few trump...? Ok, poverty chosen.")."
\n"; + $messages[] = _("Don't think you can win with just a few trump...? Ok, poverty chosen.")."
\n"; DB_set_sickness_by_hash($me,'poverty'); } else if($_REQUEST['nines'] == 'yes') { - echo _("What? You just don't want to play a game because you have a few nines? Well, if no one". + $messages[] = _("What? You just don't want to play a game because you have a few nines? Well, if no one". " is playing solo, this game will be canceled.")."
\n"; DB_set_sickness_by_hash($me,'nines'); } else if($_REQUEST['lowtrump'] == 'yes') { if($RULES['lowtrump']=='cancel') - echo _("What? You just don't want to play a game because you have low trump? Well, if no one". + $messages[] = _("What? You just don't want to play a game because you have low trump? Well, if no one". " is playing solo, this game will be canceled.")."
\n"; else - echo _("Don't think you can win with low trumps...? Ok, poverty chosen.")."
.
\n"; + $messages[] = _("Don't think you can win with low trumps...? Ok, poverty chosen.")."
.
\n"; DB_set_sickness_by_hash($me,'lowtrump'); } - echo "

\n"; - /* move on to the next stage*/ DB_set_hand_status_by_hash($me,'check'); + $mystatus='check'; }; }; @@ -528,12 +524,8 @@ switch($mystatus) * this can therefore only be handled once all players finished the last stage */ - $mycards = DB_get_hand($me); - $mycards = mysort($mycards,$gametype); - - /* output sickness of other playes, in case the already selected and are sitting in front of the current player */ + /* output sickness of other playes, in case they already selected and are sitting in front of the current player */ echo "\n\n"; /* end div trick, end li trick , end tricks*/ /* end displaying sickness */ - echo "
\n"; - echo '

'._('Checking if someone else selected solo, nines, wedding or poverty.').'

'; + $messages[] = _('Checking if someone else selected solo, nines, wedding or poverty.'); /* check if everyone has reached this stage */ $userids = DB_get_all_userid_by_gameid($gameid); @@ -573,10 +564,10 @@ switch($mystatus) if(!$ok) { - echo '

'._('This step can only be handled after everyone finished the last step. '. + $messages[] = _('This step can only be handled after everyone finished the last step. '. 'Seems like this is not the case, so you need to wait a bit... '. 'you will get an email once that is the case, please use the link in '. - 'that email to continue the game.').'

'; + 'that email to continue the game.'); /* display cards, if player was just at the init-phase he will still see the cards from there * we can put this one here, since the last player to finish the init state won't get here and @@ -584,13 +575,8 @@ switch($mystatus) */ if($mystatus=='check') { - /* show cards */ - echo '
'._('Your cards are').":
\n"; - foreach($mycards as $card) - display_card($card,$PREF['cardset']); - echo "
\n"; + $card_status = CARDS_SHOW; } - break; } else { @@ -598,7 +584,7 @@ switch($mystatus) * are playing, in case there are any solos this already * will have the correct information in it */ - echo '

'._('Ok, everyone is done... figuring out what kind of game we are playing.').'

'; + $messages[] = _('Ok, everyone is done... figuring out what kind of game we are playing.'); $gametype = DB_get_gametype_by_gameid($gameid); $startplayer = DB_get_startplayer_by_gameid($gameid); @@ -636,7 +622,7 @@ switch($mystatus) /* cancel game */ if($cancelsick == 'nines') { - $message = "The game has been canceled because ".DB_get_name('userid',$cancel). + $email_message = "The game has been canceled because ".DB_get_name('userid',$cancel). " has five or more nines and nobody is playing solo.\n\n". "To redeal either start a new game or, in case the game was part of a tournament,\n". "go to the last game and use the link at the bottom of the page to redeal.\n\n"; @@ -644,12 +630,12 @@ switch($mystatus) /* update game status */ cancel_game('nines',$gameid); - echo "

The game has been canceled because ".DB_get_name('userid',$cancel). - " has five or more nines and nobody is playing solo.

\n"; + $messages[] = "The game has been canceled because ".DB_get_name('userid',$cancel). + " has five or more nines and nobody is playing solo."; } else if ($cancelsick == 'lowtrump') { - $message = "The game has been canceled because ".DB_get_name('userid',$cancel). + $email_message = "The game has been canceled because ".DB_get_name('userid',$cancel). " has low trump and nobody is playing solo.\n\n". "To redeal either start a new game or, in case the game was part of a tournament,\n". "go to the last game and use the link at the bottom of the page to redeal.\n\n"; @@ -657,18 +643,16 @@ switch($mystatus) /* update game status */ cancel_game('lowtrump',$gameid); - echo "

The game has been canceled because ".DB_get_name('userid',$cancel). - " has low trump and nobody is playing solo.

\n"; + $messages[] = "The game has been canceled because ".DB_get_name('userid',$cancel). + " has low trump and nobody is playing solo."; }; $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); } - echo "\n"; /* end div message */ break; } else if($poverty==1) /* one person has poverty */ @@ -712,7 +696,7 @@ switch($mystatus) $gametype = 'wedding'; }; /* now the gametype is set correctly in the database */ - echo '

'._('Got it').' :)

'; + $messages[] = _('Got it').' :)'; /* loop over all players, set re/contra if possible and start the game if possible */ $userids = DB_get_all_userid_by_gameid($gameid); @@ -800,14 +784,13 @@ switch($mystatus) if(DB_get_email_pref_by_hash($hash)!='emailaddict') { /* email startplayer */ - $message = "It's your turn now in game ".DB_format_gameid($gameid).".\n". + $email_message = "It's your turn now in game ".DB_format_gameid($gameid).".\n". "Use this link to play a card: ".$HOST.$INDEX."?action=game&me=".$hash."\n\n" ; - $subject = 'Ready, set, go... (game '.DB_format_gameid($gameid).')'; - mymail($who,$subject,$message); + mymail($who,$gameid,GAME_READY,$email_message); } } else - echo "Please, start the game.
\n"; + $messages[] = "Please, start the game.
\n"; } else { @@ -817,7 +800,7 @@ switch($mystatus) $whoid = DB_get_userid('gameid-position',$gameid,$who); if($whoid==$myid) - echo "Please, start the game.
start the game.
\n"; - break; + $card_status = CARDS_SHOW; } + break; case 'poverty': /* user only gets here in a poverty game, several things have to be handled here: @@ -875,16 +857,11 @@ switch($mystatus) }; } - /* update hand */ - $mycards = DB_get_hand($me); - $mycards = mysort($mycards,$gametype); - /* output pre-game trick in case user reloads, * only needs to be done when a team has been formed */ if($myparty=='re' || $myparty=='contra') { echo "\n