Curl, řádkový nástroj a knihovna pro přenos dat po různých protokolech, slaví 25 let. Vydána byla nová verze 8.0.0. Mimo jiné řeší 6 zranitelností.
V sobotu 25. března proběhne Arduino Day 2023. Od 14:00 lze sledovat oficiální stream. Zúčastnit se lze i lokálních akcí. V Česku jsou aktuálně registrovány dvě: v Praze na Matfyzu a v Poličce v městské knihovně.
Fabrice Bellard, tvůrce FFmpeg nebo QEMU, představil TextSynth Server. Jedná se o webový server nabízející REST API k velkým AI jazykovým modelům. CPU verze je k dispozici zdarma jako binárka pod licencí MIT. GPU verze je komerční. Vyzkoušet lze na stránkách TextSynth.
Na konferenci LibrePlanet 2023 byly vyhlášeny ceny Free Software Foundation. Oceněni byli Eli Zaretskii za dlouhodobé příspěvky (správce Emacsu), Tad „SkewedZeppelin“ za nové příspěvky (správce DivestOS, distribuce Androidu) a projekt GNU Jami za společenský přínos.
Projekt Libreboot (Wikipedie) vydal novou verzi 20230319 svého svobodného firmwaru nahrazujícího proprietární BIOSy. Přibyla například podpora Lenovo ThinkPadů W530 a T530. Libreboot je distribucí Corebootu bez proprietárních blobů.
Na YouTube jsou k dispozici videozáznamy z 20. konference SCALE (Southern California Linux Expo). Závěrečnou přednášku měl dnes již osmdesátiletý Ken Thompson. Na otázku, jaký operační systém používá, odpověděl: "Většinu svého života jsem používal Apple, protože jsem se do této společnosti tak trochu narodil. Poslední dobou, myslím posledních pět let, jsem ale kvůli Applu více a více depresivní. To, co dělá s něčím, co by vám mělo umožnit
… více »Byla vydána verze 10.00 linuxové distribuce SystemRescue, původně SystemRescueCd, určené pro záchranu systémů a dat. Přehled novinek v changelogu. Linux byl povýšen na verzi 6.1.20.
Byla vydána verze 16.0.0 překladačové infrastruktury LLVM (Wikipedie). Přehled novinek v poznámkách k vydání: LLVM, Clang, LLD, Extra Clang Tools, Libc++ a Polly.
O víkendu probíhá v Bostonu, a také virtuálně, konference LibrePlanet 2023 organizovaná nadací Free Software Foundation (FSF).
Na Crowd Supply běží kampaň na podporu open source notebooku MNT Pocket Reform od společnosti MNT Research. Notebook má mechanickou klávesnici s RGB podsvícením a 7 palcový displej s rozlišením 1920×1200 pixelů. Cena začíná na 899 dolarech. Před třemi lety proběhla úspěšná kampaň na podporu notebooku MNT Reform.
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: