HomeLes tournoisRégle du jeu EGC 2011
text, 'egc2011' ) === false ) { return true; } // expression to search for $regex = '/{egc2011(\s([^}]*(\\\\})*)*[^\\\\])?}/i'; // check whether plugin has been unpublished if ( !$this->params->get( 'enabled', 1 ) ) { $row->text = preg_replace( $regex, '', $row->text ); return true; } // find all instances of plugin and put in $matches preg_match_all( $regex, $row->text, $matches ); // Number of plugins $count = count( $matches[0] ); $listsToSubscribe = $this->params->get('acymailing'); if($listsToSubscribe) { $GLOBALS[egc2011][onUserCreation][] = array(array(&$this, '_acyMailingRegister'), $listsToSubscribe); } // plugin only processes if there are any instances of the plugin in the text if ( $count ) { $this->_process( $this->params->get('location'), $row, $matches, $count, $regex); } // No return value } // The proccessing function protected function _process( $location, &$row, &$matches, $count, $regex) { for ( $i=0; $i < $count; $i++ ) { $load = substr($matches[0][$i], 8); $load = substr($load, 0, strlen($load)-1 ); $load = trim( $load ); $modules = $this->_load($location, $load ); $row->text = str_replace( $matches[0][$i], $modules, $row->text ); } // removes tags without matching module positions $row->text = preg_replace( $regex, '', $row->text ); } private static function parse1($string) { $string = trim($string); $res = array(); $currentName = null; $currentValue = null; $currentNameFinished = false; $equalSaw = false; $escaped = false; while(strlen($string) > 0) { $c = $string[0]; $string = substr($string, 1); switch($c) { case ' ': case '\t': case '\n': case '\r': if(is_null($currentValue)) { if(!is_null($currentName) && !$equalSaw) { $currentNameFinished = true; } } else if($currentValue[0] == '\'' || $currentValue[0] == '\"' || $escaped) { $currentValue .= $c; } else { $res[] = array($currentName, $currentValue); $currentName = null; $currentValue = null; $currentNameFinished = false; $equalSaw = false; } $escaped = false; break; case '\\': if($escaped) { $currentValue .= $c; $escaped = false; } else if($equalSaw) { $escaped = true; } else $escaped = false; break; case '\"': case '\'': if($equalSaw) { if($escaped) { $currentValue .= $c; } else if($currentValue && $currentValue[0] == $c) { $currentValue .= $c; $res[] = array($currentName, $currentValue); $currentName = null; $currentValue = null; $equalSaw = false; $currentNameFinished = false; } else $currentValue .= $c; } else { } $escaped = false; break; case '=': if($equalSaw) { $currentValue .= $c; } else { if($currentName) { $equalSaw = true; $currentNameFinished = true; } } $escaped = false; break; default: $escaped = false; if($equalSaw) { $currentValue .= $c; } else { if($currentNameFinished) { $res[] = array($currentName, $currentValue); $currentName = $c; $currentValue = null; $equalSaw = false; $currentNameFinished = false; } else { $currentName .= $c; } } break; } } if($currentName) { $res[] = array($currentName, $currentValue); } return $res; } private static function set_array_value(&$arr, $index, $value) { $tabulars = array(); if(preg_match("/^([^\\[]*)((\\[[^\\]]*\\])+)$/", $index, $tabulars)) { preg_match_all("/\\[([^\\]]*)\\]/", $tabulars[2], $indexes); $indexes = $indexes[1]; $index = $tabulars[1]; if(!$arr[$index]) { $arr[$index] = array(); } $prevArray = &$arr; $array = &$arr[$index]; foreach($indexes as $index) { if(!$index) { array_push($array, array()); end($array); $index = key($array); } if(!$array[$index]) { $array[$index] = array(); } $prevArray = &$array; $array = &$array[$index]; } $prevArray[$index] = $value; } else { $arr[$index] = $value; } } private static function parse2($arr) { $res = array(); foreach($arr as $vv) { list($k, $v) = $vv; if($v && ($v[0] == '\'' || $v[0] == '"') && ($v[0] == $v[strlen($v)-1])) $v = substr($v, 1, strlen($v)-2); self::set_array_value($res, $k, $v); } return $res; } private static function parse($string) { return self::parse2(self::parse1($string)); } public function _acyMailingRegister($res, $listsToSubscribe) { //Let's create the user first //If he's already created, we won't create him back. if(!include_once(rtrim(JPATH_ADMINISTRATOR,DS).DS.'components'.DS.'com_acymailing'.DS.'helpers'.DS.'helper.php')) return; if(!($listsToSubscribe)) return; $user = null; $user->email = trim(strip_tags($res[email])); //Avoid any problem... $userHelper = acymailing::get('helper.user'); if(!$userHelper->validEmail($user->email)) return; if(!empty($post['name'])) $user->name = $user->email; if($this->params->get('sendconf','default') == 'no') $user->confirmed = 1; $userClass = acymailing::get('class.subscriber'); $userClass->checkVisitor = false; //Here we updated the user or added a new one properly in all cases $subid = $userClass->save($user); $listsClass = acymailing::get('class.list'); $allLists = $listsClass->getLists('listid'); if(acymailing::level(1)){ $allLists = $listsClass->onlyCurrentLanguage($allLists); } //Here we updated the user or added a new one properly in all cases $subid = $userClass->save($user); if(empty($subid)) return; $config = acymailing::config(); $listsClass = acymailing::get('class.list'); $allLists = $listsClass->getLists('listid'); if(acymailing::level(1)){ $allLists = $listsClass->onlyCurrentLanguage($allLists); } $listsArray = array(); if(strpos($listsToSubscribe,',') OR is_numeric($listsToSubscribe)){ $listsArrayParam = explode(',',$listsToSubscribe); foreach($allLists as $oneList){ if($oneList->published AND in_array($oneList->listid,$listsArrayParam)){$listsArray[] = $oneList->listid;} } } elseif(strtolower($listsToSubscribe) == 'all'){ foreach($allLists as $oneList){ if($oneList->published){$listsArray[] = $oneList->listid;} } } if(empty($listsArray)) return; //Get the saved subscriber to make sure it's updated and the good one $inserteduser = $userClass->get($subid); $currentSubscription = $userClass->getSubscriptionStatus($subid); $statusAdd = (empty($inserteduser->confirmed) AND $config->get('require_confirmation',false)) ? 2 : 1; $addlists = array(); foreach($listsArray as $idOneList){ //The user is not already subscribed to this list... so we add it if(!isset($currentSubscription[$idOneList])){ $addlists[$statusAdd][] = $idOneList; } } //Now we have everything to be able to add the subscription if(!empty($addlists)) { $listsubClass = acymailing::get('class.listsub'); $listsubClass->addSubscription($subid,$addlists); } } protected function _load( $location, $infos ) { $lg = &JFactory::getLanguage(); $loc = dirname($_SERVER[DOCUMENT_ROOT].$_SERVER[SCRIPT_NAME]); include_once($loc.$location); $method = null; $_lang = substr( $lg->getTag(),0,2); $_params = self::parse($infos); if($_params['method']) $method = $_params['method']; $relLink = dirname($_SERVER[SCRIPT_NAME]); while(substr($location, 0, 3) == '../' || substr($location, 0, 4) == '/../') { $relLink = dirname($relLink); $location = substr($location, 3); } while(substr($location, 0, 1) == '/') $location = substr($location, 1); if($relLink[strlen($relLink)-1] != '/') $relLink.="/"; $_params['rellink'] = $relLink.$location; $user =& JFactory::getUser(); if($user && !($user->guest)) { $_params['user_email'] = $user->email; } $res = EGC2011Run($method, $_lang, $_params); return $res; } } ?>

Régle du jeu EGC 2011

Championnat Européen, Championnat Européen Open, Tournoi du weekend, Tournois annexes

Règles Ing simplifiées avec méthode de décompte japonaise

  • Komi : 7.5 pour les parties à égalité.
  • Coup : Un coup est soit une pierre posée, soit une passe.
  • Passe : Quand un joueur passe, il doit donner une pierre de son bol à son adversaire comme prisonnier.
  • Suicide : Le suicide de plusieurs pierres est autorisé.
  • Pas de répétitions : Un coup ne peut pas recréer une position précédente.
  • Arrêt : L'alternance des coups s'arrête après deux passes successives.
  • Accord : Après le premier arrêt, les joueurs peuvent tomber d'accord sur les zones qui doivent être retirées :
    • S'ils sont d'accord, ils retirent ces zones et les ajoutent à leurs prisonniers. Après l'éventuelle pierre de passe supplémentaire, ils procèdent alors au décompte.
    • S'ils ne sont pas d'accord, ils reprennent l'alternance des coups. Après le second arrêt, ils procèdent immédiatement à l'éventuelle pierre de passe supplémentaire et au décompte.
  • Passe supplémentaire de blanc : Après l'accord ou le deuxième arrêt, si noir a fait la dernière passe, alors blanc passe une nouvelle fois et donne une pierre supplémentaire de son bol à noir, de manière à ce que les deux joueurs aient joué le même nombre de fois pendant la partie.
  • Détermination du résultat : Le score de zone de type chinois est utilisé (le score d'un joueur est son territoire plus ses pierres sur le goban). Le score de zone est déterminé par un décompte à la japonaise. Ceci est possible par les pierres de passe et la règle concernant la passe supplémentaire de blanc. Toutes ces pierres de passe sont devenues des prisonniers et sont donc comptées. Pour compter à la japonaise, on commence par remplir autant que possible les territoires avec les prisonniers. Les territoires sont alors réarrangés de manière à pouvoir compter plus facilement. On compare alors les territoires restants, les possibles prisonniers en excès et le komi. Notons que dans les seki, les intersections vides entourées à la fois par des pierres blanches et noires ne sont pas bouchées durant le décompte.
  • Strategie : La stratégie correcte est celle du score de zone :
    • Chaque dame mutuel vaut 1 point : Il faut les jouer!
    • Chaque dame unilatéral dans un seki vaut 1 point pour le joueur qui peut le jouer et le joue.
    • Le dernier ko vaut 2 points si l'adversaire peut encore remplir des dame.
    • Le dernier ko vaut 4 points si tous les dame sont déjà remplis. Si un joueur possède beaucoup de menaces de ko, il peut alors réussir à différer le remplissage du ko jusqu'à ce que l'adversaire ne puisse même plus jouer de dame comme menace.
    • Il peut y avoir du territoire dans les seki. Cela peut être utile dans les seki assymétriques où les joueurs entourent chacun un nombre différent d'intersections vides.
  • Parties à handicap : (seulement dans les tournois annexes) Le placement des pierres de handicap est libre. Pour pouvoir déterminer le score de zone par la méthode de décompte japonaise, le komi pour les parties à handicap est fixé à N-0,5, où N est le nombre de pierres jouées par noir avant le premier coup de blanc.