Příspěvek na blogu herního enginu Godot představuje aplikaci Xogot přinášející Godot na iPad a iPhone. Instalovat lze z App Storu. Za Xogotem stojí Miguel de Icaza (GitHub) a společnost Xibbon.
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za březen (YouTube).
ESP-IDF (Espressif IoT Development Framework), tj. oficiální vývojový framework pro vývoj aplikací na mikrokontrolérech řady ESP32, byl vydán v nové verzi 6.0. Detaily na portálu pro vývojáře.
DeepMind (Alphabet) představila novou verzi svého multimodálního modelu, Gemma 4. Modely jsou volně k dispozici (Ollama, Hugging Face a další) ve velikostech 5-31 miliard parametrů, s kontextovým oknem 128k až 256k a v dense i MoE variantách. Modely zvládají text, obrázky a u menších verzí i audio. Modely jsou optimalizované pro běh na desktopových GPU i mobilních zařízeních, váhy všech těchto modelů jsou uvolněny pod licencí Apache 2.0. Návod na spuštění je už i na Unsloth.
Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 3. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).
Průkopnická firma FingerWorks kolem roku 2000 vyvinula vícedotykové trackpady s gesty a klávesnice jako TouchStream LP. V roce 2005 ji koupil Apple, výrobu těchto produktů ukončil a dotykové technologie využil při vývoji iPhone. Multiplatformní projekt Apple Magic TouchstreamLP nyní implementuje funkcionalitu TouchStream LP na současném Apple Magic Trackpad, resp. jejich dvojici. Diskuze k vydání probíhá na Redditu.
Byla vydána nová verze 10.3 sady aplikací pro SSH komunikaci OpenSSH. Přináší řadu bezpečnostních oprav, vylepšení funkcí a oprav chyb.
Cloudflare představil open source redakční systém EmDash. Jedná se o moderní náhradu WordPressu, která řeší bezpečnost pluginů. Administrátorské rozhraní lze vyzkoušet na EmDash Playground.
Bratislava OpenCamp 2026 zverejnil program a spustil registráciu. Štvrtý ročník komunitnej konferencie o otvorených technológiách prinesie 19 prednášok na rôzne technologické témy. Konferencia sa uskutoční v sobotu 25. apríla 2026 v priestoroch FIIT STU v Bratislave.
Na iVysílání lze zhlédnout všechny díly kultovního sci-fi seriálu Červený trpaslík.
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: