Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.3. Současně oznámila, že nadcházející větší vydání 24.04-2.0 bude mít modernější webový prohlížeč.
Ploopy po DIY trackballech či sluchátkách představuje nový externí DIY trackpoint se čtyřmi tlačítky Bean. Obsahuje snímač Texas Instruments TMAG5273, spínače Omron D2LS-21 a řadič RP2040, používá firmware QMK. Schémata jsou na GitHubu; sadu lze předobjednat za 69 kanadských dolarů (bez dopravy a DPH).
Mozilla před dvěma týdny na svém blogu oznámila, že díky Claude Mythos Preview bylo ve Firefoxu nalezeno a opraveno 271 bezpečnostních chyb. Včera vyšel na Mozilla Hacks článek s podrobnějšími informacemi. Z 271 bezpečnostních chyb mělo 180 chyb vysokou závažnost, 80 chyb střední závažnost a 11 chyb nízkou závažnost. Celkově bylo v dubnu ve Firefoxu opraveno 423 bezpečnostních chyb. Čísla CVE nemusí být přiřazována jednotlivým chybám. CVE-2026-6784 například představuje 154 bezpečnostních chyb.
Před týdnem zranitelnost Copy Fail. Dnes zranitelnost Dirty Frag. Běžný uživatel může na Linuxu získat práva roota (lokální eskalaci práv). Na většině linuxových distribucí vydaných od roku 2017. Aktuálně bez oficiální záplaty a CVE čísla [oss-security mailing list].
Ačkoli je papež Lev XIV. hlavou katolické církve a stojí v čele více než miliardy věřících po celém světě, také on někdy řeší všední potíže. A kdo v životě neměl problémy se zákaznickou linkou? Krátce poté, co nastoupil do úřadu, musel papež se svou bankou řešit změnu údajů. Operátorka ale nechtěla uvěřit, s kým mluví, a Svatému otci zavěsila.
Incus, komunitní fork nástroje pro správu kontejnerů LXD, byl vydán ve verzi 7.0 LTS (YouTube). Stejně tak související LXC a LXCFS.
Google Chrome 148 byl prohlášen za stabilní. Nejnovější stabilní verze 148.0.7778.96 přináší řadu novinek z hlediska uživatelů i vývojářů. Vypíchnout lze Prompt API (demo) pro přímý přístup k AI v zařízení. Podrobný přehled v poznámkách k vydání. Opraveno bylo 127 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
Richard Hughes oznámil, že po společnostech Red Hat a Framework a organizacích OSFF a Linux Foundation, službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzorují také společnosti Dell a Lenovo. Do dnešního dne bylo díky LVFS provedeno více než 145 milionů aktualizací firmwarů od více než 100 různých výrobců na milionech linuxových zařízení.
Americké technologické společnosti Microsoft, Google a xAI souhlasily, že vládě Spojených států poskytnou přístup k novým modelům umělé inteligence (AI) před jejich uvedením na trh. Oznámila to americká vláda, která tak bude moci prověřit, zda modely nepředstavují hrozbu pro národní bezpečnost. Oznámení podtrhuje rostoucí obavy Washingtonu z rizik spojených s výkonnými AI systémy. Americké úřady chtějí v rámci předběžného přístupu
… více »Minule jsem lehce nastínil, co je to Root a na jednoduchém příkladě ukázal jednu z mnoha věcí, ke kterým by se dal použít. Jak bylo řečeno, Root slouží k analýze dat. Obvykle ale chceme analyzovat i něco jiného než náhodná čísla vygenerovaná v Rootu. Dnes se tedy pokusím popsat, jakými způsoby lze data do Rootu načítat a ukládat.
Jelikož Root je framework v C++, lze pochopitelně k vstupům i výstupům použít standatní prostředky C++. V Rootu samotném jsou pak např. implementovány třídy pro usnadnění manipulace s daty v XML (a to jak SAX tak DOM parser), tak pro komunikaci se SQL serverem. Toto velmi usnadní práci zvláště když chceme uložit nějaký celý rootovský objekt, např. uložení plátna c1 do databáze lze jednoduše provést takto:
gBenchmark->Start("writeSQL");
c1->Write("Canvas");
Tento a další příklady lze najít v $ROOTSYS/tutorials/sql (resp. tutorilas/xml). Když už jsem zde dal za příklad ukládání plátna, ještě zmíním, že objekty jako plátno jdou velmi snadno (c1->Print("graf.eps")) ukládat do formátů ps, esp, jpg a mnoha dalších. Formát se se volí automaticky podle koncovky souboru (v našem případě grafy.esp tedy eps formát).
Pokud explicitně nezvolíme způsob uložení objektu (např. do databáze) a zavoláme na objektu (těmito objekty jsou v Rootu nejčastěji rootvské stromy - TTree) metodu Write() (musíme mít ale otevřeny nějaký rootovský soubor TFile), objekt se zapíše ve vlastním formátu Rootu (no, lépe řečeno, jedná se o serializaci objektů
. Jak se píše v Root user's guide, rootovský soubor je jako UNIXový adresář, může obsahovat adresáře a objekty v neomezeném množství úrovní. Obsah takovéhoto souboru pak můžeme zobrazit a procházet např. pomocí TBrowser (v příkazové řádce Rootu napíšeme new TBrowser() a spustí se, jak již název napovídá, grafický browser, kterým můžeme procházet obsah souboru nebo otvírat další soubory). Pokud chceme načíst nějaký objekt v programu, patrně nejsnadněji toho dosáhneme zavoláním metody Get("object_key") na objektu typu TFile (myTFile->Get(object_key)), kde klíč objektu obvykle zadáváme při jeho vytvoření (typicky první parametr konstruktoru) nebo při ukládání objektu(object->Write("new_key")). Seznam všech klíčů objektů uložených v souboru získáme pomocí myTFile->GetListOfKeys(). Výpis adresářů v souboru zas pomocí myTFile->ls() a do adresáře se přesuneme pomocí myTFile->cd().
Jak již bylo řečeno, ukládání probíhá serializací objektů. O to se starají streamry. O streamrech a podrobnostech ukládání objektů se můžete dočíst v manuálu. Další zajímavou funkcí IO systém Rootu je možnost vzdáleného přístupu k rootovským souborům. Soubor, který chceme ukládat přes síť, musí být typu TNetFile. Chová se stejně jako TFile (také je to jeho potomek), akorát místo na disk přesměruje výstup na demona rootd (který pochopitelně musí běžet
. Jména souborů jsou jako URL adresy s protokolem root (např. root://cosi.kdesi.cz/root/test.root). Podrobnosti (a jak rozběhnout demona) opět viz manuál. Soubory lze zpřístupnit i přes web sever. Soubor pak musí být typu TWebFile a z Root pak k němu přistoupit přes protokol HTTP:
TWebFile webFile("http://cosi.kdesi.cz/rootFile.root");
webFile.ls()
Tiskni
Sdílej: