Byl vydán Debian 13.5, tj. pátá opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.14, tj. čtrnáctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.
CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.
Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].
Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.
Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.
Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.
Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.
Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.
Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.
Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.
array(4) {
[0]=>
array(2) {
[0]=>
array(2) {
["id"]=>
int(1)
["name"]=>
string(5) "jedna"
}
[1]=>
array(2) {
["id"]=>
int(4)
["name"]=>
string(5) "ctyri"
}
}
[1]=>
array(2) {
[0]=>
array(2) {
["id"]=>
int(2)
["name"]=>
string(3) "dva"
}
[1]=>
array(2) {
["id"]=>
int(3)
["name"]=>
string(3) "tri"
}
}
[4]=>
array(3) {
[0]=>
array(2) {
["id"]=>
int(5)
["name"]=>
string(3) "pet"
}
[1]=>
array(2) {
["id"]=>
int(6)
["name"]=>
string(4) "sest"
}
[2]=>
array(2) {
["id"]=>
int(7)
["name"]=>
string(4) "sedm"
}
}
[7]=>
array(2) {
[0]=>
array(2) {
["id"]=>
int(8)
["name"]=>
string(3) "osm"
}
[1]=>
array(2) {
["id"]=>
int(9)
["name"]=>
string(5) "devet"
}
}
}
rekurzivni funkce (dovolil jsem si tam dat var_dumpy):
public function findListDown($seekVal, $tmp_array = array()) {
if (count($tmp_array) == 0) { // kdyz je pole prazdne vlozi prvni hledanou hodnotu
array_push($tmp_array,$seekVal);
}
var_dump($tmp_array);
foreach ($this->slovnik()[$seekVal] as $tmp_key) {
var_dump($tmp_key['id']);
array_push($tmp_array,$tmp_key['id']);
$seekVal = $tmp_key['id'];
$this->findListDown($seekVal,$tmp_array);
}
return $tmp_array;
}
Vystupem var_dumpu je toto:
array(1) {
[0]=>
int(0)
}
int(1)
array(2) {
[0]=>
int(0)
[1]=>
int(1)
}
int(2)
array(3) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
}
int(3)
array(4) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
} ---------> az sem vsechno ok
int(4)
array(3) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(4) ---> ale tady mi asi ta rekurzivni funkce prepsala hodnoty v poli
}...
------------> chtel bych zde mit:
int(4)
array(3) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
[4]=>
int(4)
}...
<?php
class itemList {
public $slovnik =
array (
0 =>
array (
0 =>
array (
'id' => 1,
'name' => 'jedna',
),
1 =>
array (
'id' => 4,
'name' => 'ctyri',
),
),
1 =>
array (
0 =>
array (
'id' => 2,
'name' => 'dva',
),
1 =>
array (
'id' => 3,
'name' => 'tri',
),
),
4 =>
array (
0 =>
array (
'id' => 5,
'name' => 'pet',
),
1 =>
array (
'id' => 6,
'name' => 'sest',
),
2 =>
array (
'id' => 7,
'name' => 'sedm',
),
),
7 =>
array (
0 =>
array (
'id' => 8,
'name' => 'osm',
),
1 =>
array (
'id' => 9,
'name' => 'devet',
),
),
);
public function findListDown($seekVal, $tmp_array = array()) {
# [ 0: {1,4}, 1: {2,3}, 4: {5,6,7}, 7: {8,9} ]
if (count($tmp_array) == 0) {
array_push($tmp_array,$seekVal);
}
var_dump($tmp_array);
foreach ($this->slovnik[$seekVal] as $tmp_key) {
var_dump($tmp_key['id']);
array_push($tmp_array,$tmp_key['id']);
$seekVal = $tmp_key['id'];
$this->findListDown($seekVal,$tmp_array);
}
return $tmp_array;
}
}
$Lists = new itemList;
echo "<pre>";
$Lists->findListDown(0);
echo "</pre>";
?>
upravena verze:
<?php
class itemList {
public $slovnik =
array (
0 =>
array (
0 =>
array (
'id' => 1,
'name' => 'jedna',
),
1 =>
array (
'id' => 4,
'name' => 'ctyri',
),
),
1 =>
array (
0 =>
array (
'id' => 2,
'name' => 'dva',
),
1 =>
array (
'id' => 3,
'name' => 'tri',
),
),
4 =>
array (
0 =>
array (
'id' => 5,
'name' => 'pet',
),
1 =>
array (
'id' => 6,
'name' => 'sest',
),
2 =>
array (
'id' => 7,
'name' => 'sedm',
),
),
7 =>
array (
0 =>
array (
'id' => 8,
'name' => 'osm',
),
1 =>
array (
'id' => 9,
'name' => 'devet',
),
),
);
private $tmp_array = array();
public function findListDown($seekVal) {
if (count($this->tmp_array) == 0) {
array_push($this->tmp_array,$seekVal);
}
var_dump($this->tmp_array);
foreach ($this->slovnik[$seekVal] as $tmp_key) {
var_dump($tmp_key['id']);
array_push($this->tmp_array,$tmp_key['id']);
$seekVal = $tmp_key['id'];
$this->findListDown($seekVal);
}
return $this->tmp_array;
}
}
$Lists = new itemList;
echo "<pre>";
$Lists->findListDown(0);
echo "</pre>";
?>
a jejich rozdilne vystupy, puvodni verze bez privatni promenne...:
array(1) {
[0]=>
int(0)
}
int(1)
array(2) {
[0]=>
int(0)
[1]=>
int(1)
}
int(2)
array(3) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
}
int(3)
array(4) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
}
int(4)
array(3) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(4)
}
int(5)
array(4) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(4)
[3]=>
int(5)
}
int(6)
array(5) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(4)
[3]=>
int(5)
[4]=>
int(6)
}
int(7)
array(6) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(4)
[3]=>
int(5)
[4]=>
int(6)
[5]=>
int(7)
}
int(8)
array(7) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(4)
[3]=>
int(5)
[4]=>
int(6)
[5]=>
int(7)
[6]=>
int(8)
}
int(9)
array(8) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(4)
[3]=>
int(5)
[4]=>
int(6)
[5]=>
int(7)
[6]=>
int(8)
[7]=>
int(9)
}
upravena verze s privatni promennou:
array(1) {
[0]=>
int(0)
}
int(1)
array(2) {
[0]=>
int(0)
[1]=>
int(1)
}
int(2)
array(3) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
}
int(3)
array(4) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
}
int(4)
array(5) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
[4]=>
int(4)
}
int(5)
array(6) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
[4]=>
int(4)
[5]=>
int(5)
}
int(6)
array(7) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
[4]=>
int(4)
[5]=>
int(5)
[6]=>
int(6)
}
int(7)
array(8) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
[4]=>
int(4)
[5]=>
int(5)
[6]=>
int(6)
[7]=>
int(7)
}
int(8)
array(9) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
[4]=>
int(4)
[5]=>
int(5)
[6]=>
int(6)
[7]=>
int(7)
[8]=>
int(8)
}
int(9)
array(10) {
[0]=>
int(0)
[1]=>
int(1)
[2]=>
int(2)
[3]=>
int(3)
[4]=>
int(4)
[5]=>
int(5)
[6]=>
int(6)
[7]=>
int(7)
[8]=>
int(8)
[9]=>
int(9)
}
$seekVal i $tmp_array a místo standardního
$tmp_array[] = $tmp_key['id'];používáš nedoporučovanou konstrukci
array_push($tmp_array, $tmp_key['id']);Takže: Čeho chceš vlastně dosáhnout? Nestačilo by jednoduché volání nějaké standardní funkce, která by tohle vše udělala jedním vrzem? Odkud bereš data? Nestačilo by je vyfiltrovat už při čtení? Proč to neuděláš funkcionálně?
id | parent_id | name | dalsi sloupce
-------+-----------+-----------+---------------
1 | 0 | jedna |
2 | 1 | dva |
3 | 1 | tri |
4 | 0 | ctyri |
5 | 4 | pet |
6 | 4 | sest |
7 | 4 | sedm |
8 | 7 | osm |
9 | 7 | devet |
1 0 jedna 2 1 dva 3 1 tri 4 0 ctyri 5 4 pet 6 4 sest 7 4 sedm 8 7 osm 9 7 devetProtoze chci obcas vykreslovat jen nektere vetve (napr. id 4-9) Vytvoril jsem si slovnik, ktery odrazky prevede do tvaru
[ 0: {1,4}, 1: {2,3}, 4: {5,6,7}, 7: {8,9} ]
Funkci $this->findListDown(4); bych napr. vykresloval jen odrazky s id 4-9.
Nicmene, to asi utikame od dotazu. Zajimalo by me, proc prvni uvedena funkce nedela to co druha? Dela prece to same, je jen zapsana jinak...
array_push(), kterou nepoužívám a proto jsem ani nevěděl o této její vlastnosti.
$doc = new DOMdocument();
$pole = array();
$pole[0] = $doc->appendChild(new DOMElement('root'));
while ($row = $select->fetch(PDO::FETCH_ASSOC)) {
$id = $row['id'];
$pid = 0 + $row['pid'];
$parentId = isset($pole[$pid]) ? $pid : 0;
$child = new DOMElement('div', htmlspecialchars($row['nazev']));
$pole[$id] = $pole[$parentId]->appendChild($child);
}
V CSS jsem pak dal jen odsazení divu na 4% a bylo to. Proměnná $pole je jen pomocná, výsledek je v $doc
public function findListDown($seekVal, &$tmp_array = array()) {
if (count($tmp_array) == 0) {
array_push($tmp_array,$seekVal);
}
foreach ($this->slovnik[$seekVal] as $tmp_key) {
$tmp_array[] = $tmp_key['id'];
$seekVal = $tmp_key['id'];
$this->findListDown($seekVal, $tmp_array);
}
return $tmp_array;
}
Tiskni
Sdílej: