FEATURE: added solo and now you also can only play cards that are valid on a trick
authorarun <arun@nubati.net>
Mon, 8 Jan 2007 09:16:20 +0000 (09:16 +0000)
committerarun <arun>
Mon, 8 Jan 2007 09:16:20 +0000 (09:16 +0000)
create_database.sql
db.php
functions.php
index.php
output.php

index 66c0cc330ee787591373066c989c7cdf655bd217..88c41d9d41fe81498e76132a2b94d892363cb630 100644 (file)
@@ -70,8 +70,9 @@ CREATE TABLE `Game` (
   `mod_date` timestamp NOT NULL default CURRENT_TIMESTAMP on update CURRENT_TIMESTAMP,
   `create_date` timestamp NOT NULL default '0000-00-00 00:00:00',
   `randomnumbers` varchar(136) default NULL,
-  `type` enum('solo','wedding','poverty','dpoverty') default NULL,
+  `type` enum('normal','solo','wedding','poverty','dpoverty') default NULL,
   `solo` enum('trumpless','jack','queen','trump','club','spade','heart','silent') default NULL,
+  `startplayer` tinyint(4) default '1', 
   `status` enum('pre','play','gameover') default NULL,
   `followup_of` int(11) default NULL,
   `id` int(11) NOT NULL auto_increment,
diff --git a/db.php b/db.php
index 254c460ae538f541cab5f56afdaa9873ddd7aed8..6da3bd989a6ac996541d0551e0314317a6226be3 100644 (file)
--- a/db.php
+++ b/db.php
@@ -283,12 +283,18 @@ function DB_get_cards_by_trick($id)
 }
 
 
-function DB_set_solo_by_hash($me,$solo)
+function DB_set_solo_by_hash($hash,$solo)
 {
   mysql_query("UPDATE Hand SET solo=".DB_quote_smart($solo)." WHERE hash=".DB_quote_smart($hash));
   return;
 }
 
+function DB_set_solo_by_gameid($id,$solo)
+{
+  mysql_query("UPDATE Game SET solo=".DB_quote_smart($solo)." WHERE id=".DB_quote_smart($id));
+  return;
+}
+
 function DB_set_sickness_by_hash($hash,$sickness)
 {
   mysql_query("UPDATE Hand SET sickness=".DB_quote_smart($sickness)." WHERE hash=".DB_quote_smart($hash));
@@ -420,4 +426,51 @@ function DB_insert_comment($comment,$playid,$userid)
   mysql_query("INSERT INTO Comment VALUES (NULL,NULL,NULL,$userid,$playid, ".DB_quote_smart($comment).")");
   return;
 }
+
+function DB_get_gametype_by_gameid($id)
+{
+  $result = mysql_query("SELECT type FROM Game WHERE id=".DB_quote_smart($id));
+  $r      = mysql_fetch_array($result,MYSQL_NUM);
+  
+  if($r)
+    return $r[0]."";
+  else
+    return "";
+}
+
+function DB_set_gametype_by_gameid($id,$p)
+{
+  mysql_query("UPDATE Game SET type='".$p."' WHERE id=".DB_quote_smart($id));
+  return;
+}
+
+function DB_get_solo_by_gameid($id)
+{
+  $result = mysql_query("SELECT solo FROM Game WHERE id=".DB_quote_smart($id));
+  $r      = mysql_fetch_array($result,MYSQL_NUM);
+  
+  if($r)
+    return $r[0]."";
+  else
+    return "";
+}
+
+
+function DB_get_startplayer_by_gameid($id)
+{
+  $result = mysql_query("SELECT startplayer FROM Game WHERE id=".DB_quote_smart($id));
+  $r      = mysql_fetch_array($result,MYSQL_NUM);
+  
+  if($r)
+    return $r[0];
+  else
+    return 0;
+}
+
+function DB_set_startplayer_by_gameid($id,$p)
+{
+  mysql_query("UPDATE Game SET startplayer='".$p."' WHERE id=".DB_quote_smart($id));
+  return;
+}
+
 ?>
\ No newline at end of file
index a6ee160ec805c5598ad038fabb6da27c48bfdb6c..2077d0019ac98ce2287c41a861726b4b6ce262e8 100644 (file)
@@ -49,69 +49,35 @@ function pos_array($c,$arr)
   return $ret;
 }
 
-function is_trump($c,$game
+function is_trump($c) 
 { 
-  switch($game)
-    {
-    case "queen":
-      if(in_array($c,array('3','4','5','6','7','8','9','10')))
-       return 1;
-      else 
-       return 0;
-      break;
-    case "normal":
-      return (($c<27) ? 1:0);
-      break;
-    }
+  global $TRUMP;
+
+  if(in_array($c,$TRUMP))
+    return 1;
+  else 
+    return 0;
 }
 
-function is_same_suite($c1,$c2,$game
+function is_same_suite($c1,$c2) 
 {
-  switch($game)
-    {
-    case "queen":
-      /* clubs */
-      if(in_array($c1,array('11','12','27','28','29','30','31','32','33','34')) &&
-        in_array($c2,array('11','12','27','28','29','30','31','32','33','34')) )
-       return 1;
-      /* spade */
-      if(in_array($c1,array('13','14','35','36','37','38','39','40','41','42')) &&
-        in_array($c2,array('13','14','35','36','37','38','39','40','41','42')) )
-       return 1;
-      /* heart */
-      if(in_array($c1,array( '1', '2','15','16','43','44','45','46','47','48')) &&
-        in_array($c2,array( '1', '2','15','16','43','44','45','46','47','48')) )
-       return 1;
-      /* diamonds */
-      if(in_array($c1,array('17','18','19','20','21','22','23','24','25','26')) &&
-        in_array($c2,array('17','18','19','20','21','22','23','24','25','26')) )
-       return 1;
-      
-      return 0;
-      break;
-    case "normal":
-      /* clubs */
-      if(in_array($c1,array('27','28','29','30','31','32','33','34')) &&
-        in_array($c2,array('27','28','29','30','31','32','33','34')) )
-       return 1;
-      /* spade */
-      if(in_array($c1,array('35','36','37','38','39','40','41','42')) &&
-        in_array($c2,array('35','36','37','38','39','40','41','42')) )
-       return 1;
-      /* heart */
-      if(in_array($c1,array('43','44','45','46','47','48')) &&
-        in_array($c2,array('43','44','45','46','47','48')) )
-       return 1;
-      
-      return 0;
-      break;
-    }
+  global $TRUMP,$DIAMONDS,$HEARTS,$CLUBS,$SPADES;
+  
+  if(in_array($c1,$TRUMP   ) && in_array($c2,$TRUMP   ) ) return 1;
+  if(in_array($c1,$CLUBS   ) && in_array($c2,$CLUBS   ) ) return 1;
+  if(in_array($c1,$HEARTS  ) && in_array($c2,$HEARTS  ) ) return 1;
+  if(in_array($c1,$SPADES  ) && in_array($c2,$SPADES  ) ) return 1;
+  if(in_array($c1,$DIAMONDS) && in_array($c2,$DIAMONDS) ) return 1;
+  
+  return 0;
 }
 
 function compare_cards($a,$b,$game)
 {
   /* if "a" is higher than "b" return 1, else 0, "a" being the card first played */
 
+  global $TRUMP,$DIAMONDS,$HEARTS,$CLUBS,$SPADES;
+
   /* first map all cards to the odd number, 
    * this insure that the first card wins the trick 
    * if they are the same card
@@ -120,93 +86,65 @@ function compare_cards($a,$b,$game)
     $a--;
   if( $b/2 - (int)($b/2) != 0.5)
     $b--;
-  
+
+  /* some special cases */
   switch($game)
     {
-    case "trumpless":
-      break;
-    case "jack":
-      break;
-    case "queen":
-      if(is_trump($a,$game) && is_trump($b,$game) && $a<=$b)
-       return 1;
-      else if(is_trump($a,$game) && is_trump($b,$game) )
-       return 0;
-      else 
-       { /*$a is not a trump */
-         if(is_trump($b,$game))
-           return 0;
-         else
-           { /* both no trump */
-             /* both clubs? */
-             $posA = pos_array($a,array('27','28','29','30','31','32','11','12','33','34'));
-             $posB = pos_array($b,array('27','28','29','30','31','32','11','12','33','34'));
-             if($posA && $posB)
-               if($posA <= $posB)
-                 return 1;
-               else
-                 return 0;
-             /* both spades? */
-             $posA = pos_array($a,array('35','36','37','38','39','40','13','14','41','42'));
-             $posB = pos_array($b,array('35','36','37','38','39','40','13','14','41','42'));
-             if($posA && $posB)
-               if($posA <= $posB)
-                 return 1;
-               else
-                 return 0;
-             /* both hearts? */
-             $posA = pos_array($a,array('43','44','15','16','45','46', '1', '2','47','48'));
-             $posB = pos_array($b,array('43','44','15','16','45','46', '1', '2','47','48'));
-             if($posA && $posB)
-               if($posA <= $posB)
-                 return 1;
-               else
-                 return 0;
-             /* both diamonds? */
-             $posA = pos_array($a,array('19','20','21','22','23','24','17','18','25','26'));
-             $posB = pos_array($b,array('19','20','21','22','23','24','17','18','25','26'));
-             if($posA && $posB)
-               if($posA <= $posB)
-                 return 1;
-               else
-                 return 0;
-
-             /* not the same suit and no trump: a wins */
-             return 1;
-           }     
-       }
-      break;
-    case "trump":
-      break;
-    case "club":
-      break;
-    case "spade":
-      break;
-    case "heart":
-      break;
     case "normal":
       if($a==1 && $b==1) /* both 10 of hearts */
        return 0;        /* second one wins. TODO should be able to set this at the start of a new game */
-      if(is_trump($a,$game) && $a<=$b)
-       return 1;
-      else if(is_trump($a,$game))
+    }
+  
+  if(is_trump($a) && is_trump($b) && $a<=$b)
+    return 1;
+  else if(is_trump($a) && is_trump($b) )
+    return 0;
+  else 
+    { /*$a is not a trump */
+      if(is_trump($b))
        return 0;
-      else 
-       { /*$a is not a trump */
-         if(is_trump($b,$game))
-           return 0;
-         else
-           {
-             if(is_same_suite($a,$b,$game))
-               if($a<=$b)
-                 return 1;
-               else
-                 return 0;
-             
-             /* not the same suit and no trump: a wins */
+      else
+       { /* both no trump */
+
+         /* both clubs? */
+         $posA = pos_array($a,$CLUBS);
+         $posB = pos_array($b,$CLUBS);
+         if($posA && $posB)
+           if($posA <= $posB)
              return 1;
-           }     
-       }
+           else
+             return 0;
+
+         /* both spades? */
+         $posA = pos_array($a,$SPADES);
+         $posB = pos_array($b,$SPADES);
+         if($posA && $posB)
+           if($posA <= $posB)
+             return 1;
+           else
+             return 0;
+
+         /* both hearts? */
+         $posA = pos_array($a,$HEARTS);
+         $posB = pos_array($b,$HEARTS);
+         if($posA && $posB)
+           if($posA <= $posB)
+             return 1;
+           else
+             return 0;
+
+         /* both diamonds? */
+         $posA = pos_array($a,$DIAMONDS);
+         $posB = pos_array($b,$DIAMONDS);
+         if($posA && $posB)
+           if($posA <= $posB)
+             return 1;
+           else
+             return 0;
+         
+         /* not the same suit and no trump: a wins */
+         return 1;
+       }         
     }
 } 
 
@@ -219,12 +157,25 @@ function get_winner($p,$mode)
   $c4 = $p[4];
 
   /* find out who won */
+
+  /* first card is better than all the rest */
   if( compare_cards($c1,$c2,$mode) && compare_cards($c1,$c3,$mode) && compare_cards($c1,$c4,$mode) )
-    return 1;
+    return 1; 
+
+  /* second card is better than first and better than the rest */
   if( !compare_cards($c1,$c2,$mode) && compare_cards($c2,$c3,$mode) && compare_cards($c2,$c4,$mode) )
     return 2;
-  if( !compare_cards($c1,$c3,$mode) && !compare_cards($c2,$c3,$mode) && compare_cards($c3,$c4,$mode) )
-    return 3;
+
+  /* third card is better than first card and better than last */
+  if( !compare_cards($c1,$c3,$mode) &&  compare_cards($c3,$c4,$mode) )
+    /* if second card is better than first, third card needs to be even better */
+    if( !compare_cards($c1,$c2,$mode) && !compare_cards($c2,$c3,$mode) )
+      return 3;
+    /* second is worse than first, e.g. not following suite */
+    else if (compare_cards($c1,$c2,$mode) )
+      return 3;
+
+  /* non of the above */
   return 4;
 }
 
@@ -246,7 +197,7 @@ function count_nines($cards)
 function check_wedding($cards)
 {
 
-  if( in_array("3",$cards) && in_array("2",$cards) )
+  if( in_array("3",$cards) && in_array("4",$cards) )
     return 1;
 
   return 0;
@@ -461,4 +412,117 @@ function return_timezone($offset)
   return $zone;
 }
 
+function have_suit($cards,$c)
+{
+  global $TRUMP,$DIAMONDS,$HEARTS,$CLUBS,$SPADES;
+  $suit = array();
+
+  if(in_array($c,$TRUMP))
+    $suit = $TRUMP;
+  else if(in_array($c,$CLUBS))
+    $suit = $CLUBS;
+  else if(in_array($c,$SPADES))
+    $suit = $SPADES;
+  else if(in_array($c,$HEARTS))
+    $suit = $HEARTS;
+  else if(in_array($c,$DIAMONDS))
+    $suit = $DIAMONDS;
+
+  foreach($cards as $card)
+    {
+      if(in_array($card,$suit))
+       return 1;
+    }
+
+  return 0;
+}
+
+function same_type($card,$c)
+{
+  global $TRUMP,$DIAMONDS,$HEARTS,$CLUBS,$SPADES;
+  $suit = "";
+
+  /* figure out what kind of card c is */
+  if(in_array($c,$TRUMP))
+    $suit = $TRUMP;
+  else if(in_array($c,$CLUBS))
+    $suit = $CLUBS;
+  else if(in_array($c,$SPADES))
+    $suit = $SPADES;
+  else if(in_array($c,$HEARTS))
+    $suit = $HEARTS;
+  else if(in_array($c,$DIAMONDS))
+    $suit = $DIAMONDS;
+
+  /* card is the same suid return 1 */ 
+  if(in_array($card,$suit))
+    return 1;
+  
+  return 0;
+}
+
+function set_gametype($gametype)
+{
+  global $TRUMP,$DIAMONDS,$HEARTS,$CLUBS,$SPADES;
+
+  switch($gametype)
+    {
+    case "normal":
+    case "trump":
+    case "silent":
+      $TRUMP    = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16', 
+                        '17','18','19','20','21','22','23','24','25','26');
+      $DIAMONDS = array();
+      $CLUBS    = array('27','28','29','30','31','32','33','34');
+      $SPADES   = array('35','36','37','38','39','40','41','42');
+      $HEARTS   = array('43','44','45','46','47','48');
+      break;
+    case "queen":
+      $TRUMP    = array('3','4','5','6','7','8','9','10');
+      $CLUBS    = array('27','28','29','30','31','32','11','12','33','34');
+      $SPADES   = array('35','36','37','38','39','40','13','14','41','42');
+      $HEARTS   = array('43','44', '1', '2','45','46','15','16','47','48');
+      $DIAMONDS = array('19','20','21','22','23','24','17','18','25','26');
+      break;
+    case "jack":
+      $TRUMP    = array('11','12','13','14','15','16','17','18');
+      $CLUBS    = array('27','28','29','30','31','32','3', '4','33','34');
+      $SPADES   = array('35','36','37','38','39','40','5', '6','41','42');
+      $HEARTS   = array('43','44', '1', '2','45','46','7', '8','47','48');
+      $DIAMONDS = array('19','20','21','22','23','24','9','10','25','26');
+      break;
+    case "trumpless":
+      $TRUMP    = array();
+      $CLUBS    = array('27','28','29','30','31','32','3', '4','11','12','33','34');
+      $SPADES   = array('35','36','37','38','39','40','5', '6','13','14','41','42');
+      $HEARTS   = array('43','44', '1', '2','45','46','7', '8','15','16','47','48');
+      $DIAMONDS = array('19','20','21','22','23','24','9','10','17','18','25','26');
+      break;
+    case "club":
+      $TRUMP    = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16', 
+                        '17','18','27','28','29','30','31','32','33','34');
+      $CLUBS    = array();
+      $SPADES   = array('35','36','37','38','39','40','41','42');
+      $HEARTS   = array('43','44','45','46','47','48');
+      $DIAMONDS = array('19','20','21','22','23','24','25','26');
+      break;
+    case "spade":
+      $TRUMP    = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16', 
+                        '17','18','35','36','37','38','39','40','41','42');
+      $CLUBS    = array('27','28','29','30','31','32','33','34');
+      $SPADES   = array();
+      $HEARTS   = array('43','44','45','46','47','48');
+      $DIAMONDS = array('19','20','21','22','23','24','25','26');
+      break;
+    case "heart":
+      $TRUMP    = array('1','2','3','4','5','6','7','8','9','10','11','12','13','14','15','16', 
+                        '17','18','43','44','45','46','47','48');
+      $CLUBS    = array('27','28','29','30','31','32','33','34');
+      $SPADES   = array('35','36','37','38','39','40','41','42');
+      $HEARTS   = array();
+      $DIAMONDS = array('19','20','21','22','23','24','25','26');
+      break;
+    }
+}
+
 ?>
\ No newline at end of file
index 550144f0805a5d31d898d4ba8b267dbc84ab1c03..f8c7a3aca50657d605278ee86c32b9eb644bf031 100644 (file)
--- a/index.php
+++ b/index.php
@@ -7,7 +7,6 @@ include_once("db.php");          /* database only */
 include_once("functions.php");   /* the rest */
 
 DB_open();
-
 output_header();
 
 /* check if we want to start a new game */
@@ -47,10 +46,10 @@ else if( myisset("PlayerA", "PlayerB","PlayerC","PlayerD" ))
     if(myisset("followup") )
       {
        $followup= $_REQUEST["followup"];
-       mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', NULL, NULL,'pre','$followup' ,NULL)");
+       mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', 'normal', NULL,'1','pre','$followup' ,NULL)");
       }
     else
-      mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', NULL, NULL,'pre', NULL ,NULL)");
+      mysql_query("INSERT INTO Game VALUES (NULL, NULL, '$randomNRstring', 'normal', NULL,'1','pre', NULL ,NULL)");
     $game_id = mysql_insert_id();
     
     /* create hash */
@@ -127,6 +126,7 @@ else if(myisset("me"))
     $gameid   = DB_get_gameid_by_hash($me);
     $myname   = DB_get_name_by_hash($me);
     $mystatus = DB_get_status_by_hash($me);
