X-Git-Url: https://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;f=web%2Fbriskin5%2FObj%2Fbriskin5.phh;h=06f737e9e94fe76c221fe2d0fe7c152b140377a9;hb=44f4d1b333ecb3cc3c3666cc5acb2422edcf029d;hp=1afb8b2ce5f9fd69d750713791e60bc7b441621a;hpb=cb0ba3960a1911a231d114b25560e8bce211a79a;p=brisk.git diff --git a/web/briskin5/Obj/briskin5.phh b/web/briskin5/Obj/briskin5.phh index 1afb8b2..06f737e 100644 --- a/web/briskin5/Obj/briskin5.phh +++ b/web/briskin5/Obj/briskin5.phh @@ -2,7 +2,7 @@ /* * brisk - briskin5.phh * - * Copyright (C) 2006-2009 Matteo Nastasi + * Copyright (C) 2006-2011 Matteo Nastasi * mailto: nastasi@alternativeoutput.it * matteo.nastasi@milug.org * web: http://www.alternativeoutput.it @@ -20,8 +20,6 @@ * not, write to the Free Software Foundation, Inc, 59 Temple Place - * Suite 330, Boston, MA 02111-1307, USA. * - * $Id$ - * */ define(BRISKIN5_PLAYERS_N, 3); define(BRISKIN5_MAX_PLAYERS, BRISKIN5_PLAYERS_N); @@ -30,7 +28,74 @@ define(BRISKIN5_SHM_MIN, 32768); define(BRISKIN5_SHM_MAX, (BRISKIN5_SHM_MIN + 1048576)); define(BRISKIN5_SHM_DLT, 32768); -$table_wellarr = Array ( 'Benvenuto al tavolo. Se almeno tre giocatori non sbloccano l\'uscita cliccando il lucchetto, chi esce non può risedersi a un qualunque tavolo per '.floor(BAN_TIME/60).' minuti.'); +$mlang_bin5_bin5 = array( + 'info_part' => array( 'it' => '
Nell\'ultima mano ha chiamato %s, il socio era %s,
', + 'en' => '
In the last hand the declarer was %s, the partner was %s,
'), + 'info_capp' => array( 'it' => 'hanno fatto cappotto EBBRAVI!.
', + 'en' => 'and they made capot WELL DONE!.
'), + 'info_pnt' => array( 'it' => 'dovevano fare %s punti e ne hanno fatti %d: hanno %s.
', + 'en' => 'they had to do %s points and they had made %d: they have %s.
'), + 'info_alea' => array( 'it' => 'almeno ', + 'en' => 'at least '), + 'info_more' => array( 'it' => 'più di 60', + 'en' => 'over 60'), + 'info_win' => array( 'it' => 'vinto', + 'en' => 'win'), + 'info_peer' => array( 'it' => 'pareggiato', + 'en' => 'drew'), + 'info_lost' => array( 'it' => 'perso', + 'en' => 'lost'), + + 'info_alon' => array( 'it' => '
Nell\'ultima partita %s si è chiamato in mano,
', + 'en' => '
In the last hand %s play alone against each other,
'), + 'info_apnt' => array( 'it' => 'doveva fare %s punti e ne ha fatti %d: ha %s.
', + 'en' => 'he/she had to do %s points and they had made %d: he/she had %s.
'), + 'info_acap' => array( 'it' => 'ha fatto cappotto EBBRAVO!.
', + 'en' => 'and he/she made capot WELL DONE!.
'), + + 'info_omul' => array( 'it' => ' La partita valeva %s.', + 'en' => ' EN: The game was worth %s.' ), + + 'info_yturn'=> array( 'it' => ' tocca a te giocare.', + 'en' => ' it\'s your turn.'), + 'info_turn' => array( 'it' => 'tocca a %s giocare.', + 'en' => 'it\'s the %s\'s turn.'), + 'info_mult' => array( 'it' => ' La partita vale %s.', + 'en' => ' The game worth %s.' ), + 'info_yshuf'=> array( 'it' => 'Fai tu il mazzo, ', + 'en' => 'It\'s your shuffled the cards, '), + 'info_shuf' => array( 'it' => 'Il mazzo a %s, ', + 'en' => '%s shuffled the cards, '), + 'btn_bkgame'=> array( 'it' => 'torna alla partita', + 'en' => 'back to the game'), + 'call_wptn' => array( 'it' => '
con %d punti', + 'en' => '
with %d points'), + 'call_ycall'=> array( 'it' => 'Chiami%s:', + 'en' => 'Call%s:'), + 'call_call' => array( 'it' => 'Chiama %s%s:', + 'en' => 'The declarer is %s%s:') + + + ); + + // MLANG + $table_wellarr = Array( 'it' => Array ( 'Benvenuto al tavolo. Se almeno tre giocatori non sbloccano l\'uscita cliccando il lucchetto, chi esce non può risedersi a un qualunque tavolo per '.floor(BAN_TIME/60).' minuti.'), + 'en' => Array ( 'EN Benvenuto al tavolo. Se almeno tre giocatori non sbloccano l\'uscita cliccando il lucchetto, chi esce non può risedersi a un qualunque tavolo per '.floor(BAN_TIME/60).' minuti.') ); + +function multoval($mult) +{ + GLOBAL $G_lang; + + if ($mult == 2) + return ($G_lang == 'en' ? 'double' : 'doppio'); + if ($mult == 3) + return ($G_lang == 'en' ? 'triple' : 'triplo'); + else if ($mult == 4) + return ($G_lang == 'en' ? 'quadruple' : 'quadruplo'); + else + return (sprintf(($G_lang == 'en' ? "%d-ple" : "%d-plo"), $mult)); +} + class Card { var $value; /* 0 - 39 card value */ @@ -94,6 +159,7 @@ class Table_briskin5 extends Table { var $old_reason; var $old_asta_pnt; + var $old_mult; var $old_pnt; var $old_win; var $old_friend; @@ -104,12 +170,10 @@ class Table_briskin5 extends Table { /* CREATE() NOT USED - function &create($idx) + function create($idx) { - GLOBAL $G_false; - if (($thiz =& new Table_briskin5()) == FALSE) - return ($G_false); + return (FALSE); $thiz->create($idx); @@ -130,6 +194,7 @@ class Table_briskin5 extends Table { $thiz->old_reason = ""; $thiz->old_asta_pnt = -1; + $thiz->old_mult = -1; $thiz->old_pnt = -1; $thiz->old_win = -1; $thiz->old_friend = -1; @@ -139,12 +204,10 @@ class Table_briskin5 extends Table { */ /* CLONE() NOT USED - function &clone(&$from) + function myclone(&$from) { - GLOBAL $G_false; - if (($thiz =& new Table_briskin5()) == FALSE) - return ($G_false); + return (FALSE); parent::copy($from); @@ -169,6 +232,7 @@ class Table_briskin5 extends Table { $thiz->old_reason = $from->old_reason; $thiz->old_asta_pnt = $from->old_asta_pnt; + $thiz->old_mult = $from->mult; $thiz->old_pnt = $from->old_pnt; $thiz->old_win = $from->old_win; $thiz->old_friend = $from->old_friend; @@ -182,18 +246,17 @@ class Table_briskin5 extends Table { parent::copy($from); } - function &spawn(&$from) + function spawn(&$from) { - GLOBAL $G_false; - if (($thiz =& new Table_briskin5()) == FALSE) - return ($G_false); + return (FALSE); $thiz->parentcopy($from); log_main("PLAYER_N - spawn.".$thiz->player_n); - $thiz->card = &$thiz->bunch_create(); + $thiz->card = array(); + $thiz->bunch_create(); $thiz->mazzo = rand(0,PLAYERS_N-1); $thiz->points_n = 0; $thiz->mult = 1; @@ -211,28 +274,39 @@ class Table_briskin5 extends Table { } - function &bunch_create() + // function bunch_create_old() function AND + // { + // $ret = array(); + // + // for ($i = 0 ; $i < (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) ; $i++) { + // // for ($i = 0 ; $i < 40 ; $i++) { + // $ret[$i] =& new Card($i, 'bunch', 'no_owner'); + // } + // + // $oret = &$ret; + // return ($oret); + // } + + function bunch_create() { - $ret = array(); - - for ($i = 0 ; $i < 40 ; $i++) { - $ret[$i] =& new Card($i, 'bunch', 'no_owner'); - } - - $oret = &$ret; - return ($oret); + $ret = array(); + + for ($i = 0 ; $i < (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) ; $i++) { + $this->card[$i] = new Card($i, 'bunch', 'no_owner'); + } } function bunch_make() { + log_main("bunch_make start"); $ct = array(0,0,0,0,0); mt_srand(make_seed()); - for ($i = 39 ; $i >= 0 ; $i--) + for ($i = (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) - 1 ; $i >= 0 ; $i--) $rest[$i] = $i; - for ($i = 39 ; $i >= 0 ; $i--) { + for ($i = (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) - 1 ; $i >= 0 ; $i--) { $rn = rand(0, $i); if ($rn == 0) @@ -240,15 +314,16 @@ class Table_briskin5 extends Table { $id = $rest[$rn]; - $owner = $i % PLAYERS_N; + $owner = $i % BRISKIN5_PLAYERS_N; $this->card[$id]->assign('hand', $owner); $rest[$rn] = $rest[$i]; // $pubbpos[$rn2] = $pubbpos[$i]; } + log_main("bunch_make end"); } - function init(&$userarr) + function init($userarr) { /* MOVED INTO SPAWN $this->mazzo = rand(0,PLAYERS_N-1); @@ -257,24 +332,24 @@ class Table_briskin5 extends Table { $this->old_win = -1; $this->old_reason = ""; */ - for ($i = 0 ; $i < PLAYERS_N ; $i++) { + for ($i = 0 ; $i < BRISKIN5_PLAYERS_N ; $i++) { $this->total[$i] = 0; - $user_cur = &$userarr[$this->player[$i]]; + $user_cur = $userarr[$this->player[$i]]; $user_cur->exitislock = TRUE; } log_main("table::init: ci siamo"); } - function game_init(&$userarr) + function game_init($userarr) { log_rd2("GSTART 4"); - $this->gstart = ($this->mazzo+1) % PLAYERS_N; + $this->gstart = ($this->mazzo+1) % BRISKIN5_PLAYERS_N; $this->bunch_make(); - $this->asta_pla_n = PLAYERS_N; + $this->asta_pla_n = BRISKIN5_PLAYERS_N; $this->asta_card = -1; $this->asta_pnt = 60; $this->asta_win = -1; @@ -282,20 +357,21 @@ class Table_briskin5 extends Table { $this->friend = -1; $this->turn = 0; - for ($i = 0 ; $i < PLAYERS_N ; $i++) { + for ($i = 0 ; $i < BRISKIN5_PLAYERS_N ; $i++) { $this->asta_pla[$i] = TRUE; - $user_cur = &$userarr[$this->player[$i]]; + $user_cur = $userarr[$this->player[$i]]; $user_cur->subst = 'asta'; $user_cur->asta_card = -2; $user_cur->asta_pnt = -1; $user_cur->handpt = $this->hand_points($i); // SEE function calculate_points(&$table) } + log_rd2("GEND 4"); } function game_next() { - $this->mazzo = ($this->mazzo + 1) % PLAYERS_N; + $this->mazzo = ($this->mazzo + 1) % BRISKIN5_PLAYERS_N; } @@ -305,7 +381,8 @@ class Table_briskin5 extends Table { $tot = 0; - for ($i = 0 ; $i < 40 ; $i++) { + for ($i = 0 ; $i < (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) ; $i++) { + // for ($i = 0 ; $i < 40 ; $i++) { if ($this->card[$i]->owner != $idx) continue; @@ -317,9 +394,9 @@ class Table_briskin5 extends Table { } - function exitlock_show(&$userarr, $table_pos) + function exitlock_show($userarr, $table_pos) { - $ct = $this->exitlock_calc(&$userarr, $table_pos); + $ct = $this->exitlock_calc($userarr, $table_pos); $ret = sprintf('exitlock_show(%d, %s);', $ct, ($userarr[$this->player[$table_pos]]->exitislock ? 'true' : 'false')); @@ -342,28 +419,28 @@ class Table_briskin5 extends Table { - +define(BIN5_USER_FLAG_RING_ENDAUCT, 0x01); class User_briskin5 extends User { var $asta_card; // var $asta_pnt; // var $handpt; // Total card points at the beginning of the current hand. var $exitislock; // Player can exit from the table ? + var $privflags; // Flags for briskin5 only function User() { } /* CREATE NOT USED - function &create($name, $sess, $stat = "", $subst = "", $table = -1, $ip="0.0.0.0") { - GLOBAL $G_false; - + function create($name, $sess, $stat = "", $subst = "", $table = -1, $ip="0.0.0.0") { if (($thiz =& new User()) == FALSE) - return ($G_false); + return (FALSE); $thiz->asta_card = -2; $thiz->asta_pnt = -1; $thiz->handpt = -1; $thiz->exitislock = TRUE; + $thiz->privflags = 0; return ($thiz); } @@ -382,15 +459,14 @@ class User_briskin5 extends User { $this->asta_pnt = $from->asta_pnt; $this->handpt = $from->handpt; $this->exitislock = $from->exitislock; + $this->privflags = $from->privflags; } /* CLONE NOT USED - function &clone(&$from) + function myclone(&$from) { - GLOBAL $G_false; - if (($thiz =& new User()) == FALSE) - return ($G_false); + return (FALSE); $thiz->copy($from); @@ -398,12 +474,12 @@ class User_briskin5 extends User { } */ - function &spawn(&$from, $table, $table_pos) + function spawn(&$from, $table, $table_pos) { - GLOBAL $G_false; + GLOBAL $CO_bin5_pref_ring_endauct; if (($thiz =& new User_briskin5()) == FALSE) - return ($G_false); + return (FALSE); $thiz->parentcopy($from); @@ -412,6 +488,10 @@ class User_briskin5 extends User { $thiz->handpt = -1; $thiz->exitislock = TRUE; + log_wr("Briskin5 constructor"); + + $this->privflags = ($CO_bin5_pref_ring_endauct == "true" ? BIN5_USER_FLAG_RING_ENDAUCT : 0) | 0; + $thiz->table_orig = $table; $thiz->table = 0; $thiz->table_pos = $table_pos; @@ -447,14 +527,14 @@ class Briskin5 { exit; } - $user =& $room->user; - $table =& $room->table[$table_idx]; + $user = $room->user; + $table = $room->table[$table_idx]; log_wr("Briskin5 constructor"); for ($i = 0 ; $i < $table->player_n ; $i++) { $user[$table->player[$i]]->table_token = $table_token; - $this->user[$i] =& User_briskin5::spawn(&$user[$table->player[$i]], $table_idx, $i); + $this->user[$i] =& User_briskin5::spawn($user[$table->player[$i]], $table_idx, $i); } $this->table[0] =& Table_briskin5::spawn(&$table); @@ -468,9 +548,9 @@ class Briskin5 { } - function &get_user($sess, &$idx) + function get_user($sess, &$idx) { - GLOBAL $PHP_SELF, $G_false; + GLOBAL $PHP_SELF; if (validate_sess($sess)) { for ($i = 0 ; $i < BRISKIN5_MAX_PLAYERS ; $i++) { @@ -489,20 +569,21 @@ class Briskin5 { log_main(sprintf("get_user: Wrong strlen [%s]",$sess)); } - return ($G_false); + return (FALSE); } function garbage_manager($force) { - + GLOBAL $G_base; + /* Garbage collector degli utenti in timeout */ $ismod = FALSE; $curtime = time(); if ($force || $this->garbage_timeout < $curtime) { for ($i = 0 ; $i < BRISKIN5_MAX_PLAYERS ; $i++) { - $user_cur = &$this->user[$i]; + $user_cur = $this->user[$i]; if ($user_cur->sess == "" || ($user_cur->stat == 'table' && ($user_cur->subst == 'shutdowned' || $user_cur->subst == 'shutdowner'))) continue; @@ -523,7 +604,16 @@ class Briskin5 { */ - $this->table_wakeup(&$user_cur); + /* se gli altri utenti non erano d'accordo questo utente viene bannato */ + $remcalc = $this->table[0]->exitlock_calc(&$this->user, $user_cur->table_pos); + if ($remcalc < 3) { + require_once("${G_base}Obj/hardban.phh"); + Hardbans::add(($user_cur->flags & USER_FLAG_AUTH ? $user_cur->name : FALSE), + $user_cur->ip, $user_cur->sess, $user_cur->laccwr + BAN_TIME); + } + // $user->bantime = $user->laccwr + BAN_TIME; + + $this->table_wakeup($user_cur); } } } @@ -542,7 +632,7 @@ class Briskin5 { // // static functions // - function &load_data($table_idx, $table_token = "") + function load_data($table_idx, $table_token = "") { GLOBAL $G_false, $sess; $doexit = FALSE; @@ -588,7 +678,7 @@ class Briskin5 { if ($doexit) exit(); - return ($G_false); + return (FALSE); } @@ -701,8 +791,10 @@ class Briskin5 { } - function chatt_send(&$user, $mesg) + function chatt_send($user, $mesg) { + GLOBAL $mlang_brisk, $G_lang; + if ($user->stat == 'table') { $table = &$this->table[$user->table]; } @@ -717,7 +809,7 @@ class Briskin5 { if (($name_new = validate_name(substr($user_mesg, 6))) == FALSE) { $user->comm[$user->step % COMM_N] = "gst.st = ".($user->step+1)."; "; - $user->comm[$user->step % COMM_N] .= sprintf('chatt_sub("%s", [2, "%s"],"Il nickname deve contenere almeno una lettera dell\'alfabeto o una cifra.");', $dt, NICKSERV); + $user->comm[$user->step % COMM_N] .= sprintf('chatt_sub("%s", [2, "%s"],"%s");', $dt, NICKSERV, $mlang_brisk['nickmust'][$G_lang]); $user->step_inc(); return; @@ -728,13 +820,15 @@ class Briskin5 { // update local graph // update remote graphs for ($i = 0 ; $i < BRISKIN5_MAX_PLAYERS ; $i++) { - $user_cur = &$this->user[$i]; + $user_cur = $this->user[$i]; // 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)."; "; - $user->comm[$user->step % COMM_N] .= sprintf('chatt_sub("%s", [2, "%s"],"Nickname %s già in uso.%d");', $dt, NICKSERV, xcape($name_new), $this->table[$user->table]->auth_only == TRUE); + + $premsg = sprintf($mlang_brisk['nickdupl'][$G_lang], xcape($name_new)); + $user->comm[$user->step % COMM_N] .= sprintf('chatt_sub("%s", [2, "%s"],"%s");', $dt, NICKSERV, $premsg); $user->step_inc(); break; } @@ -743,7 +837,7 @@ class Briskin5 { if ($user->flags & USER_FLAG_AUTH && strcasecmp($user->name,$name_new) != 0) { if ($this->table[$user->table]->auth_only == TRUE) { $user->comm[$user->step % COMM_N] = "gst.st = ".($user->step+1)."; "; - $user->comm[$user->step % COMM_N] .= sprintf('chatt_sub("%s", [2, "%s"],"Non puoi cambiare nick a un tavolo per soli autenticati.");', $dt, NICKSERV); + $user->comm[$user->step % COMM_N] .= sprintf('chatt_sub("%s", [2, "%s"],"%s");', $dt, NICKSERV, $mlang_brisk['authchan'][$G_lang]); $user->step_inc(); return; } @@ -814,7 +908,7 @@ class Briskin5 { } } - function table_wakeup(&$user) + function table_wakeup($user) { $table = &$this->table[0]; @@ -886,11 +980,28 @@ function locshm_exists($tok) } +function asta2mult($asta_pnt) +{ + if ($asta_pnt > 110) + return (5); + else if ($asta_pnt > 100) + return (4); + else if ($asta_pnt > 90) + return (3); + else if ($asta_pnt > 80) + return (2); + else if ($asta_pnt > 70) + return (1); + else + return (0); +} +// rendiamo qui l'elenco dei punti come return della func function calculate_points(&$table) { GLOBAL $G_all_points; + $ret = array(); $pro = 0; if ($table->asta_pnt == 60) @@ -900,8 +1011,10 @@ function calculate_points(&$table) $table->old_win = $table->asta_win; $table->old_friend = $table->friend; $table->old_asta_pnt = $table->asta_pnt; + $table->old_mult = $table->mult; - for ($i = 0 ; $i < 40 ; $i++) { + for ($i = 0 ; $i < (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) ; $i++) { + // for ($i = 0 ; $i < 40 ; $i++) { $ctt = $table->card[$i]->value % 10; $own = $table->card[$i]->owner; if ($own == $table->asta_win || $own == $table->friend) @@ -913,13 +1026,15 @@ function calculate_points(&$table) if ($table->asta_pnt == 61 && $pro == 60) { // PATTA ! $table->points[$table->points_n % MAX_POINTS] = array(); - for ($i = 0 ; $i < BRISKIN5_PLAYERS_N ; $i++) + for ($i = 0 ; $i < BRISKIN5_PLAYERS_N ; $i++) { $table->points[$table->points_n % MAX_POINTS][$i] = 0; + $ret[$i] = 0; + } $table->points_n++; $table->old_pnt = $pro; - $table->mult *= 2; + $table->mult += 1; - return; + return($ret); } if ($pro >= $table->asta_pnt) @@ -927,6 +1042,8 @@ function calculate_points(&$table) else $sig = -1; + $gamult = asta2mult($table->asta_pnt); + $table->points[$table->points_n % MAX_POINTS] = array(); for ($i = 0 ; $i < BRISKIN5_PLAYERS_N ; $i++) { if ($i == $table->asta_win) @@ -935,19 +1052,24 @@ function calculate_points(&$table) $pt = 1; else $pt = -1; + + log_wr(sprintf("PRO: pt[%d][%d] = %d", $table->points_n % MAX_POINTS, $i, $pt)); - $pt = $pt * $sig * $table->mult * ($pro == 120 ? 2 : 1); + $pt = $pt * $sig * ($gamult + $table->mult) * ($pro == 120 ? 2 : 1); log_wr(sprintf("PRO:[%d][%d][%d]", $sig, $table->mult, ($pro == 120 ? 2 : 1))); $table->points[$table->points_n % MAX_POINTS][$i] = $pt; $table->total[$i] += $pt; + $ret[$i] = $pt; } $table->points_n++; $table->old_pnt = $pro; $table->mult = 1; + + return($ret); } /* show table @@ -963,7 +1085,7 @@ Examples of $is_transition, $is_again: function show_table(&$room, &$user, $sendstep, $is_transition, $is_again) { $table_idx = $user->table; - $table = &$room->table[$table_idx]; + $table = $room->table[$table_idx]; $table_pos = $user->table_pos; $ret = "table_init();"; @@ -1018,7 +1140,8 @@ function show_table(&$room, &$user, $sendstep, $is_transition, $is_again) for ($i = 0 ; $i < 8 ; $i++) { for ($e = 0 ; $e < BRISKIN5_PLAYERS_N ; $e++) { $ct = 0; - for ($o = 0 ; $o < 40 && $ct < $i+1 ; $o++) { + for ($o = 0 ; $o < (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) && $ct < $i+1 ; $o++) { + // for ($o = 0 ; $o < 40 && $ct < $i+1 ; $o++) { if ($table->card[$o]->owner == (($e + $table->gstart) % BRISKIN5_PLAYERS_N)) { $ct++; if ($ct == $i+1) @@ -1040,7 +1163,8 @@ function show_table(&$room, &$user, $sendstep, $is_transition, $is_again) $ontabl = array(-1,-1,-1,-1,-1); $cards = array(); - for ($i = 0 ; $i < 40 ; $i++) { + for ($i = 0 ; $i < (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) ; $i++) { + // for ($i = 0 ; $i < 40 ; $i++) { if ($table->card[$i]->stat == 'hand') { if ($table->card[$i]->owner == $table_pos) { $cards[$inhand[$table->card[$i]->owner]] = $table->card[$i]->value; @@ -1073,7 +1197,7 @@ function show_table(&$room, &$user, $sendstep, $is_transition, $is_again) for ($i = 0 ; $i < BRISKIN5_PLAYERS_N ; $i++) { /* Qui sotto al posto di + 1 c'era + ->gstart ... credo in modo errato */ $ret .= sprintf('cards_dispose(%d,%d,%d);', $i, - $inhand[$i], $taked[$i]); + ($inhand[$i] <= 8 ? $inhand[$i] : 8) , $taked[$i]); if ($ontabl[$i] != -1) { $ret .= sprintf('card_place(%d,%d,%d,%d,%d);',$i, $inhand[$i], @@ -1095,6 +1219,7 @@ function show_table(&$room, &$user, $sendstep, $is_transition, $is_again) } if (BRISKIN5_PLAYERS_N == 3) $showst .= ",-2,-2"; + $ret .= sprintf('document.title = "Brisk - Tavolo %d (asta)";', $user->table_orig); $ret .= sprintf('show_astat(%s);', $showst); if ($table->asta_win != -1 && $table->asta_win == $table_pos) { @@ -1134,7 +1259,7 @@ function show_table(&$room, &$user, $sendstep, $is_transition, $is_again) else $ret .= "remark_off();"; - /* WHO CALL AND WATH */ + /* WHO CALL AND WHAT */ $ret .= briscola_show($room, $table, $user); } @@ -1150,7 +1275,8 @@ function calculate_winner(&$table) $cur_val = 100; $cur_seed = $table->briscola - ($table->briscola % 10); - for ($i = 0 ; $i < 40 ; $i++) { + for ($i = 0 ; $i < (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) ; $i++) { + // for ($i = 0 ; $i < 40 ; $i++) { if ($table->card[$i]->stat != "table") continue; @@ -1188,8 +1314,10 @@ function calculate_winner(&$table) function show_table_info(&$room, &$table, $table_pos) { + GLOBAL $G_lang, $mlang_bin5_bin5; + $ret = ""; - $user = &$room->user[$table->player[$table_pos]]; + $user = $room->user[$table->player[$table_pos]]; $pnt_min = $table->points_n - MAX_POINTS < 0 ? 0 : $table->points_n - MAX_POINTS; $noty = sprintf(''); @@ -1229,39 +1357,46 @@ function show_table_info(&$room, &$table, $table_pos) if ($win != $fri) { /* MLANG: "
Nell'ultima mano ha chiamato %s, il socio era %s,
", "hanno fatto cappotto EBBRAVI!.
", "dovevano fare %s punti e ne hanno fatti %d: hanno %s.
", "
Nell'ultima mano %s si è chiamato in mano,
", "ha fatto cappotto EBBRAVO!.
", "doveva fare %s punti e ne ha fatti %d: ha %s.
", ($table->old_asta_pnt > 61 ? "almeno ".$table->old_asta_pnt : 'più di 60'), $table->old_pnt, ($wol == 1 ? "vinto" : ($wol == 0 ? "pareggiato" : "perso" */ - $noty .= sprintf("
Nell'ultima mano ha chiamato %s, il socio era %s,
", + + $noty .= sprintf($mlang_bin5_bin5['info_part'][$G_lang], xcape($room->user[$win]->name), xcape($room->user[$fri]->name)); if ($table->old_pnt == 120) { - $noty .= sprintf("hanno fatto cappotto EBBRAVI!.
"); + $noty .= sprintf($mlang_bin5_bin5['info_capp'][$G_lang]); } else { - $noty .= sprintf("dovevano fare %s punti e ne hanno fatti %d: hanno %s.
", - ($table->old_asta_pnt > 61 ? "almeno ".$table->old_asta_pnt : - 'più di 60'), $table->old_pnt, - ($wol == 1 ? "vinto" : ($wol == 0 ? "pareggiato" : "perso"))); + $noty .= sprintf($mlang_bin5_bin5['info_pnt'][$G_lang], + ($table->old_asta_pnt > 61 ? $mlang_bin5_bin5['info_alea'][$G_lang].$table->old_asta_pnt : + $mlang_bin5_bin5['info_more'][$G_lang]), $table->old_pnt, + ($wol == 1 ? $mlang_bin5_bin5['info_win'][$G_lang] : ($wol == 0 ? $mlang_bin5_bin5['info_peer'][$G_lang] : $mlang_bin5_bin5['info_lost'][$G_lang]))); } } else { - $noty .= sprintf("
Nell'ultima mano %s si è chiamato in mano,
", + $noty .= sprintf($mlang_bin5_bin5['info_alon'][$G_lang], xcape($room->user[$win]->name)); if ($table->old_pnt == 120) { - $noty .= sprintf("ha fatto cappotto EBBRAVO!.
"); + $noty .= sprintf($mlang_bin5_bin5['info_acap'][$G_lang]); } else { - $noty .= sprintf("doveva fare %s punti e ne ha fatti %d: ha %s.
", - ($table->old_asta_pnt > 61 ? "almeno ".$table->old_asta_pnt : - 'più di 60'), $table->old_pnt, - ($wol == 1 ? "vinto" : ($wol == 0 ? "pareggiato" : "perso"))); + $noty .= sprintf($mlang_bin5_bin5['info_apnt'][$G_lang], + + ($table->old_asta_pnt > 61 ? $mlang_bin5_bin5['info_alea'][$G_lang].$table->old_asta_pnt : + $mlang_bin5_bin5['info_more'][$G_lang]), $table->old_pnt, + + ($wol == 1 ? $mlang_bin5_bin5['info_win'][$G_lang] : ($wol == 0 ? $mlang_bin5_bin5['info_peer'][$G_lang] : $mlang_bin5_bin5['info_lost'][$G_lang]))); } } + if (($table->old_mult + asta2mult($table->old_asta_pnt)) > 1) { + $noty .= sprintf($mlang_bin5_bin5['info_omul'][$G_lang], multoval($table->old_mult + asta2mult($table->old_asta_pnt))); + } + $noty .= "

"; } /* MLANG: "Fai tu il mazzo,", "Il mazzo a $unam," */ if ($table->mazzo == $table_pos) - $noty .= "Fai tu il mazzo,"; + $noty .= $mlang_bin5_bin5['info_yshuf'][$G_lang]; else { $unam = xcape($room->user[$table->player[$table->mazzo]]->name); - $noty .= "Il mazzo a $unam,"; + $noty .= sprintf($mlang_bin5_bin5['info_shuf'][$G_lang], $unam); } if ($user->subst == 'asta') { @@ -1276,18 +1411,18 @@ function show_table_info(&$room, &$table, $table_pos) /* MLANG: " tocca a te giocare.", " tocca a $unam giocare.", " La partita vale %s.", "torna alla partita" */ if ($curplayer == $table_pos) { - $noty .= " tocca a te giocare."; + $noty .= $mlang_bin5_bin5['info_yturn'][$G_lang]; } else { $unam = xcape($room->user[$table->player[$curplayer]]->name); - $noty .= " tocca a $unam giocare."; + $noty .= sprintf($mlang_bin5_bin5['info_turn'][$G_lang], $unam); } - if ($table->mult > 1) { - $noty .= sprintf(" La partita vale %s.", multoval($table->mult)); + if (($table->mult + asta2mult($table->asta_pnt)) > 1) { + $noty .= sprintf($mlang_bin5_bin5['info_mult'][$G_lang], multoval($table->mult + asta2mult($table->asta_pnt))); } $noty .= "

"; - $ret .= show_notify($noty, 3000, "torna alla partita", 500, 400); + $ret .= show_notify($noty, 3000, $mlang_bin5_bin5['btn_bkgame'][$G_lang], 500, 400); /* NOTE: show_notify($noty, 3000, "torna alla partita", 500, * 130 + ($table->points_n > 0 ? 50 : 0) + * (120 * ($table->points_n / MAX_POINTS))); @@ -1300,11 +1435,11 @@ function show_table_info(&$room, &$table, $table_pos) function table_wellcome($user) { - GLOBAL $table_wellarr; + GLOBAL $table_wellarr, $G_lang; $ret = ""; - for ($i = 0 ; $i < count($table_wellarr) ; $i++) - $ret .= sprintf('chatt_sub("%s", [2, "ChanServ: "],"%s");', "", str_replace('"', '\"', $table_wellarr[$i])); + for ($i = 0 ; $i < count($table_wellarr[$G_lang]) ; $i++) + $ret .= sprintf('chatt_sub("%s", [2, "ChanServ: "],"%s");', "", str_replace('"', '\"', $table_wellarr[$G_lang][$i])); return ($ret); } @@ -1312,18 +1447,24 @@ function table_wellcome($user) function briscola_show($room, $table, $user) { + GLOBAL $G_lang, $mlang_bin5_bin5; $ptnadd = ""; $ret = ""; if ($table->asta_card == 9) - $ptnadd = sprintf("
con %d punti", $table->asta_pnt); + $ptnadd = sprintf($mlang_bin5_bin5['call_wptn'][$G_lang], $table->asta_pnt); /* text of caller cell */ - if ($user->table_pos == $table->asta_win) - $ret .= sprintf('$("callerinfo").innerHTML = "Chiami%s:";', $ptnadd); - else - $ret .= sprintf('$("callerinfo").innerHTML = "Chiama %s%s:";', + if ($user->table_pos == $table->asta_win) { + $prestr = sprintf('$("callerinfo").innerHTML = "%s";', $mlang_bin5_bin5['call_ycall'][$G_lang]); + $ret .= sprintf($prestr, $ptnadd); + } + else { + $prestr = sprintf('$("callerinfo").innerHTML = "%s";', $mlang_bin5_bin5['call_call'][$G_lang]); + $ret .= sprintf($prestr, xcape($room->user[$table->player[$table->asta_win]]->name), $ptnadd); + } + $ret .= sprintf('set_iscalling(%d);', ($table->asta_win - $user->table_pos + BRISKIN5_PLAYERS_N) % BRISKIN5_PLAYERS_N); $ret .= sprintf('$("caller").style.backgroundImage = \'url("img/brisk_caller_sand%d.png")\';', $table->asta_win); @@ -1356,4 +1497,17 @@ function game_result($asta_pnt, $pnt) } } +function log_points($curtime, $user, $where, $mesg) +{ + GLOBAL $_SERVER; + + if (($fp = @fopen(LEGAL_PATH."/points.log", 'a')) != FALSE) { + /* Unix time | session | nickname | IP | where was | mesg */ + fwrite($fp, sprintf("%ld|%s|%s|%s|%s|%s|%s|\n", $curtime, $user->sess, + ($user->flags & USER_FLAG_AUTH ? 'A' : 'N'), + $user->name, $_SERVER['REMOTE_ADDR'], $where , $mesg)); + fclose($fp); + } +} + ?>