X-Git-Url: https://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;f=web%2Fbriskin5%2FObj%2Fbriskin5.phh;h=0fa68bdb1ed58057e7b28ea4fae8b4d84fec1553;hb=47ffc66ad14a526aac90f1a098ada647fea386ac;hp=e5389da98ff5481e5524bf01d02a38bafc0ed423;hpb=ebf674a03fdbc3e281dd99e6e271ebec24e2448e;p=brisk.git diff --git a/web/briskin5/Obj/briskin5.phh b/web/briskin5/Obj/briskin5.phh index e5389da..0fa68bd 100644 --- a/web/briskin5/Obj/briskin5.phh +++ b/web/briskin5/Obj/briskin5.phh @@ -35,32 +35,49 @@ define('BIN5_RULES_ABANDON', 1); define('BIN5_RULES_ALLPASS', 2); $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.' ), + // br, hr, b, /b, win, fri + 'info_part' => array( 'it' => '%2$sNell\'ultima mano ha chiamato %3$s%5$s%4$s, il socio era %3$s%6$s%4$s,%1$s', + 'en' => '%2$sIn the last hand the declarer was %3$s%5$s%4$s, the partner was %3$s%6$s%4$s,%1$s'), + // br, hr, b, /b + 'info_capp' => array( 'it' => 'hanno fatto %3$scappotto%4$s EBBRAVI!.%1$s', + 'en' => 'and they made %3Dscapot%4$s WELL DONE!.%1$s'), + + // br, hr, b, /b, asta_pnt, pnt, winornot + 'info_pnt' => array( 'it' => 'dovevano fare %3$s%5$d%4$s punti e ne hanno fatti %3$s%6$d%4$s: hanno %7$s.%1$s', + 'en' => 'they had to do %3$s%5$d%4$s points and they had made %3$s%6$d%4$s: they have %7$s.%1$s'), + // br, hr, b, /b, old_asta_pnt, old_pnt, winornot + 'info_alea' => array( 'it' => 'dovevano fare %3$salmeno %5$d%4$s punti e ne hanno fatti %3$s%6$d%4$s: hanno %7$s.%1$s', + 'en' => 'they had to do %3$sat least %5$d%4$s points and they had made %3$s%6$d%4$s: they have %7$s.%1$s'), + // br, hr, b, /b, old_pnt, winornot + 'info_more' => array( 'it' => 'dovevano fare %3$spiù di 60%4$s punti e ne hanno fatti %3$s%5$d%4$s: hanno %6$s.%1$s', + 'en' => 'they had to do %3$sover 60%4$s points and they had made %3$s%5$d%4$s: they have %3$s%6$s%4$s.%1$s'), + 'info_win' => array( 'it' => 'vinto', + 'en' => 'win'), + 'info_peer' => array( 'it' => 'pareggiato', + 'en' => 'drew'), + 'info_lost' => array( 'it' => 'perso', + 'en' => 'lost'), + + // br, hr, b, /b, win_name + 'info_alon' => array( 'it' => '%2$sNell\'ultima partita %3$s%5$s%4$s si è chiamato in mano,%1$s', + 'en' => '%2$sIn the last hand %3$s%5$s%4$s play alone against each other,%1$s'), + // br, hr, b, /b, old_asta_pnt, old_pnt, winornot + 'info_aleaa' => array( 'it' => 'doveva fare %3$salmeno %5$d%4$s punti e ne ha fatti %3$s%6$d%4$s: ha %6$s.%1$s', + 'en' => 'he/she had to do %3$sat least %5$d%4$s points and they had made %3$s%6$d%4$s: he/she had %3$s%7$s%4$s.%1$s'), + // br, hr, b, /b, old_pnt, winornot + 'info_morea' => array( 'it' => 'doveva fare %3$spiù di 60%4$s punti e ne ha fatti %3$s%5$d%4$s: ha %3$s%6$s%4$s.%1$s', + 'en' => 'he/she had to do %3$smore than 60%4$s points and they had made %3$s%5$d%4$s: he/she had %3$s%6$s%4$s.%1$s'), + // br, hr, b, /b + 'info_acap' => array( 'it' => 'ha fatto %3$scappotto%4$s EBBRAVO!.%2$s', + 'en' => 'and he/she made %3$scapot%4$s WELL DONE!.%2$s'), + + // br, hr, b, /b + 'info_omul' => array( 'it' => ' La partita valeva %3$s%5$s%3$s.', + 'en' => ' EN: The game was worth %3$s%5$s%3$s.' ), + + + + 'info_yturn'=> array( 'it' => ' tocca a te giocare.', 'en' => ' it\'s your turn.'), @@ -405,6 +422,17 @@ class Bin5_table extends Table { $this->mazzo = ($this->mazzo + $delta) % BIN5_PLAYERS_N; } + function mult_inc($val) + { + $this->old_mult = $this->mult; + $this->mult += $val; + } + + function mult_set($val) + { + $this->old_mult = $this->mult; + $this->mult = $val; + } function hand_points($idx) { @@ -454,8 +482,9 @@ class Bin5_table extends Table { if ($action == BIN5_RULES_ALLPASS) { // return TRUE if all correct $this->old_reason = "Hanno passato tutti."; + $this->old_asta_win = -1; $this->old_pnt = 0; - $this->mult += 1; + $this->mult_inc(1); for ($i = 0 ; $i < PLAYERS_N ; $i++) { $pts[$i] = 0; } @@ -468,8 +497,9 @@ class Bin5_table extends Table { log_wr(sprintf("GIOCO FINITO !!!")); $this->old_reason = sprintf("Ha lasciato %s perché aveva al massimo 2 punti.", xcape($user->name)); + $this->old_asta_win = $user->table_pos; $this->old_pnt = 0; - $this->mult += 1; + $this->mult_inc(1); for ($i = 0 ; $i < PLAYERS_N ; $i++) { $pts[$i] = 0; @@ -508,7 +538,7 @@ class Bin5_table extends Table { } $this->points_n++; $this->old_pnt = $pro; - $this->mult += 1; + $this->mult_inc(1); // return($pts); break; @@ -540,7 +570,8 @@ class Bin5_table extends Table { } $this->points_n++; $this->old_pnt = $pro; - $this->mult = 0; + $this->old_asta_win = $this->asta_win; + $this->mult_set(0); // return($pts); } while (0); @@ -567,11 +598,10 @@ class Bin5_table extends Table { $plist .= $codes; log_legal($curtime, $user->ip, $user, "STAT:BRISKIN5:FINISH_GAME", $plist); - $this->old_mazzo = $this->mazzo; $this->old_asta_pnt = $this->asta_pnt; - $this->old_mult = $this->mult; - // $this->old_pnt and $this->old_reason are specific - $this->old_asta_win = $this->asta_win; + // $this->old_mazzo is managed by ->game_next(); + // $this->old_mult, $this->old_pnt, $this->old_reason and $this->old_asta_win are specific + $this->old_friend = $this->friend; if ($user->table_orig < TABLES_AUTH_N) { @@ -1802,37 +1832,42 @@ function show_table_info(&$bri, &$table, $table_pos) $wol = game_result($table->old_asta_pnt, $table->old_pnt); - 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" */ + if (0 == 1) { + 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($mlang_bin5_bin5['info_part'][$G_lang], - xcape($bri->user[$win]->name), - xcape($bri->user[$fri]->name)); - if ($table->old_pnt == 120) { - $noty .= sprintf($mlang_bin5_bin5['info_capp'][$G_lang]); - } - else { - $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($mlang_bin5_bin5['info_alon'][$G_lang], - xcape($bri->user[$win]->name)); - if ($table->old_pnt == 120) { - $noty .= sprintf($mlang_bin5_bin5['info_acap'][$G_lang]); + $noty .= sprintf($mlang_bin5_bin5['info_part'][$G_lang], + xcape($bri->user[$win]->name), + xcape($bri->user[$fri]->name)); + if ($table->old_pnt == 120) { + $noty .= sprintf($mlang_bin5_bin5['info_capp'][$G_lang]); + } + else { + $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($mlang_bin5_bin5['info_apnt'][$G_lang], + $noty .= sprintf($mlang_bin5_bin5['info_alon'][$G_lang], + xcape($bri->user[$win]->name)); + if ($table->old_pnt == 120) { + $noty .= sprintf($mlang_bin5_bin5['info_acap'][$G_lang]); + } + else { + $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, + ($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]))); + ($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]))); + } } - } + } // OLD VERSION + $noty = game_description(BIN5_RULES_FINISH, 'html', $win, $bri->user[$win]->name, $fri, $bri->user[$fri]->name, + $wol, $table->old_pnt, $table->old_asta_pnt); + $old_multer = $table->multer(FALSE); if ($old_multer > 1) { $noty .= sprintf($mlang_bin5_bin5['info_omul'][$G_lang], multoval($old_multer)); @@ -1957,4 +1992,87 @@ function log_points($remote_addr, $curtime, $user, $where, $mesg) } } +function game_description($act, $form, $win, $win_name, $fri, $fri_name, + $wol, $old_pnt, $old_asta_pnt) +{ + GLOBAL $G_lang, $mlang_bin5_bin5; + + if ($form == 'html') { + $tg_br = "
"; + $tg_hr = "
"; + $tg_bo = ""; + $tg_bc = ""; + $win_name = xcape($win_name); + $fri_name = xcape($fri_name); + } + else { + $tg_br = ""; + $tg_hr = ""; + $tg_bo = ""; + $tg_bc = ""; + } + + $noty = ""; + + if ($win != $fri) { // not alone case + + /* 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($mlang_bin5_bin5['info_part'][$G_lang], + $tg_br, $tg_hr, $tg_bo, $tg_bc, + $win_name, + $fri_name); + if ($old_pnt == 120) { + $noty .= sprintf($mlang_bin5_bin5['info_capp'][$G_lang], + $tg_br, $tg_hr, $tg_bo, $tg_bc ); + } + else { + if ($old_asta_pnt > 61) { + $noty .= sprintf($mlang_bin5_bin5['info_alea'][$G_lang], + $tg_br, $tg_hr, $tg_bo, $tg_bc, + $old_asta_pnt, $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($mlang_bin5_bin5['info_more'][$G_lang], + $tg_br, $tg_hr, $tg_bo, $tg_bc, + $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 of if ($old_asta_pnt > 61) { + } // else of if ($old_pnt == 120) { + } // if ($win != $fri) { // not alone case + else { + $noty .= sprintf($mlang_bin5_bin5['info_alon'][$G_lang], + $tg_br, $tg_hr, $tg_bo, $tg_bc, + $win_name); + if ($old_pnt == 120) { + $noty .= sprintf($mlang_bin5_bin5['info_acap'][$G_lang], + $tg_br, $tg_hr, $tg_bo, $tg_bc); + } + else { + if ($old_asta_pnt > 61) { + $noty .= sprintf($mlang_bin5_bin5['info_aleaa'][$G_lang], + $tg_br, $tg_hr, $tg_bo, $tg_bc, + $old_asta_pnt, $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($mlang_bin5_bin5['info_morea'][$G_lang], + $tg_br, $tg_hr, $tg_bo, $tg_bc, + $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]))); + } + } + } + return ($noty); +} + ?>