+    $mypos    = DB_get_pos_by_hash($me);
     
     switch($mystatus)
       {
@@ -177,8 +177,8 @@ else if(myisset("me"))
        break;
        
       case 'check':
-       echo "no checking at the moment... you need to play a normal game.".
-         " At the moment you need to reload this page to finish the setup.";
+       echo "checking for solo...<br /> if you have a wedding or poverty you need to play a normal game,sorry...<br />".
+         " At the moment you need to reload this page to finish the setup.<br />";
        if(!myisset("solo","wedding","poverty","nines") )
          {
            /* all these variables have a pre-selected default,
@@ -188,13 +188,28 @@ else if(myisset("me"))
          }
        else
          {
+           /* check if this sickness needs to be handled first */
+           $gametype    = DB_get_gametype_by_gameid($gameid);
+           $startplayer = DB_get_startplayer_by_gameid($gameid);
+
            if( $_REQUEST["solo"]!="No")
              {
                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";
+               
+               if($gametype == "solo" && $startplayer<$mypos)
+                 {}/* do nothing */
+               else
+                 {
+                   DB_set_gametype_by_gameid($gameid,"solo");
+                   DB_set_startplayer_by_gameid($gameid,$mypos);
+                   DB_set_solo_by_gameid($gameid,$_REQUEST["solo"]);
+                 };
              }
            else if($_REQUEST["wedding"] == "yes")
              {
+               /* TODO: add silent solo somewhere*/
                echo "wedding was chosen<br />\n";
                DB_set_sickness_by_hash($me,"wedding");
              }
@@ -209,14 +224,14 @@ else if(myisset("me"))
                 DB_set_sickness_by_hash($me,"nines");
              }
          }
+
        DB_set_hand_status_by_hash($me,'poverty');
-       
+
        /* check all players and set game to final result, e.g. solo, wedding, povert, redeal */
-       
-       /* reset solo, etc from players who did say something, but it didn't matter? */
+
        break;
       case 'poverty':
-       /* here we need to check if there is a solo or some other form o sickness.
+       /* here we need to check if there is a solo or some other form of sickness.
         * If so, which one counts
         * set that one in the Game table, delete other ones form Hand table 
         * tell people about it.
@@ -246,6 +261,24 @@ else if(myisset("me"))
         * in case of 'play' there is a break later that skips the last part
         */
 
+       /* figure out what kind of game we are playing, 
+        * set the global variables $TRUMP,$DIAMONDS,$HEARTS,$CLUBS,$SPADES
+        * accordingly
+        */
+       
+       $gametype = DB_get_gametype_by_gameid($gameid);
+       $GT = $gametype;
+       if($gametype=="solo")
+         {
+           $gametype = DB_get_solo_by_gameid($gameid);
+           $GT = $gametype." ".$GT;
+         }
+       else
+         $gametype="normal";
+       
+       set_gametype($gametype);
+
+       
        /* display useful things in divs */
        
        /* display local time */
@@ -263,7 +296,7 @@ else if(myisset("me"))
          };
        echo "</table>\n</div>\n";
 
