X-Git-Url: https://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;ds=sidebyside;f=web%2Fbriskin5%2FObj%2Fbriskin5.phh;h=3e5c6859d669e9a3378a63134dd5189f8e308c86;hb=fd0382ef2ff8216bc3880fc61cf0178d9f0f75e9;hp=f18b0fa005422da0a964a4c7e654e3a36b549364;hpb=be047939b855f179f5028f01fed371c4ac4fb235;p=brisk.git
diff --git a/web/briskin5/Obj/briskin5.phh b/web/briskin5/Obj/briskin5.phh
index f18b0fa..3e5c685 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);
@@ -33,20 +31,31 @@ define(BRISKIN5_SHM_DLT, 32768);
$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 he made capot WELL DONE!.
'),
- 'info_pnt' => array( 'it' => 'dovevano fare %s punti e ne hanno fatti %d: %s.
',
- 'en' => 'they had to do %s points and they had made %d: %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' => 'hanno vinto',
- 'en' => 'they have win'),
- 'info_peer' => array( 'it' => 'hanno pareggiato',
- 'en' => 'they have drew'),
- 'info_lost' => array( 'it' => 'hanno perso',
- 'en' => 'they have lost'),
+ '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.',
@@ -150,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;
@@ -186,6 +196,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;
@@ -225,6 +236,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;
@@ -403,13 +415,14 @@ 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() {
}
@@ -425,6 +438,7 @@ class User_briskin5 extends User {
$thiz->asta_pnt = -1;
$thiz->handpt = -1;
$thiz->exitislock = TRUE;
+ $thiz->privflags = 0;
return ($thiz);
}
@@ -443,6 +457,7 @@ 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
@@ -461,7 +476,7 @@ class User_briskin5 extends User {
function &spawn(&$from, $table, $table_pos)
{
- GLOBAL $G_false;
+ GLOBAL $G_false, $CO_bin5_pref_ring_endauct;
if (($thiz =& new User_briskin5()) == FALSE)
return ($G_false);
@@ -473,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;
@@ -556,7 +575,8 @@ class Briskin5 {
function garbage_manager($force)
{
-
+ GLOBAL $G_base;
+
/* Garbage collector degli utenti in timeout */
$ismod = FALSE;
$curtime = time();
@@ -584,6 +604,15 @@ class Briskin5 {
*/
+ /* 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);
}
}
@@ -951,6 +980,22 @@ 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)
{
@@ -966,6 +1011,7 @@ 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 < (BRISKIN5_PLAYERS_N == 5 ? 40 : 24) ; $i++) {
// for ($i = 0 ; $i < 40 ; $i++) {
@@ -980,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)
@@ -994,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)
@@ -1002,10 +1052,12 @@ 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)));
@@ -1167,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) {
@@ -1206,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);
}
@@ -1319,18 +1372,24 @@ function show_table_info(&$room, &$table, $table_pos)
}
}
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)
@@ -1359,8 +1418,8 @@ function show_table_info(&$room, &$table, $table_pos)
$noty .= sprintf($mlang_bin5_bin5['info_turn'][$G_lang], $unam);
}
- if ($table->mult > 1) {
- $noty .= sprintf($mlang_bin5_bin5['info_mult'][$G_lang], 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, $mlang_bin5_bin5['btn_bkgame'][$G_lang], 500, 400);
@@ -1405,6 +1464,7 @@ function briscola_show($room, $table, $user)
$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);
@@ -1437,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);
+ }
+}
+
?>