X-Git-Url: https://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;f=web%2Fbrisk.phh;h=2a7355c97bc4e6ab0f078d06147d2019da1ec311;hb=ef0eff447cc1d588c95b9b6bfc5da4cb14ba7af6;hp=df0c63166f6b0f07881fae598e61fbbb6b544074;hpb=f55c2d16a38119d63ee03304ea38e7e647ad1f5a;p=brisk.git diff --git a/web/brisk.phh b/web/brisk.phh index df0c631..2a7355c 100644 --- a/web/brisk.phh +++ b/web/brisk.phh @@ -34,9 +34,50 @@ define(NICKSERV, "SERVER"); define(BRISK_DEBUG, FALSE); // define(DEBUGGING, "local"); +$root_wellarr = Array ( 'Benvenuto in brisk (Ver. 0.4.3).', + 'Se vuoi iscriverti alla Mailing List, cliccala!' ); +$table_wellarr = Array ( 'In bocca al lupo!'); + +$G_brisk_version = "0.4.3"; + +$G_room_help= ' +
+Descrizione
+Questa è un\'implementazione della briscola in cinque, così come è spiegata su +Wikipedia; in breve è la variante con l\'asta prima sulla carta e poi sui punti.

+Uso del sito
+Potete sedervi a un tavolo o rimanere in piedi.
+Se al vostro tavolo si raggiungono i 5 giocatori inizia automaticamente la partita.
+
+Partita
+All\'inizio vengono distribuite le carte e parte l\'asta; per partecipare all\'asta, quando sarà il vostro turno, potrete scegliere se andare avanti o passare cliccando sulle icone corrispondenti. Se si arriva ai punti, scrivete nella textbox il vostro rilancio e cliccate PUNTI.

+Chi vince l\'asta dovrà decidere il seme della carta scelta e inizierà la mano.
+Per giocare le carte dovrete trascinarle nel quadrato al centro del vostro schermo.

+Il vostro turno è sempre segnalato da una cornice verde lampeggiante intorno quadrato al centro del vostro schermo.

+Durante la partita, se vorrete ricaricare la pagina, usate l\'apposito bottone \\"reload\\" in basso a destra.
+
+
Comandi della chat +
/nick <nuovo_nickname> - cambio di nickname +
.. to be continue .. +
+
+'; + +$G_room_about= '
+
+ + briscola chiamata in salsa ajax +
+
version '.$G_brisk_version.'

+Copyright 2006-2007 Matteo Nastasi (aka mop)