-       display_status();
+       display_status($GT);
 
        /* display links to the users status page */
        $result = mysql_query("SELECT email,password from User WHERE id='$myid'" );
@@ -324,6 +357,7 @@ else if(myisset("me"))
        $play = array(); /* needed to calculate winner later  */
        $seq  = 1;          
        $pos  = 0;
+       $firstcard = ""; /* first card in a trick */
        
        echo "\n<ul class=\"tricks\">\n";
        echo "  <li> Hello $myname!   History: </li>\n";
@@ -338,20 +372,27 @@ else if(myisset("me"))
            /* save card to be able to find the winner of the trick later */
            $play[$pos] = $r[0]; 
            
-           if($trick!=$lasttrick && $seq==1)
-             {
-               /* start of an old trick? */
-               echo "  <li onclick=\"hl('$trickNR');\"><a href=\"#\">Trick $trickNR</a>\n".
-                 "    <div class=\"trick\" id=\"trick".$trickNR."\">\n".
-                 "      <img class=\"arrow\" src=\"pics/arrow".($pos-1).".png\" alt=\"table\" />\n";
-             }
-           else if($trick==$lasttrick && $seq==1)
+           if($seq==1)
              {
-               /* start of a last trick? */
-               echo "  <li onclick=\"hl('$trickNR');\"><a href=\"#\">Current Trick</a>\n".
-                 "    <div class=\"trick\" id=\"trick".$trickNR."\">\n".
-                 "      <img class=\"arrow\" src=\"pics/arrow".($pos-1).".png\" alt=\"table\" />\n";
-             }
+               /* first card in a trick, output some html */
+               if($trick!=$lasttrick)
+                 {
+                   /* start of an old trick? */
+                   echo "  <li onclick=\"hl('$trickNR');\"><a href=\"#\">Trick $trickNR</a>\n".
+                     "    <div class=\"trick\" id=\"trick".$trickNR."\">\n".
+                     "      <img class=\"arrow\" src=\"pics/arrow".($pos-1).".png\" alt=\"table\" />\n";
+                 }
+               else if($trick==$lasttrick)
+                 {
+                   /* start of a last trick? */
+                   echo "  <li onclick=\"hl('$trickNR');\"><a href=\"#\">Current Trick</a>\n".
+                     "    <div class=\"trick\" id=\"trick".$trickNR."\">\n".
+                     "      <img class=\"arrow\" src=\"pics/arrow".($pos-1).".png\" alt=\"table\" />\n";
+                 };
+               
+               /* remember first card, so that we are able to check, what cards can be played */
+               $firstcard = $r[0];
+             };
            
            /* display card */
            echo "      <div class=\"card".($pos-1)."\">\n";
@@ -381,8 +422,9 @@ else if(myisset("me"))
        /* whos turn is it? */
        if($seq==4)
          {
-            $winner = get_winner($play,"normal"); /* returns the position */
+            $winner = get_winner($play,$gametype); /* returns the position */
             $next = $winner;
+            $firstcard = ""; /* new trick, no first card */
          }
        else
          {
@@ -455,7 +497,7 @@ else if(myisset("me"))
                    if($sequence==4)
                      {
                        $play   = DB_get_cards_by_trick($trickid);
-                       $winner = get_winner($play,"normal"); /* returns the position */
+                       $winner = get_winner($play,$gametype); /* returns the position */
                        $next = $winner;
                      }
                    else
@@ -497,8 +539,19 @@ else if(myisset("me"))
            echo "Hello ".$myname.", it's your turn!  <br />\n";
            echo "Your cards are: <br />\n";
            echo "<form action=\"index.php?me=$me\" method=\"post\">\n";
+
+           /* do we have to follow suit? */
+           $followsuit = 0;
+           if(have_suit($mycards,$firstcard))
+             $followsuit = 1;
+
            foreach($mycards as $card) 
-             display_link_card($card);
+             {
+               if($followsuit && !same_type($card,$firstcard))
+                 display_card($card);
+               else
+                 display_link_card($card);
+             }
 
            echo "<br />\nA short comments:<input name=\"comment\" type=\"text\" size=\"30\" maxlength=\"50\" />\n";
            echo "<input type=\"hidden\" name=\"me\" value=\"$me\" />\n";
index 5b796813df5738af4770f7bc69e5b5897f79a5f6..000c2b2227b061ee405e1268a11cf15289959ca7 100644 (file)
@@ -2,10 +2,10 @@
 
 /* functions which only ouput html  */
 
-function display_status()
+function display_status($gametype)
 {
   echo "<div class=\"info\">";
-  echo " is someone playing solo, etc?";
+  echo " Gametype: $gametype";
   echo "</div>\n";
   
   return;
@@ -142,7 +142,7 @@ function check_for_sickness($me,$mycards)
 
  <?php   
       
-   echo "wedding?";
+  echo "wedding?";
   if(check_wedding($mycards))
      {
        echo " yes<input type=\"radio\" name=\"wedding\" value=\"yes\" checked=\"checked\" />";