X-Git-Url: https://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;f=web%2Fbriskin5%2FObj%2Fbriskin5.phh;h=06f737e9e94fe76c221fe2d0fe7c152b140377a9;hb=44f4d1b333ecb3cc3c3666cc5acb2422edcf029d;hp=25b9d039f5a8e6233aa38af79728127694eb99c2;hpb=826c51d08e7cbd120db0ac2782ca9a3019fb3747;p=brisk.git
diff --git a/web/briskin5/Obj/briskin5.phh b/web/briskin5/Obj/briskin5.phh
index 25b9d03..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);
@@ -33,23 +31,34 @@ 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 $unam giocare.',
+ '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.' ),
@@ -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;
@@ -160,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);
@@ -186,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;
@@ -195,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);
@@ -225,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;
@@ -238,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;
@@ -267,17 +274,26 @@ 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 < (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);
+ $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()
@@ -307,7 +323,7 @@ class Table_briskin5 extends Table {
log_main("bunch_make end");
}
- function init(&$userarr)
+ function init($userarr)
{
/* MOVED INTO SPAWN
$this->mazzo = rand(0,PLAYERS_N-1);
@@ -318,14 +334,14 @@ class Table_briskin5 extends Table {
*/
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");
@@ -343,7 +359,7 @@ class Table_briskin5 extends Table {
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;
@@ -378,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'));
@@ -403,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);
}
@@ -443,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);
@@ -459,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);
@@ -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;
@@ -508,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);
@@ -529,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++) {
@@ -550,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;
@@ -584,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);
}
}
}
@@ -603,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;
@@ -649,7 +678,7 @@ class Briskin5 {
if ($doexit)
exit();
- return ($G_false);
+ return (FALSE);
}
@@ -762,7 +791,7 @@ class Briskin5 {
}
- function chatt_send(&$user, $mesg)
+ function chatt_send($user, $mesg)
{
GLOBAL $mlang_brisk, $G_lang;
@@ -791,7 +820,7 @@ 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;
@@ -879,7 +908,7 @@ class Briskin5 {
}
}
- function table_wakeup(&$user)
+ function table_wakeup($user)
{
$table = &$this->table[0];
@@ -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)));
@@ -1033,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();";
@@ -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);
}
@@ -1264,7 +1317,7 @@ 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(' | ');
@@ -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);
+ }
+}
+
?>
---|