'; + + function xcape($s) { - return (str_replace('\\', '\\\\', str_replace('@', '@', str_replace('|', '¦', htmlentities($s,ENT_COMPAT,"UTF-8"))))); + $from = array ( '\\', '@', '|' ); + $to = array ( '\\\\', '@', '¦' ); + + return (str_replace($from, $to, htmlentities($s,ENT_COMPAT,"UTF-8"))); } @@ -219,8 +260,37 @@ class Table { { $this->player[$idx] = $player; } -} + function user_add($idx) + { + $this->player[$this->player_n] = $idx; + $this->player_n++; + + return ($this->player_n - 1); + } + + function user_rem(&$bri, &$user) + { + $tabpos = $user->table_pos; + + /* verifico la consistenza dei dati */ + if ($bri->user[$this->player[$tabpos]] == $user) { + + /* aggiorna l'array dei giocatori al tavolo. */ + for ($i = $tabpos ; $i < $this->player_n-1 ; $i++) { + $this->player[$i] = $this->player[$i+1]; + $user_cur = &$bri->user[$this->player[$i]]; + $user_cur->table_pos = $i; + } + $this->player_n--; + } + else { + log_main($user->sess, "INCONSISTENCY ON TABLE."); + } + } + +} // End class Table + class User { var $name; // name of the user var $sess; // session of the user @@ -343,14 +413,10 @@ class brisco { } } } + /* aggiorna l'array dei giocatori al tavolo. */ - for ($i = $user->table_pos ; $i < $table->player_n-1 ; $i++) { - $table->player[$i] = $table->player[$i+1]; - $user_cur = &$this->user[$table->player[$i]]; - $user_cur->table_pos = $i; - } - $this->table[$table_idx]->player_n--; - + $table->user_rem(&$this, &$user); + for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { $user_cur = &$this->user[$i]; if ($user_cur->sess == '' || $user_cur->stat != 'room') @@ -480,7 +546,7 @@ class brisco { if (strncmp($user_mesg, "/nick ", 6) == 0) { log_main($user->sess, "chatt_send BEGIN"); - $name_new = substr(trim(substr($user_mesg, 6)),0,12); + $name_new = str_replace(' ', '_', substr(trim(substr($user_mesg, 6)),0,12)); $user_mesg = "COMMAND ".$user_mesg; // Search dup name // change @@ -488,7 +554,8 @@ class brisco { // update remote graphs for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { $user_cur = &$this->user[$i]; - if ($user_cur->sess == '' || $user_cur->stat != 'room') + // if ($user_cur->sess == '' || $user_cur->stat != 'room') + if ($user_cur->sess == '') continue; if ($user_cur->name == $name_new) { $user->comm[$user->step % COMM_N] = "gst.st = ".($user->step+1)."; "; @@ -511,7 +578,7 @@ class brisco { continue; if ($user_cur->stat == 'room') { if ($user->stat == 'room' && $user->subst == 'standup') { - standup_update(&$this,&$user); + $this->standup_update(&$user); } else if ($user->stat == 'room' && $user->subst == 'sitdown' || $user->stat == 'table') { @@ -558,7 +625,109 @@ class brisco { } } } + + function &get_user($sess, &$idx) + { + GLOBAL $PHP_SELF; + + if (strlen($sess) == SESS_LEN) { + for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { + if (strcmp($sess, $this->user[$i]->sess) == 0) { + // find it + $idx = $i; + return ($this->user[$i]); + } + } + log_main($sess, sprintf("get_user: Wrong sess from page [%s]",$PHP_SELF)); + // for ($i = 0 ; $i < MAX_PLAYERS ; $i++) + // log_main($sess, sprintf("get_user: Wrong sess compared with [%s]",$this->user[$i]->sess)); + } + else { + log_main($sess, sprintf("get_user: Wrong strlen [%s]",$sess)); + } + return (FALSE); + } + + /* + * function &add_user(&$bri, &$sess, &$idx, $name) + * + * RETURN VALUE: + * if ($idx != -1 && ret == FALSE) => duplicated nick + * if ($idx == -1 && ret == FALSE) => no space left + * if (ret == TRUE) => SUCCESS + */ + function &add_user(&$sess, &$idx, $name) + { + $idx = -1; + $idfree = -1; + + log_auth("XXX", sprintf("ARRIVA: [%s]", $sess)); + if (validate_sess($sess) == FALSE) + $sess = ""; + + for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { + /* free user ? */ + if (strcmp($sess, $this->user[$i]->sess) == 0) { + if ($idx == -1) + $idx = $i; + } + if ($idfree == -1 && strcmp("", $this->user[$i]->sess) == 0) { + $idfree = $i; + } + if (strcmp($this->user[$i]->name, $name) == 0) { + $idx = $i; + break; + } + } + if ($idx == -1) + $idx = $idfree; + + log_auth("XXX", sprintf("TROVATO A QUESTO PUNTO [%d] sess [%s] name [%s]", $idx, $sess, $name)); + + if ($idx != -1 && $i == MAX_PLAYERS) { + /* SUCCESS */ + if ($sess == "") { + $this->user[$idx]->sess = uniqid(""); + $sess = $this->user[$idx]->sess; + + } + else { + $this->user[$idx]->sess = $sess; + } + $this->user[$idx]->name = $name; + $this->user[$idx]->stat = "room"; + $this->user[$idx]->subst = "standup"; + + log_main("XXX", sprintf("TROVATO LIBERO A [%d] sess [%s] name [%s]", $idx, $sess, $name)); + + return ($this->user[$idx]); + } + + return (FALSE); + } + function standup_update(&$user) + { + for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { + $user_cur = &$this->user[$i]; + if ($user_cur->sess == '') + continue; + + log_main("STANDUP START", $user_cur->stat); + + if ($user_cur->stat == 'room') { + $user_cur->comm[$user_cur->step % COMM_N] = "gst.st = ".($user_cur->step+1)."; ".standup_content($this, $user_cur); + if ($user_cur == $user) + $user_cur->comm[$user_cur->step % COMM_N] .= sprintf('$("myname").innerHTML = "%s: ";', xcape($user->name)); + + log_main("FROM STANDUP", "NAME: ".$user_cur->name." SENDED: ".$user_cur->comm[$user_cur->step % COMM_N]); + + $user_cur->step++; + } + } + } + + } // end class brisco function make_seed() @@ -715,80 +884,18 @@ function save_data(&$bri) return ($ret); } -function &get_user(&$bri, $sess, &$idx) -{ - GLOBAL $PHP_SELF; - - if (strlen($sess) == SESS_LEN) { - for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { - if (strcmp($sess, $bri->user[$i]->sess) == 0) { - // find it - $idx = $i; - return ($bri->user[$i]); - } - } - log_main($sess, sprintf("get_user: Wrong sess from page [%s]",$PHP_SELF)); - // for ($i = 0 ; $i < MAX_PLAYERS ; $i++) - // log_main($sess, sprintf("get_user: Wrong sess compared with [%s]",$bri->user[$i]->sess)); - } - else { - log_main($sess, sprintf("get_user: Wrong strlen [%s]",$sess)); - } - return (FALSE); -} - -/* - * function &add_user(&$bri, &$sess, &$idx, $name) - * - * RETURN VALUE: - * if ($idx != -1 && ret == FALSE) => duplicated nick - * if ($idx == -1 && ret == FALSE) => no space left - * if (ret == TRUE) => SUCCESS - */ -function &add_user(&$bri, &$sess, &$idx, $name) -{ - $idx = -1; - - for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { - /* free user ? */ - if (strcmp($sess, $bri->user[$i]->sess) == 0) { - if ($idx == -1) - $idx = $i; - } - if (strcmp($bri->user[$i]->name, $name) == 0) { - $idx = $i; - break; - } - } - if ($idx != -1 && $i == MAX_PLAYERS) { - /* SUCCESS */ - $bri->user[$idx]->sess = uniqid(""); - $sess = $bri->user[$idx]->sess; - $bri->user[$idx]->name = $name; - $bri->user[$idx]->stat = "room"; - $bri->user[$idx]->subst = "standup"; - - log_main("XXX", sprintf("TROVATO LIBERO A [%d] sess [%s] name [%s]", $idx, $sess, $name)); - - return ($bri->user[$idx]); - } - else { - return (FALSE); - } -} - function table_act_content($isstanding, $sitted, $table, $cur_table) { $ret = ""; if ($isstanding) { if ($sitted < PLAYERS_N) { - $ret = sprintf('', $table, $table); + $ret = sprintf('', $table, $table); } } else { if ($table == $cur_table) - $ret = sprintf(''); + $ret = sprintf(''); else $ret = ""; } @@ -840,7 +947,14 @@ function standup_content(&$bri, $user) if ($user->stat != 'room') return; - $content .= ''; + for ($e = 0 , $ct = 0 ; $ct < 4 && $e < MAX_PLAYERS ; $e++) { + if ($bri->user[$e]->sess == "" || $bri->user[$e]->stat != "room" || $bri->user[$e]->name == "") + continue; + $ct++; + } + + $content .= sprintf('
', $ct); + for ($e = 0 , $ct = 0 ; $e < MAX_PLAYERS ; $e++) { if ($bri->user[$e]->sess == "" || $bri->user[$e]->stat != "room" || $bri->user[$e]->name == "") continue; @@ -855,7 +969,7 @@ function standup_content(&$bri, $user) else { $hilion = ""; $hilioff = ""; } - $content .= sprintf('',$hilion, xcape($bri->user[$e]->name), $hilioff); + $content .= sprintf('',$hilion, xcape($bri->user[$e]->name), $hilioff); if (($ct % 4) == 3) { $content .= ''; } @@ -864,47 +978,20 @@ function standup_content(&$bri, $user) } $content .= '
%s%s%s%s%s%s
'; - $content2 = ''; + $content2 = ''; $ret .= sprintf('$("standup").innerHTML = "%s"; $("esco").innerHTML = "%s";', $content, $content2); return ($ret); } -function standup_update(&$bri, &$user) -{ - for ($i = 0 ; $i < MAX_PLAYERS ; $i++) { - $user_cur = &$bri->user[$i]; - if ($user_cur->sess == '') - continue; - - log_main("STANDUP START", $user_cur->stat); - if ($user_cur->stat == 'room') { - $user_cur->comm[$user_cur->step % COMM_N] = "gst.st = ".($user_cur->step+1)."; ".standup_content($bri, $user_cur); - if ($user_cur == $user) - $user_cur->comm[$user_cur->step % COMM_N] .= sprintf('$("myname").innerHTML = "%s: ";', xcape($user->name)); - - log_main("FROM STANDUP", "NAME: ".$user_cur->name." SENDED: ".$user_cur->comm[$user_cur->step % COMM_N]); - - $user_cur->step++; - } - } -} - - - - - -function show_notify($text, $tout, $butt) +function show_notify($text, $tout, $butt, $w, $h) { log_main("SHOW_NOTIFY", $text); - return sprintf('var noti = new notify(gst,$("bg"),"%s",%d,"%s");', $text, $tout,$butt); + return sprintf('var noti = new notify(gst,"%s",%d,"%s",%d,%d);', $text, $tout, $butt, $w, $h); } - - - function briscola_show($bri, $table, $user) { $ptnadd = ""; @@ -962,6 +1049,8 @@ function multoval($mult) function show_table_info(&$bri, &$table, $table_pos) { + $user = &$bri->user[$table->player[$table_pos]]; + $pnt_min = $table->points_n - MAX_POINTS < 0 ? 0 : $table->points_n - MAX_POINTS; $noty = sprintf(''); @@ -1021,10 +1110,29 @@ function show_table_info(&$bri, &$table, $table_pos) } } if ($table->mazzo == $table_pos) - $noty .= "Fai tu il mazzo."; + $noty .= "Fai tu il mazzo,"; else { $unam = xcape($bri->user[$table->player[$table->mazzo]]->name); - $noty .= "Il mazzo a $unam."; + $noty .= "Il mazzo a $unam,"; + } + + if ($user->subst == 'asta') { + if ($table->asta_win == -1) // auction case + $curplayer = $table->gstart % PLAYERS_N; + else + $curplayer = $table->asta_win; + } + else if ($user->subst == 'game') { + $curplayer = ($table->gstart + $table->turn) % PLAYERS_N; + } + + + if ($curplayer == $table_pos) { + $noty .= " tocca a te giocare."; + } + else { + $unam = xcape($bri->user[$table->player[$curplayer]]->name); + $noty .= " tocca a $unam giocare."; } if ($table->mult > 1) { @@ -1032,17 +1140,37 @@ function show_table_info(&$bri, &$table, $table_pos) } $noty .= "

"; - $ret .= show_notify($noty, 3000, "torna alla partita"); + $ret .= show_notify($noty, 3000, "torna alla partita", 500, 400); return ($ret); } +function root_wellcome($user) +{ + GLOBAL $root_wellarr; + + for ($i = 0 ; $i < count($root_wellarr) ; $i++) + $ret .= sprintf('chatt_sub("ChanServ: ","%s");', str_replace('"', '\"', $root_wellarr[$i])); + + return ($ret); +} + +function table_wellcome($user) +{ + GLOBAL $table_wellarr; + for ($i = 0 ; $i < count($table_wellarr) ; $i++) + $ret .= sprintf('chatt_sub("ChanServ: ","%s");', str_replace('"', '\"', $table_wellarr[$i])); + + return ($ret); +} function show_room(&$bri, &$user) { $ret .= sprintf('gst.st = %d;', $user->step); $ret .= sprintf('stat = "%s";', $user->stat); + + $ret .= root_wellcome($user); $ret .= sprintf('subst = "%s";', $user->subst); $ret .= sprintf('$("myname").innerHTML = "%s";', xcape($user->name,ENT_COMPAT,"UTF-8")); for ($i = 0 ; $i < TABLES_N ; $i++) { @@ -1061,6 +1189,12 @@ function show_room(&$bri, &$user) /* show table is_transition (is from room to table ?) is_again (is another game) + +Examles of $is_transition, $is_again: + from reload of the page: FALSE, FALSE + from sitdown in room: TRUE, FALSE + from table: asta cmd e tutti passano: TRUE, TRUE + from table: fine partita: TRUE, TRUE */ function show_table(&$bri, &$user, $sendstep, $is_transition, $is_again) { @@ -1101,6 +1235,8 @@ function show_table(&$bri, &$user, $sendstep, $is_transition, $is_again) if ($is_transition) { // && $user->subst == "asta" superfluo $ret .= show_table_info(&$bri, &$table, $user->table_pos); } + if (!$is_again) + $ret .= table_wellcome($user); /* CARDS */ if ($is_transition) { // && $user->subst == "asta" superfluo @@ -1118,7 +1254,7 @@ function show_table(&$bri, &$user, $sendstep, $is_transition, $is_again) } log_rd($sess, "O ".$o." VAL ".$table->card[$o]->value." Owner: ".$table->card[$o]->owner); - $ret .= sprintf( ' card_send(%d,%d,%d,%f,%d);|', ($table->gstart + $e) % PLAYERS_N, + $ret .= sprintf( ' card_send(%d,%d,%d,%8.2f,%d);|', ($table->gstart + $e) % PLAYERS_N, $i, ((($e + PLAYERS_N - $user->table_pos + $table->gstart) % PLAYERS_N) == 0 ? $table->card[$o]->value : -1), ($i == 7 && $e == (PLAYERS_N - 1) ? 1 : 0.5),$i+1); @@ -1339,4 +1475,10 @@ function calculate_points(&$table) $table->mult = 1; } +function validate_sess($sess) { + if (strlen($sess) == SESS_LEN) + return (TRUE); + else + return (FALSE); +} ?>