X-Git-Url: https://mop.ddnsfree.com/gitweb/?a=blobdiff_plain;f=web%2FObj%2Fbrisk.phh;h=cf6b8246c734ac817648ded54c07880298265241;hb=9facf6a8c63b14f22736b12855900fe89456f379;hp=ea4350c307675f8033d41a41131409a7e46e4ce3;hpb=9cabbe94c242e1a7fa55cc2842525678b425828b;p=brisk.git diff --git a/web/Obj/brisk.phh b/web/Obj/brisk.phh index ea4350c..cf6b824 100644 --- a/web/Obj/brisk.phh +++ b/web/Obj/brisk.phh @@ -27,7 +27,7 @@ define(BRISK_CONF, "brisk.conf.pho"); define(FTOK_PATH, "/var/lib/brisk"); define(LEGAL_PATH, "/tmp/legal_brisk"); define(PROXY_PATH, "/var/lib/brisk_proxy"); -define(TABLES_N, 12); +define(TABLES_N, 32); define(PLAYERS_N, 3); define(MAX_POINTS, 5); define(MAX_PLAYERS, (20 + (PLAYERS_N * TABLES_N))); @@ -48,7 +48,7 @@ define(EXPIRE_TIME_SMAMMA, 360); define(EXPIRE_TIME_WAG, 10); define(WAKEUP_TIME, 12); // BAN_TIME da allineare anche in commons.js -define(BAN_TIME, 900); +define(BAN_TIME, 3600); define(GARBAGE_TIMEOUT, 10); define(NICKSERV, "BriskServ"); @@ -64,7 +64,8 @@ define(DBG_LOAD, 0x0100); define(DBG_AUTH, 0x0200); define(DBG_CRIT, 0x0400); -define(BRISK_DEBUG, 0); +// NOTE: BRISK DEBUG must be a numerical constant, not the result of operations on symbols +define(BRISK_DEBUG, 0xffffffff); define(BRISK_SINGLE_DEBUG,0); define(BRISK_SINGLE_SESS, ""); @@ -73,14 +74,17 @@ define(BRISK_SINGLE_SESS, ""); require_once("$DOCUMENT_ROOT/Etc/".BRISK_CONF); $G_false = FALSE; +$G_lang = "it"; +$G_lng = ""; +// $G_lang = "en"; +// $G_lng = "_en"; $G_all_points = array( 11,10,4,3,2, 0,0,0,0,0 ); -$G_brisk_version = "2.1.1 - trusty"; +$G_brisk_version = "2.1.5 - trusty"; -$root_wellarr = Array ( 'Brisk (Ver. '.$G_brisk_version.'), NOVITA\': Autenticazione e tavoli riservati.', +/* MLANG: ALL THE INFO STRINGS IN brisk.phh */ +$root_wellarr = Array ( 'Brisk (Ver. '.$G_brisk_version.'), NOVITA\': il rendering degli utenti in piedi è stato riscritto.', 'Se vuoi iscriverti alla Mailing List, cliccala!' ); -$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.'); - $G_room_help= '
@@ -105,10 +109,14 @@ Dopo che è iniziata una partita per uscirne dovete chiedere agli altri gi
Comandi della chat
/nick <nuovo_nickname> - cambio di nickname
/tav <frase di invito> - invito per gli altri giocatori al tavolo dove si è seduti +
/st <stato> - cambia l\'icona associata al tuo user; stato può valere: \\"normale\\", \\"fuori\\", \\"pausa\\", \\"cibo\\", \\"cane\\", \\"lavoro\\", \\"presente\\" oppure \\"sigaretta\\" +
/garante - se si è autenticati permette di garantire per un utente fidato
'; +// + $G_room_about= '
@@ -126,6 +134,13 @@ function xcape($s) return (str_replace($from, $to, htmlentities($s,ENT_COMPAT,"UTF-8"))); } +function xcapelt($s) +{ + $from = array ( '\\', '|' ); + $to = array ( '\\\\', '\\|' ); + + return (str_replace($from, $to, $s)); +} class Card { var $value; /* 0 - 39 card value */ @@ -567,6 +582,9 @@ class Table { $act = 'sit'; } } + else { + $act = 'none'; + } } else { if ($table == $cur_table) @@ -588,6 +606,18 @@ class Table { // User flags define(USER_FLAG_AUTH, 0x02); +// user status +define(USER_FLAG_S_NORM, 0x000); // done +define(USER_FLAG_S_PAU, 0x100); // done +define(USER_FLAG_S_OUT, 0x200); // done +define(USER_FLAG_S_DOG, 0x300); // done +define(USER_FLAG_S_EAT, 0x400); // done +define(USER_FLAG_S_WRK, 0x500); // done +define(USER_FLAG_S_SMK, 0x600); // done +define(USER_FLAG_S_EYE, 0x700); // done + +define(USER_FLAG_S_ALL, 0xf00); // done + class User { var $name; // name of the user var $sess; // session of the user @@ -803,7 +833,7 @@ class User { function reset() { $curtime = time(); - log_legal($curtime, $this->sess, $this->name, "STAT:LOGOUT", ''); + log_legal($curtime, $this, "STAT:LOGOUT", ''); $tmp_sess = $this->sess; $this->sess = ""; @@ -876,9 +906,14 @@ class Room { for ($i = 0 ; $i < TABLES_N ; $i++) { $this->table[$i] =& Table::create($i); - $row = ( (((int)($i / 4)) % 2) == 0 ); - $col = ($i % 2 == 0); - $this->table[$i]->auth_only = (($row && $col) || (!$row && !$col)); + if ($i < 12) { + $row = ( (((int)($i / 4)) % 2) == 0 ); + $col = ($i % 2 == 0); + $this->table[$i]->auth_only = (($row && $col) || (!$row && !$col)); + } + else { + $this->table[$i]->auth_only = FALSE; + } } $this->garbage_timeout = 0; } @@ -947,7 +982,7 @@ class Room { $user_cur->bantime = $bri_user->bantime; } - log_legal($curtime, $user_cur->sess, $user_cur->name, "STAT:DESTROY_GAME", $plist); + log_legal($curtime, $user_cur, "STAT:DESTROY_GAME", $plist); $this->room_join_wakeup(&$user_cur, FALSE, 0); $table_cur->table_token = ""; @@ -983,7 +1018,7 @@ class Room { for ($i = 0 ; $i < $table_cur->player_n ; $i++) { $plist .= '|'.$this->user[$table_cur->player[$i]]->sess; } - log_legal($curtime, $user_cur->sess, $user_cur->name, "STAT:DESTROY_GAME(RECOVERY)", $plist); + log_legal($curtime, $user_cur, "STAT:DESTROY_GAME(RECOVERY)", $plist); $this->room_join_wakeup(&$user_cur, TRUE, -2); $table_cur->table_token = ""; @@ -1027,6 +1062,7 @@ class Room { if ($user_cur->stat == 'room' && $user_cur->subst == 'sitdown') { $this->room_wakeup(&$user_cur); $user_cur->comm[$user_cur->step % COMM_N] = "gst.st = ".($user_cur->step+1)."; "; + /* MLANG:
Sei stato inattivo per ".(EXPIRE_TIME_SMAMMA/60.0)." minuti.

Quindi ritorni tra i Giocatori in piedi.", "torna ai tavoli" */ $user_cur->comm[$user_cur->step % COMM_N] .= show_notify("
Sei stato inattivo per ".(EXPIRE_TIME_SMAMMA/60.0)." minuti.

Quindi ritorni tra i Giocatori in piedi.", 0, "torna ai tavoli", 400, 100); $user_cur->step_inc(); } @@ -1387,6 +1423,7 @@ class Room { strncmp($msg, "/tav ", 5) == 0) { do { if ($user->stat != 'room' || $user->subst != 'sitdown') { + /* MLANG: "
Per attivare il messaggio di segnalazione del tavolo occorre essere seduti.

", "
Il messaggio di segnalazione del tavolo è già attivato.

", "
Il messaggio di segnalazione del tavolo
è disattivato ancora per %d second%s.

" */ $msg = "
Per attivare il messaggio di segnalazione del tavolo occorre essere seduti.

"; $to_user = show_notify($msg, 0, "chiudi", 400, 100); @@ -1432,22 +1469,33 @@ class Room { } do { if (strncmp($msg, $alarm_check, strlen($alarm_check)) != 0) { + /* MLANG: "
La password digitata non è corretta.

" */ $msg = "
La password digitata non è corretta.

"; $to_user = show_notify($msg, 0, "chiudi", 400, 100); break; } + /* MLANG: "Alarm %s inviato a %s." */ $to_user = sprintf('chatt_sub("%s", [2, "%s"],"Alarm %s inviato a %s.");', $dt, NICKSERV, xcape(substr($msg, strlen($alarm_check))), ($target == "" ? "tutti" : xcape($target)) ); $msg = sprintf("
%s

%s


", $dt.NICKSERV, xcape(substr($msg, strlen($alarm_check)))); + /* MLANG: "chiudi" */ $to_all = show_notify($msg, 0, "chiudi", 400, 120); } while (0); } // /alarm chat command - + else if (strncmp($msg, "/garante", 8) == 0) { + if ($user->flags & USER_FLAG_AUTH) { + $to_user = sprintf('authbox(300,200);'); + } + else { + /* MLANG: "Per autenticare qualcuno devi a tua volta essere autenticato.", "Il nickname deve contenere almeno una lettera dell\'alfabeto o una cifra.", "Nickname %s già in uso." */ + $to_user = sprintf('chatt_sub("%s", [2, "%s"],"Per autenticare qualcuno devi a tua volta essere autenticato.");', $dt, NICKSERV); + } + } else if (strncmp($msg, "/nick ", 6) == 0) { log_main("chatt_send BEGIN"); @@ -1471,6 +1519,7 @@ class Room { break; } + /* MLANG: "Non puoi cambiare nick a un tavolo per soli autenticati.", "Il nickname \'%s\' è già registrato, se il suo proprietario si autentificherà verrai rinominato d\'ufficio come ghostN." */ if ($user->flags & USER_FLAG_AUTH) { if (strcasecmp($user->name,$name_new) != 0) { if ($user->subst == 'standup' || ($user->subst != 'standup' && $this->table[$user->table]->auth_only == FALSE)) { @@ -1486,10 +1535,10 @@ class Room { } } $user->name = $name_new; // OK - nick changed - /* se nome gia' in uso, segnala cosa potrebbe capitare */ if (($user->flags & USER_FLAG_AUTH) == 0) { $userdb = new LoginDB(); + /* MLANG: "Il nickname \'%s\' è già registrato, se il suo proprietario si autentificherà verrai rinominato d\'ufficio come ghostN." */ if ($userdb->login_exists($name_new)) { $to_user .= sprintf('chatt_sub("%s", [2, "%s"],"Il nickname \'%s\' è già registrato, se il suo proprietario si autentificherà verrai rinominato d\'ufficio come ghostN.");', $dt, NICKSERV, xcape($name_new)); } @@ -1501,6 +1550,50 @@ class Room { } while (0); } // nick chat command + else if (strncmp($msg, "/st ", 4) == 0) { + log_main("chatt_send BEGIN"); + + do { + $st_str = substr($msg, 4); + + if (strcasecmp($st_str, "normale") == 0) { + $st = USER_FLAG_S_NORM; + } + else if (strcasecmp($st_str, "pausa") == 0) { + $st = USER_FLAG_S_PAU; + } + else if (strcasecmp($st_str, "fuori") == 0) { + $st = USER_FLAG_S_OUT; + } + else if (strcasecmp($st_str, "cane") == 0) { + $st = USER_FLAG_S_DOG; + } + else if (strcasecmp($st_str, "cibo") == 0) { + $st = USER_FLAG_S_EAT; + } + else if (strcasecmp($st_str, "lavoro") == 0) { + $st = USER_FLAG_S_WRK; + } + else if (strcasecmp($st_str, "sigaretta") == 0) { + $st = USER_FLAG_S_SMK; + } + else if (strcasecmp($st_str, "presente") == 0) { + $st = USER_FLAG_S_EYE; + } + else { + /* MLANG: "Questo stato non esiste." */ + $to_user = sprintf('chatt_sub("%s", [2,"%s"],"Questo stato non esiste.");', $dt, NICKSERV); + break; + } + + log_main("chatt_send start set"); + if (($user->flags & USER_FLAG_S_ALL) != $st) { + $update_room = TRUE; + $user->flags = ($user->flags & ~USER_FLAG_S_ALL) | $st; + } + } while (0); + } // nick chat command + else { // normal chat line if ($curtime < ($user->chat_ban + $user->chat_dlt)) { $only_you = TRUE; @@ -1530,7 +1623,7 @@ class Room { $to_room = $to_user; } - log_legal($curtime, $user->sess, $user->name, + log_legal($curtime, $user, ($user->stat == 'room' ? 'room' : 'table '.$user->table),$msg); $user->chat_lst = "$msg"; @@ -1727,7 +1820,7 @@ class Room { log_auth("XXX", sprintf("TROVATO A QUESTO PUNTO [%d] sess [%s] name [%s]", $idx, $sess, $name_new)); - if ($ghost > -1 && $authenticate) { + if ($ghost > -1 && $ghost_auth && $authenticate) { /* swap session */ $ghost_user =& $this->user[$ghost]; @@ -1954,13 +2047,11 @@ class Room { // echo "LOCK: ".FTOK_PATH."/main"; // exit; if (($tok = @ftok(FTOK_PATH."/main", "B")) == -1) { - echo "FTOK FAILED"; - exit; + return (FALSE); } // echo "FTOK ".$tok."
"; if (($res = sem_get($tok)) == FALSE) { - echo "SEM_GET FAILED"; - exit; + return (FALSE); } if (sem_acquire($res)) { log_lock("LOCK room"); @@ -2010,7 +2101,7 @@ class Room { $flags |= 1; } - $content .= sprintf('%s[ %d, \'%s\' ]',($ct > 0 ? ', ' : ''), $flags, xcape($this->user[$e]->name)); + $content .= sprintf('%s[ %d, "%s" ]',($ct > 0 ? ', ' : ''), $flags, xcape($this->user[$e]->name)); $ct++; } } @@ -2083,7 +2174,7 @@ class Room { log_main($user_cur->name. sprintf(" IN TABLE [%d]", $table_idx)); - $content .= sprintf('%s[ %d, \'%s\' ]',($i == 0 ? '' : ', '), $flags, xcape($user_cur->name)); + $content .= sprintf('%s[ %d, "%s" ]',($i == 0 ? '' : ', '), $flags, xcape($user_cur->name)); } $content .= ' ]'; @@ -2316,13 +2407,16 @@ function log_auth($sess, $log) { } -function log_legal($curtime, $sess, $name, $where, $mesg) +// function log_legal($curtime, $sess, $name, $where, $mesg) +function log_legal($curtime, &$user, $where, $mesg) { GLOBAL $_SERVER; if (($fp = @fopen(LEGAL_PATH."/legal.log", 'a')) != FALSE) { /* Unix time | session | nickname | IP | where was | mesg */ - fwrite($fp, sprintf("%ld|%s|%s|%s|%s|%s|\n", $curtime, $sess, $name, $_SERVER['REMOTE_ADDR'], $where , $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); } } @@ -2400,52 +2494,6 @@ function show_notify($text, $tout, $butt, $w, $h) return sprintf('var noti = new notify(gst,"%s",%d,"%s",%d,%d);', $text, $tout, $butt, $w, $h); } -function briscola_show($room, $table, $user) -{ - $ptnadd = ""; - $ret = ""; - - if ($table->asta_card == 9) - $ptnadd = sprintf("
con %d punti", $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:";', - xcape($room->user[$table->player[$table->asta_win]]->name), $ptnadd); - - $ret .= sprintf('$("caller").style.backgroundImage = \'url("img/brisk_caller_sand%d.png")\';', - $table->asta_win); - $ret .= sprintf('$("callerimg").src = "img/%02d.png";', $table->briscola); - $ret .= sprintf('$("caller").style.visibility = "visible";'); - $ret .= sprintf('$("chooseed").style.visibility = "hidden";'); - $ret .= sprintf('$("astalascio").style.visibility = "";'); - $ret .= sprintf('$("asta").style.visibility = "hidden";'); - $ret .= sprintf('show_astat(-2,-2,-2,-2,-2);'); - - return ($ret); -} - - -function game_result($asta_pnt, $pnt) -{ - if ($asta_pnt == 61) { - if ($pnt > 60) - return (1); - else if ($pnt == 60) - return (0); - else - return (-1); - } - else { - if ($pnt >= $asta_pnt) - return (1); - else - return (-1); - } -} - function multoval($mult) { if ($mult == 2) @@ -2456,113 +2504,6 @@ function multoval($mult) return (sprintf("%d-plo", $mult)); } -function show_table_info(&$room, &$table, $table_pos) -{ - $ret = ""; - $user = &$room->user[$table->player[$table_pos]]; - - $pnt_min = $table->points_n - MAX_POINTS < 0 ? 0 : $table->points_n - MAX_POINTS; - $noty = sprintf(''); - - // Names. - for ($i = 0 ; $i < PLAYERS_N ; $i++) - $noty .= sprintf('', xcape($room->user[$table->player[$i]]->name)); - $noty .= sprintf(""); - - // Points. - log_main("show_table_info: pnt_min: ".$pnt_min." Points_n: ".$table->points_n); - - for ($i = $pnt_min ; $i < $table->points_n ; $i++) { - $noty .= sprintf('', $i+1); - for ($e = 0 ; $e < PLAYERS_N ; $e++) - $noty .= sprintf('', $table->points[$i % MAX_POINTS][$e]); - $noty .= ""; - } - - // Total points. - $noty .= ''; - for ($e = 0 ; $e < PLAYERS_N ; $e++) - $noty .= sprintf('', $table->total[$e]); - $noty .= "
%s
%d%d
Tot.%d
"; - - if ($table->old_reason != "") { - $noty .= sprintf("
%s
", xcape($table->old_reason)); - } - - if ($table->old_win != -1) { - $win = $table->player[$table->old_win]; - $fri = $table->player[$table->old_friend]; - - $wol = game_result($table->old_asta_pnt, $table->old_pnt); - - if ($win != $fri) { - $noty .= sprintf("
Nell'ultima mano ha chiamato %s, il socio era %s,
", - xcape($room->user[$win]->name), - xcape($room->user[$fri]->name)); - if ($table->old_pnt == 120) { - $noty .= sprintf("hanno fatto cappotto EBBRAVI!.
"); - } - 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"))); - } - } - else { - $noty .= sprintf("
Nell'ultima mano %s si è chiamato in mano,
", - xcape($room->user[$win]->name)); - if ($table->old_pnt == 120) { - $noty .= sprintf("ha fatto cappotto EBBRAVO!.
"); - } - 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"))); - } - } - } - if ($table->mazzo == $table_pos) - $noty .= "Fai tu il mazzo,"; - else { - $unam = xcape($room->user[$table->player[$table->mazzo]]->name); - $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($room->user[$table->player[$curplayer]]->name); - $noty .= " tocca a $unam giocare."; - } - - if ($table->mult > 1) { - $noty .= sprintf(" La partita vale %s.", multoval($table->mult)); - } - $noty .= "

"; - $ret .= show_notify($noty, 3000, "torna alla partita", 500, 400); - /* NOTE: show_notify($noty, 3000, "torna alla partita", 500, - * 130 + ($table->points_n > 0 ? 50 : 0) + - * (120 * ($table->points_n / MAX_POINTS))); - * will be used when we refact notify js function following - * photoo class logic - */ - - return ($ret); -} function root_wellcome($user) { @@ -2578,318 +2519,7 @@ function root_wellcome($user) return ($ret); } -function table_wellcome($user) -{ - GLOBAL $table_wellarr; - $ret = ""; - - for ($i = 0 ; $i < count($table_wellarr) ; $i++) - $ret .= sprintf('chatt_sub("%s", [2, "ChanServ: "],"%s");', "", str_replace('"', '\"', $table_wellarr[$i])); - - return ($ret); -} - - - -/* show table -is_transition (is from room to table ?) -is_again (is another game) - -Examples 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(&$room, &$user, $sendstep, $is_transition, $is_again) -{ - $table_idx = $user->table; - $table = &$room->table[$table_idx]; - $table_pos = $user->table_pos; - - $ret = "table_init();"; - $ret .= $table->exitlock_show(&$room->user, $table_pos); - if (!$is_again) { - /* GENERAL STATUS */ - $ret .= sprintf( 'gst.st = %d; stat = "%s"; subst = "%s"; table_pos = %d;', - $sendstep, $user->stat, $user->subst, $table_pos); - - log_rd(sprintf( 'SHOW_TABLE: gst.st = %d; stat = "%s"; subst = "%s"; table_pos = %d;', - $sendstep, $user->stat, $user->subst, $table_pos)); - - /* BACKGROUND */ - $ret .= "background_set();"; - - /* USERS INFO */ - $itin = ($user->flags & USER_FLAG_AUTH ? "" : ""); - $itou = ($user->flags & USER_FLAG_AUTH ? "" : ""); - - $ret .= sprintf('$("myname").innerHTML = "%s%s%s";', $itin, xcape($user->name), $itou); - $ret .= sprintf('set_names([%d, "%s"], [%d, "%s"], [%d, "%s"], [%d, "%s"], [%d, "%s"]); ', - $room->user[$table->player[($table_pos)%PLAYERS_N]]->flags, - xcape($room->user[$table->player[($table_pos)%PLAYERS_N]]->name), - $room->user[$table->player[($table_pos+1)%PLAYERS_N]]->flags, - xcape($room->user[$table->player[($table_pos+1)%PLAYERS_N]]->name), - - $room->user[$table->player[($table_pos+2)%PLAYERS_N]]->flags, - xcape($room->user[$table->player[($table_pos+2)%PLAYERS_N]]->name), - - (PLAYERS_N == 3 ? 0 : $room->user[$table->player[($table_pos+3)%PLAYERS_N]]->flags), - (PLAYERS_N == 3 ? "" : xcape($room->user[$table->player[($table_pos+3)%PLAYERS_N]]->name)), - - (PLAYERS_N == 3 ? 0 : $room->user[$table->player[($table_pos+4)%PLAYERS_N]]->flags), - (PLAYERS_N == 3 ? "" : xcape($room->user[$table->player[($table_pos+4)%PLAYERS_N]]->name))); - } - /* NOTIFY FOR THE CARD MAKER */ - if ($is_transition) { // && $user->subst == "asta" superfluo - $ret .= show_table_info(&$room, &$table, $table_pos); - } - if (!$is_again) - $ret .= table_wellcome($user); - - if ($is_transition && !$is_again) { // appena seduti al tavolo, play della mucca - $ret .= playsound("cow.mp3"); - } - - - /* CARDS */ - if ($is_transition) { // && $user->subst == "asta" superfluo - $ret .= "|"; - - for ($i = 0 ; $i < 8 ; $i++) { - for ($e = 0 ; $e < PLAYERS_N ; $e++) { - $ct = 0; - for ($o = 0 ; $o < 40 && $ct < $i+1 ; $o++) { - if ($table->card[$o]->owner == (($e + $table->gstart) % PLAYERS_N)) { - $ct++; - if ($ct == $i+1) - break; - } - } - log_rd("O ".$o." VAL ".$table->card[$o]->value." Owner: ".$table->card[$o]->owner); - - $ret .= sprintf( ' card_send(%d,%d,%d,%8.2f,%d);|', ($table->gstart + $e) % PLAYERS_N, - $i, ((($e + PLAYERS_N - $table_pos + $table->gstart) % PLAYERS_N) == 0 ? - $table->card[$o]->value : -1), - ($i == 7 && $e == (PLAYERS_N - 1) ? 1 : 0.5),$i+1); - } - } - } - else { - $taked = array(0,0,0,0,0); - $inhand = array(0,0,0,0,0); - $ontabl = array(-1,-1,-1,-1,-1); - $cards = array(); - - 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; - } - $inhand[$table->card[$i]->owner]++; - } - else if ($table->card[$i]->stat == 'take') { - log_main("Card taked: ".$table->card[$i]->value."OWN: ".$table->card[$i]->owner); - $taked[$table->card[$i]->owner]++; - } - else if ($table->card[$i]->stat == 'table') { - $ontabl[$table->card[$i]->owner] = $i; - } - } - $logg = "\n"; - for ($i = 0 ; $i < PLAYERS_N ; $i++) { - $logg .= sprintf("INHAND: %d IN TABLE %d TAKED %d\n", $inhand[$i], $ontabl[$i], $taked[$i]); - } - log_main("Stat table: ".$logg); - - /* Set ours cards. */ - $oursarg = ""; - for ($i = 0 ; $i < $inhand[$table_pos] ; $i++) - $oursarg .= ($i == 0 ? "" : ", ").$cards[$i]; - for ($i = $inhand[$table_pos] ; $i < 8 ; $i++) - $oursarg .= ($i == 0 ? "" : ", ")."-1"; - $ret .= sprintf('card_setours(%s);', $oursarg); - - /* Dispose all cards */ - for ($i = 0 ; $i < 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]); - - if ($ontabl[$i] != -1) { - $ret .= sprintf('card_place(%d,%d,%d,%d,%d);',$i, $inhand[$i], - $table->card[$ontabl[$i]]->value, - $table->card[$ontabl[$i]]->x, $table->card[$ontabl[$i]]->y); - } - } - } - - /* Show auction */ - if ($user->subst == 'asta') { - - /* show users auction status */ - $showst = ""; - for ($i = 0 ; $i < PLAYERS_N ; $i++) { - $user_cur = &$room->user[$table->player[$i]]; - $showst .= sprintf("%s%d", ($i == 0 ? "" : ", "), - ($user_cur->asta_card < 9 ? $user_cur->asta_card : $user_cur->asta_pnt)); - } - if (PLAYERS_N == 3) - $showst .= ",-2,-2"; - $ret .= sprintf('show_astat(%s);', $showst); - - if ($table->asta_win != -1 && $table->asta_win == $table_pos) { - /* show card chooser */ - $ret .= sprintf('choose_seed(%s); $("astalascio").style.visibility = ""; $("asta").style.visibility = "hidden";', - $table->asta_card); - } - else { - /* show auction */ - if ($table_pos == ($table->gstart % PLAYERS_N) && - $table->asta_win == -1) - $ret .= sprintf('dispose_asta(%d,%d, %s);', - $table->asta_card + 1, $table->asta_pnt+1, ($user->handpt <= 2 ? "true" : "false")); - else - $ret .= sprintf('dispose_asta(%d,%d, %s);', - $table->asta_card + 1, -($table->asta_pnt+1), ($user->handpt <= 2 ? "true" : "false")); - } - - /* Remark */ - if ($table->asta_win == -1) { // auction case - if ($table_pos == ($table->gstart % PLAYERS_N)) - $ret .= "remark_on();"; - else - $ret .= "remark_off();"; - } - else { // chooseed case - if ($table_pos == $table->asta_win) - $ret .= "remark_on();"; - else - $ret .= "remark_off();"; - } - } - else if ($user->subst == 'game') { - /* HIGHLIGHT */ - if (($table->gstart + $table->turn) % PLAYERS_N == $table_pos) - $ret .= "is_my_time = true; remark_on();"; - else - $ret .= "remark_off();"; - - /* WHO CALL AND WATH */ - $ret .= briscola_show($room, $table, $user); - - } - return ($ret); -} // end function show_table(... - -function calculate_winner(&$table) -{ - $briontab = FALSE; - $ontab = array(); - $ontid = array(); - $cur_win = -1; - $cur_val = 100; - $cur_seed = $table->briscola - ($table->briscola % 10); - - for ($i = 0 ; $i < 40 ; $i++) { - if ($table->card[$i]->stat != "table") - continue; - - log_wr(sprintf("Card On table: [%d]", $i)); - - $v = $table->card[$i]->value; - $ontab[$table->card[$i]->owner] = $v; - $ontid[$table->card[$i]->owner] = $i; - /* se briscola setto il flag */ - if (($v - ($v % 10)) == $cur_seed) - $briontab = TRUE; - } - - if ($briontab == FALSE) { - $cur_win = $table->gstart; - $cur_val = $ontab[$cur_win]; - $cur_seed = $cur_val - ($cur_val % 10); - } - - for ($i = 0 ; $i < PLAYERS_N ; $i++) { - if (($ontab[$i] - ($ontab[$i] % 10)) == $cur_seed) { - if ($ontab[$i] < $cur_val) { - $cur_val = $ontab[$i]; - $cur_win = $i; - } - } - } - - for ($i = 0 ; $i < PLAYERS_N ; $i++) { - $table->card[$ontid[$i]]->owner = $cur_win; - $table->card[$ontid[$i]]->stat = "take"; // Card stat - } - return ($cur_win); -} - -function calculate_points(&$table) -{ - GLOBAL $G_all_points; - - $pro = 0; - - if ($table->asta_pnt == 60) - $table->asta_pnt = 61; - - $table->old_reason = ""; - $table->old_win = $table->asta_win; - $table->old_friend = $table->friend; - $table->old_asta_pnt = $table->asta_pnt; - - 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) - $pro += $G_all_points[$ctt]; - } - - log_wr(sprintf("PRO: [%d]", $pro)); - - - if ($table->asta_pnt == 61 && $pro == 60) { // PATTA ! - $table->points[$table->points_n % MAX_POINTS] = array(); - for ($i = 0 ; $i < PLAYERS_N ; $i++) - $table->points[$table->points_n % MAX_POINTS][$i] = 0; - $table->points_n++; - $table->old_pnt = $pro; - $table->mult *= 2; - - return; - } - - if ($pro >= $table->asta_pnt) - $sig = 1; - else - $sig = -1; - - $table->points[$table->points_n % MAX_POINTS] = array(); - for ($i = 0 ; $i < 5 ; $i++) { - if ($i == $table->asta_win) - $pt = ($i == $table->friend ? 4 : 2); - else if ($i == $table->friend) - $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); - - 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; - } - $table->points_n++; - $table->old_pnt = $pro; - $table->mult = 1; -} function validate_sess($sess) { @@ -2943,5 +2573,35 @@ function sharedmem_sz($tok) return ($shm_sz); } +class Warrant { + function lock_data() + { + GLOBAL $sess; + + if (($tok = @ftok(FTOK_PATH."/warrant", "B")) == -1) { + return (FALSE); + } + // echo "FTOK ".$tok."
"; + if (($res = sem_get($tok)) == FALSE) { + return (FALSE); + } + if (sem_acquire($res)) { + log_lock("LOCK room"); + return ($res); + } + else + return (FALSE); + } + + function unlock_data($res) + { + GLOBAL $sess; + + log_lock("UNLOCK room"); + + return (sem_release($res)); + } + +} ?>