From 0dd96314cb0fc3d40502d87f354c6fd61f35a3cd Mon Sep 17 00:00:00 2001 From: arun Date: Thu, 8 Feb 2007 19:19:11 +0000 Subject: * rewrote checking for sickness, the player now sees a nice summary before getting to the table... * wedding is now announced * for solo and normal games, re and contra are assigned correctly * the score for re and contra is computed at the end * used one variable $CARDS instead of several global ones e.g. $CARDS["trump"] instead of $TRUMP --- index.php | 149 ++++++++++++++++++++++++++++++++++++++++++++++++++++---------- 1 file changed, 127 insertions(+), 22 deletions(-) (limited to 'index.php') diff --git a/index.php b/index.php index bd5702e..eded836 100644 --- a/index.php +++ b/index.php @@ -328,19 +328,20 @@ else if(myisset("me")) else if($_REQUEST["wedding"] == "yes") { /* TODO: add silent solo somewhere*/ - echo "wedding was chosen, can't handle it at the moment, you need to send out". - " an email by hand to the other players
\n"; + echo "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 "poverty was chosen. Unfortunately this is not implemented yet,". - " so you need to play a normal game... sorry
\n"; + echo "So you got poverty. You might as well have said nothing, since this is not implemented yet,". + " so you need to play a normal game...to make it a bit harder, I'll tell the other people that". + " you only have a few trump... should make the game more interesting (although perhaps not for you:))
\n"; DB_set_sickness_by_hash($me,"poverty"); } else if($_REQUEST["nines"] == "yes") { - echo "Nines was chosen. If no is playing solo, this game will be canceled.
\n"; + echo "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"); } } @@ -356,7 +357,7 @@ else if(myisset("me")) * set that one in the Game table * tell people about it. */ - echo "
checking if someone else selected solo or nines... wedding and poverty not handled at the moment
". + echo "
checking if someone else selected solo or nines... poverty not handled at the moment
". " Please click here to finish the setup.
"; /* check if everyone has reached this stage */ @@ -371,7 +372,7 @@ else if(myisset("me")) if($ok) { - echo "Everyone has finished checking their cards, the game can now start...
"; + echo "Everyone has finished checking their cards, let's see what they said...
"; /* check what kind of game we are playing */ $gametype = DB_get_gametype_by_gameid($gameid); $startplayer = DB_get_startplayer_by_gameid($gameid); @@ -384,9 +385,9 @@ else if(myisset("me")) $nines = $user; /* gamestatus == normal, => cancel game */ - if($nines && $gamestatus == "normal") + if($nines && $gametype != "solo") { - /* TODO: set game type to nines to be able to keep statistics? */ + /* TODO: should we keep statistics of this? */ $message = "Hello, \n\n". "the game has been canceled because ".DB_get_name_by_userid($nines)." has five or more nines.\n"; @@ -399,7 +400,10 @@ else if(myisset("me")) /* delete everything from the dB */ DB_cancel_game($me); + exit(); } + + /* check for different sickness and just output a general info */ /* check players for poverty */ $poverty = 0; @@ -412,21 +416,19 @@ else if(myisset("me")) echo "$name has a Vorbehalt.
"; } } - /* if gamestatus == normal, set poverty or dpovert (in case two people have poverty) */ - + /* check players for wedding */ $wedding = 0; foreach($userids as $user) { if(DB_get_sickness_by_userid_and_gameid($user,$gameid) == 'wedding') { - $wedding++; + $wedding=$user; $name = DB_get_name_by_userid($user); echo "$name has a Vorbehalt.
" ; } - } - /* if gamestatus == normal, set wedding */ - + }; + /* check for solo, output vorbehalt */ $solo = 0; foreach($userids as $user) @@ -439,8 +441,91 @@ else if(myisset("me")) } } - /* finished the setup, go to next stage */ - DB_set_hand_status_by_hash($me,'play'); + /* now check which sickness comes first and set the gametype to it */ + + /* if gamestatus == normal, set poverty or dpovert (in case two people have poverty) */ + if($poverty>0 && $gametype == "normal") + { + if($poverty==1) + { + DB_set_gametype_by_gameid($gameid,"poverty"); + $gametype = "poverty"; + } + else if($poverty==2) + { + DB_set_gametype_by_gameid($gameid,"dpoverty"); + $gametype = "dpoverty"; + }; + }; + /* if gamestatus == normal, set wedding */ + if($wedding> 0 && $gametype == "normal") + { + DB_set_gametype_by_gameid($gameid,"wedding"); + $gametype = "wedding"; + }; + + /* now the gametype is set correctly (shouldn't matter that this is calculated for every user) + * output what kind of game we have */ + + echo "
\n"; + + $poverty=0; + foreach($userids as $user) + { + $name = DB_get_name_by_userid($user); + $usersick = DB_get_sickness_by_userid_and_gameid($user,$gameid); + if($usersick=="poverty") + $poverty++; + if($usersick) + echo "$name has $usersick
"; + if($usersick == "wedding" && $gametype =="wedding") + break; + if($usersick == "poverty" && $gametype =="poverty") + break; + if($usersick == "poverty" && $gametype =="dpoverty" && $poverty==2) + break; + if($usersick == "solo" && $gametype =="solo") + break; + }; + echo "
\n"; + + /* check for Schweinchen (cards 21,22) */ + if($RULES["schweinchen"]=="both") + { + set_gametype($gametype); + echo "TODO: check if one user has both foxes and output here "; + } + + /* finished the setup, go to next stage unless there is a case of poverty*/ + switch($gametype) + { + case "solo": + /* are we the solo player? set us to re, else set us to contra */ + $pos = DB_get_pos_by_hash($me); + if($pos == $startplayer) + DB_set_party_by_hash($me,"re"); + else + DB_set_party_by_hash($me,"contra"); + DB_set_hand_status_by_hash($me,'play'); + break; + case "wedding": + echo "Don't know who will be Re and Contra, you need to figure that out at the end of the game yourself
\n"; + DB_set_hand_status_by_hash($me,'play'); + break; + case "normal": + $hand = DB_get_all_hand($me); + + if(in_array('3',$hand)||in_array('4',$hand)) + DB_set_party_by_hash($me,"re"); + else + DB_set_party_by_hash($me,"contra"); + DB_set_hand_status_by_hash($me,'play'); + break; + case "poverty": + case "dpoverty": + echo "TODO: handle poverty here"; + DB_set_hand_status_by_hash($me,'play'); + }; } else { @@ -467,7 +552,8 @@ else if(myisset("me")) */ /* figure out what kind of game we are playing, - * set the global variables $TRUMP,$DIAMONDS,$HEARTS,$CLUBS,$SPADES + * set the global variables $CARDS["trump"],$CARDS["diamonds"],$CARDS["hearts"], + * $CARDS["clubs"],$CARDS["spades"],$CARDS["foxes"] * accordingly */ @@ -717,15 +803,26 @@ else if(myisset("me")) echo "ERROR during scoring"; /* email all players */ - $result = mysql_query("SELECT fullname, SUM(score) FROM Score". + /* individual score */ + $result = mysql_query("SELECT fullname, SUM(score), Hand.party FROM Score". " LEFT JOIN Hand ON Hand.id=hand_id". " LEFT JOIN User ON Hand.user_id=User.id". " WHERE Hand.game_id=$gameid". " GROUP BY fullname" ); $message = "The game is over. Thanks for playing :)\n"; + while( $r = mysql_fetch_array($result,MYSQL_NUM)) + $message .= " FINAL SCORE: ".$r[0]."(".$r[2].") ".$r[1]."\n"; + $message .= "\nIf your not in the list above your score is zero...\n\n"; + + $result = mysql_query("SELECT Hand.party, SUM(score) FROM Score". + " LEFT JOIN Hand ON Hand.id=hand_id". + " LEFT JOIN User ON Hand.user_id=User.id". + " WHERE Hand.game_id=$gameid". + " GROUP BY Hand.party" ); + $message .= "\n"; while( $r = mysql_fetch_array($result,MYSQL_NUM)) $message .= " FINAL SCORE: ".$r[0]." ".$r[1]."\n"; - $message .= "\nIf your not in the list above your score is zero...\n"; + foreach($userids as $user) { $To = DB_get_email_by_userid($user); @@ -847,14 +944,22 @@ else if(myisset("me")) { echo "the game is over now...
\n"; - $result = mysql_query("SELECT fullname, SUM(score) FROM Score". + $result = mysql_query("SELECT fullname, SUM(score), Hand.party FROM Score". " LEFT JOIN Hand ON Hand.id=hand_id". " LEFT JOIN User ON Hand.user_id=User.id". " WHERE Hand.game_id=$gameid". " GROUP BY fullname" ); while( $r = mysql_fetch_array($result,MYSQL_NUM)) - echo " FINAL SCORE: ".$r[0]." ".$r[1]."
"; + echo " FINAL SCORE: ".$r[0]."(".$r[2].") ".$r[1]."
"; + $result = mysql_query("SELECT Hand.party, SUM(score) FROM Score". + " LEFT JOIN Hand ON Hand.id=hand_id". + " LEFT JOIN User ON Hand.user_id=User.id". + " WHERE Hand.game_id=$gameid". + " GROUP BY Hand.party" ); + while( $r = mysql_fetch_array($result,MYSQL_NUM)) + echo " FINAL SCORE: ".$r[0]." ".$r[1]."
\n"; + $session = DB_get_session_by_gameid($gameid); $result = mysql_query("SELECT id,create_date FROM Game". -- cgit v1.2.3-18-g5258