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. Vítáni jsou všichni, kdo se chtějí dozvědět více o naší práci, prostředí ve kterém pracujeme a o naší firemní kultuře. Letos se dveře otevřou 26. 11. 2025 v 16:00. Můžete se těšit na krátké prezentace, které vám přiblíží, na čem naši inženýři v Praze pracují, jak spolupracujeme se zákazníky, partnery i studenty, proč máme rádi open source a co pro nás skutečně
… 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 »Konference Prague PostgreSQL Developer Day 2026 (P2D2) se koná 27. a 28. ledna 2026. Konference je zaměřena na témata zajímavá pro uživatele a vývojáře. Příjem přednášek a workshopů je otevřen do 14. listopadu. Vítáme témata související s PostgreSQL či s databázemi obecně, a mohou být v češtině či angličtině.
Byl vydán Devuan 6 Excalibur. Přehled novinek v poznámkách k vydání. Kódové jméno Excalibur bylo vybráno podle planetky 9499 Excalibur. Devuan (Wikipedie) je fork Debianu bez systemd. Devuan 6 Excalibur vychází z Debianu 13 Trixie. Devuan 7 ponese kódové jméno Freia.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu poprvé překročil 3 %, aktuálně 3,05 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 27,18 %. Procesor AMD používá 67,10 % hráčů na Linuxu.
Joel Severin v diskusním listu LKML představil svůj projekt linuxového jádra ve WebAssembly (Wasm). Linux tak "nativně" běží ve webovém prohlížeči. Potřebné skripty pro převod jsou k dispozici na GitHubu.
Jde nějak v PHPku zařídit, abych na jeden XMLHTTP(Ajax) požadavek dostal více odpovědí? V AJAXu dělám importér, který podle importuje data ze souborů, které se během importu stahují, a na každý tento soubor mám vlastní AJAX request. Jenomže každý importovaný soubor má několik podpoložek a ty bych chtěl pomocí AJAXu hlásit do UI.
Schéma jak to ted funguje je takové:
id požadavku 1(ajax request) pozadavek uspesne zpracovan(ajax reply)A toto bych z toho chtel dostat:
id požadavku 1(ajax request) polozka 1 uspesne naimportovana(ajax reply) polozka 2 uspesne naimportovan(ajax reply) ...... pozadavek uspesne zpracovan(ajax reply)
window.onload=function() {
start_import();
}
function start_import() {
var f=document.adminForm;
var ajax=new Array();
var tid=f.tid.value.split(",");
do_import(ajax,tid,0);
}
function do_import(ajax, tid,i) {
var f=document.adminForm;
var msgs=document.getElementById('messages');
var url="index.php?option=com_cbazaar&controller=import&task=import_xxxcars";
if(window.XMLHttpRequest) {
ajax.push(new XMLHttpRequest());
} else if(window.ActiveXObject) {
ajax.push(new ActiveXObject("Microsoft.XMLHTTP"));
}
ajax[ajax.length-1].open('POST',url,true);
ajax[ajax.length-1].onreadystatechange=function() {
/*var p=document.createElement('p');
p.appendChild(document.createTextNode(ajax.length+' '+ajax[ajax.length-1].readyState+ ' '+ajax[ajax.length-1].responseText));
msgs.appendChild(p);*/
if(ajax[ajax.length-1].readyState==4 && ajax[ajax.length-1].status==200) {
var xml=ajax[ajax.length-1].responseXML;
if(xml.getElementsByTagName('status')[0].firstChild.nodeValue==0) {
var p=document.createElement('p');
p.appendChild(document.createTextNode("Successfully imported data to "+xml.getElementsByTagName('title')[0].firstChild.nodeValue));
msgs.appendChild(p);
} else {
var p=document.createElement('p');
p.appendChild(document.createTextNode("Failed to import data to "+xml.getElementsByTagName('title')[0].firstChild.nodeValue));
var div=document.createElement('div');
div.setAttribute('class','error');
div.appendChild(document.createTextNode(xml.getElementsByTagName('error')[0].firstChild.nodeValue));
p.appendChild(div);
msgs.appendChild(p);
}
if(xml.getElementsByTagName('img_err').length>0) {
var p=document.createElement('p');
p.appendChild(document.createTextNode('Image import warnings:'));
msgs.appendChild(p);
var ul=document.createElement('ul');
for(var j=0;j<xml.getElementsByTagName('img_err').length;j++) {
var li=document.createElement('li');
li.appendChild(document.createTextNode(xml.getElementsByTagName('img_err')[j].firstChild.nodeValue));
ul.appendChild(li);
}
msgs.appendChild(ul);
}
i++;
if(i>=tid.length) {
return;
}
do_import(ajax,tid,i);
}
}
var params="tid="+tid[i];
ajax[ajax.length-1].setRequestHeader("Content-type", "application/x-www-form-urlencoded");
ajax[ajax.length-1].setRequestHeader("Content-length", params.length);
ajax[ajax.length-1].setRequestHeader("Connection", "close");
ajax[ajax.length-1].send(params);
}
Soubor stahuju nějak takto:
$c = curl_init($this->_url_cars);
curl_setopt($c, CURLOPT_RETURNTRANSFER, 1);
if(!$this->_update = curl_exec($c)) {
$this->setError('Failed to download update file');
return false;
}
curl_close($c);
Takto získám xml soubor jednoho autobazaru(těch bazarů je víc podle obsahu pole tid) a následuje jeho zpracování do db. Když se dokončí zpracování souboru pošlu do prohlížeče xml hlášení jestli se import podařil, nebo ne. A takové hlášení bych chtěl poslat po zpracování každého auta, aby z toho šel udělat třeba teploměr, že tolik a tolik aut z toho bazaru už je zpracováno.
cometd, určitě se dozvíte víc.
Kedysi som experimentoval s tým, že som HTTP odpoveď rozdelil na viac častí, ktoré som postupne odosielal, ale spojenie za nimi neuzatváral. Nejak takto:
<?php
for ($i=0;$i<=100;$i++) {
echo $i."\n";
flush();
sleep(1);
}
?>
Bohužiaľ, prehliadače to v prípade normálneho requestu spracujú pekne, ale v prípade requestu cez AJAX to veľa prehliadačov vôbec nepochopilo. Možno to ale dnes už funguje lepšie...
Tiskni
Sdílej: