diff --git a/Grille.php b/Grille.php
index 6a45b5a..04dc223 100644
--- a/Grille.php
+++ b/Grille.php
@@ -3,9 +3,6 @@
include_once "dico.php";
-const MIN_LETTRES = 1;
-
-
class Grille {
public $grille;
public $hauteur;
@@ -19,15 +16,16 @@ class Grille {
$this->largeur = $largeur;
$this->grille = array_fill(0, $hauteur, array_fill(0, $largeur, '.'));
- if ($hauteur == $largeur) {
- $dimensions = [$hauteur];
+ if ($id == "") {
+ mt_srand();
} else {
- $dimensions = [$hauteur, $largeur];
+ mt_srand(crc32($id));
}
$this->mots_commencant_par = [];
- foreach ($dimensions as $longueur) {
+ foreach ($hauteur == $largeur? [$hauteur]: [$hauteur, $largeur] as $longueur) {
$this->mots_commencant_par[$longueur] = [];
- foreach(mots_espaces($longueur, MIN_LETTRES, crc32($id)) as $mot) {
+ $nb_mots = 0;
+ foreach(mots_espaces($longueur) as $mot) {
for ($i = 0; $i <= $longueur; $i++) {
$debut = substr($mot, 0, $i);
if (!isset($this->mots_commencant_par[$longueur][$debut])) {
@@ -37,6 +35,8 @@ class Grille {
}
}
}
+ mt_srand();
+
$this->grilles = $this->generateur();
$this->grilles->current();
}
diff --git a/dico.csv b/dico.csv
index e6a6039..683d182 100644
--- a/dico.csv
+++ b/dico.csv
@@ -1,4 +1,5 @@
#MOT Définition
+
A
ABAT Tripe ou étripe. (Robert Scipion)
ABATTIS Architecte à la retraite
diff --git a/dico.php b/dico.php
index e9dcf08..56ffff2 100644
--- a/dico.php
+++ b/dico.php
@@ -1,5 +1,10 @@
$definition) {
$n = strlen($mot);
if (!isset($mots_de_n_lettres[$n])) {
@@ -22,39 +27,41 @@ foreach ($dico as $mot => $definition) {
$mots_de_n_lettres[$n][] = $mot;
}
-function fisherYatesShuffle(&$items, $seed)
+function fisherYatesShuffle(&$items)
{
- mt_srand($seed);
- for ($i = count($items) - 1; $i > 0; $i--)
- {
- $j = @mt_rand(0, $i);
+ for ($i = count($items) - 1; $i > 0; $i--) {
+ $j = mt_rand(0, $i);
$tmp = $items[$i];
$items[$i] = $items[$j];
$items[$j] = $tmp;
}
- mt_srand();
}
-function mots_espaces($max, $min=0, $seed=0) {
+function mots_espaces($longueur) {
global $mots_de_n_lettres;
global $dico;
- if ($seed) {
- fisherYatesShuffle($mots_de_n_lettres[$max], $seed);
- } else {
- shuffle($mots_de_n_lettres[$max]);
- }
- foreach($mots_de_n_lettres[$max] as $mot) {
+ $nb_mots = 0;
+ fisherYatesShuffle($mots_de_n_lettres[$longueur]);
+ foreach($mots_de_n_lettres[$longueur] as $mot) {
yield $mot;
+ $nb_mots++;
+ if ($nb_mots > MAX_MOTS) {
+ return;
+ }
}
- for ($i = ceil($max / 2); $max - $i -1 >= $min; $i++) {
+ for ($i = 2; $longueur - $i - 1 >= MIN_LETTRES; $i++) {
foreach ($mots_de_n_lettres[$i] as $mot1) {
- foreach (mots_espaces($max - $i -1, $min) as $mot2) {
+ foreach (mots_espaces($longueur - $i - 1) as $mot2) {
if ($mot1 != $mot2) {
$dico["$mot1 $mot2"] = $dico[$mot1] && $dico[$mot2] ? "{$dico[$mot1]}
{$dico[$mot2]}." : $dico[$mot1] . $dico[$mot2];
yield "$mot1 $mot2";
$dico["$mot2 $mot1"] = $dico[$mot2] && $dico[$mot1] ? "{$dico[$mot2]}
{$dico[$mot1]}." : $dico[$mot2] . $dico[$mot1];
yield "$mot2 $mot1";
+ $nb_mots += 2;
+ if ($nb_mots > MAX_MOTS) {
+ break;
+ }
}
}
}
diff --git a/index.php b/index.php
index a983c09..b07bd24 100644
--- a/index.php
+++ b/index.php
@@ -1,18 +1,14 @@
[
- "regexp" => "/^[a-f0-9]{13}$/"
- ]
-]);
-if (!$id) {
+if (!isset($_GET["grille"])) {
$_GET["grille"] = uniqid();
- header("Location: " . $_SERVER['DOCUMENT_URI'] . "?" . http_build_query($_GET));
+ header("Location: " . dirname($_SERVER['DOCUMENT_URI']) . "?" . http_build_query($_GET));
exit;
+} else {
+ $id = htmlspecialchars($_GET["grille"]);
}
@@ -20,6 +16,10 @@ include_once "dico.php";
include_once "Grille.php";
+const HAUTEUR_PAR_DEFAUT = 6;
+const LARGEUR_PAR_DEFAUT = 6;
+
+
$hauteur = filter_input(INPUT_GET, 'lignes', FILTER_VALIDATE_INT, [
"options" => [
"default" => HAUTEUR_PAR_DEFAUT,
@@ -118,9 +118,9 @@ $grille = new Grille($hauteur, $largeur, $id);
-
-
-
+
+ name="lignes" value="= $hauteur ?>" />
+ name="colonnes" value="= $largeur ?>" />
diff --git a/style.css b/style.css
index 7099531..708d3bf 100644
--- a/style.css
+++ b/style.css
@@ -12,6 +12,10 @@ form {
justify-content: space-evenly;
}
+h1 {
+ margin: 0;
+}
+
h1 table {
margin: auto;
line-height: 0.8;
@@ -19,6 +23,7 @@ h1 table {
h1 td {
width: 0.7em;
+ text-align: center;
}
h1,