Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.
Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.
Organizace Open Container Initiative (OCI) (Wikipedie), projekt nadace Linux Foundation, vydala Runtime Specification 1.3 (pdf), tj. novou verzi specifikace kontejnerového běhového prostředí. Hlavní novinkou je podpora FreeBSD.
Nový open source router Turris Omnia NG je v prodeji. Aktuálně na Allegro, Alternetivo, Discomp, i4wifi a WiFiShop.
Na YouTube a nově také na VHSky byly zveřejněny sestříhané videozáznamy přednášek z letošního OpenAltu.
Jednou za rok otevírá společnost SUSE dveře svých kanceláří široké veřejnosti. Letos je pro vás otevře 26. listopadu v 16 hodin v pražském Karlíně. Vítáni jsou všichni, kdo se chtějí dozvědět více o práci vývojářů, prostředí ve kterém pracují a o místní firemní kultuře. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem inženýři v Praze pracují, jak spolupracují se zákazníky, partnery i studenty, proč mají rádi open source a co
… více »Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za říjen (YouTube).
Jeff Quast otestoval současné emulátory terminálu. Zaměřil se na podporu Unicode a výkon. Vítězným emulátorem terminálu je Ghostty.
Amazon bude poskytovat cloudové služby OpenAI. Cloudová divize Amazon Web Services (AWS) uzavřela s OpenAI víceletou smlouvu za 38 miliard USD (803,1 miliardy Kč), která poskytne majiteli chatovacího robota s umělou inteligencí (AI) ChatGPT přístup ke stovkám tisíc grafických procesů Nvidia. Ty bude moci využívat k trénování a provozování svých modelů AI. Firmy to oznámily v dnešní tiskové zprávě. Společnost OpenAI také nedávno
… více »
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: