Byla vydána (𝕏) nová verze 2025.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení na blogu.
Dánské ministerstvo pro digitální záležitosti má v plánu přejít na Linux a LibreOffice [It's FOSS News].
V úterý Google vydal Android 16. Zdrojové kódy jsou k dispozici na AOSP (Android Open Source Project). Chybí (zatím?) ale zdrojové kódy specifické pro telefony Pixel od Googlu. Projekty jako CalyxOS a GrapheneOS řeší, jak tyto telefony nadále podporovat. Nejistá je podpora budoucích Pixelů. Souvisí to s hrozícím rozdělením Googlu (Google, Chrome, Android)?
Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.101 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.101 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
V Brně na FIT VUT probíhá třídenní open source komunitní konference DevConf.CZ 2025. Vstup je zdarma, nutná je ale registrace. Na programu je celá řada zajímavých přednášek, lightning talků, meetupů a workshopů. Přednášky lze sledovat i online na YouTube kanálu konference. Aktuální dění lze sledovat na Matrixu, 𝕏 nebo Mastodonu.
Vyloučení technologií, které by mohly představovat bezpečnostní riziko pro stát, má umožnit zákon o kybernetické bezpečnosti, který včera Senát schválil spolu s novelami navazujících právních předpisů. Norma, kterou nyní dostane k podpisu prezident, počítá rovněž s prověřováním dodavatelů technologií pro stát. Normy mají nabýt účinnosti od třetího měsíce po jejich vyhlášení ve Sbírce zákonů.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.6.
Po Red Hat Enterprise Linuxu a AlmaLinuxu byl v nové stabilní verzi 10.0 vydán také Rocky Linux. Přehled novinek v poznámkách k vydání.
Bylo vydáno Eclipse IDE 2025-06 aneb Eclipse 4.36. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
Americká filmová studia Walt Disney a Universal Pictures podala žalobu na provozovatele populárního generátoru obrázků pomocí umělé inteligence (AI) Midjourney. Zdůvodňují to údajným porušováním autorských práv. V žalobě podané u federálního soudu v Los Angeles označují firmu za „bezednou jámu plagiátorství“, neboť podle nich bez povolení bezostyšně kopíruje a šíří postavy z filmů jako Star Wars, Ledové království nebo Já, padouch, aniž by do nich investovala jediný cent.
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: