Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
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: