Czkawka a Krokiet, grafické aplikace pro hledání duplicitních a zbytečných souborů, byly vydány ve verzi 11.0. Podrobný přehled novinek v příspěvku na Medium. Od verze 7.0 je vedle frontendu Czkawka postaveného nad frameworkem GTK 4 vyvíjen nový frontend Krokiet postavený nad frameworkem Slint. Frontend Czkawka je už pouze v udržovacím módu. Novinky jsou implementovány ve frontendu Krokiet.
Jiří Eischmann na svém blogu publikoval článek Úvod do MeshCore: "Doteď mě radioamatérské vysílání úplně míjelo. Když jsem se ale dozvěděl, že existují komunity, které svépomocí budují bezdrátové sítě, které jsou nezávislé na Internetu a do značné míry taky elektrické síti a přes které můžete komunikovat s lidmi i na druhé straně republiky, zaujalo mě to. Když o tom přede mnou pořád básnili kolegové v práci, rozhodl jsem se, že to zkusím taky.
… více »Byla vydána verze 0.5.20 open source správce počítačových her na Linuxu Lutris (Wikipedie). Přehled novinek v oznámení na GitHubu. Instalovat lze také z Flathubu.
Peter Steinberger, autor open source AI asistenta OpenClaw, nastupuje do OpenAI. OpenClaw bude převeden pod nadaci a zůstane otevřený a nezávislý.
Společnost Backblaze zveřejnila statistiky spolehlivosti pevných disků používaných ve svých datových centrech za rok 2025. Ke konci roku 2025 vlastnila 349 462 pevných disků. Průměrná AFR (Annualized Failure Rate), tj. pravděpodobnost, že disk během roku selže, byla 1,36 %. V roce 2024 to bylo 1,57 %. V roce 2023 to bylo 1,70 %. V roce 2022 to bylo 1,37 %.
Nástroj sql-tap je proxy mezi aplikací a databází, které zachytává všechny SQL dotazy a zobrazuje je v terminálovém rozhraní. Zde lze téměř v reálném čase zkoumat dotazy, sledovat transakce a spouštět SQL příkaz EXPLAIN. Podporované databázové systémy jsou pouze PostgreSQL a MySQL. Zdrojový kód je dostupný na GitHubu, pod licencí MIT.
Byla vydána nová verze 9.2 textového editoru Vim (Vi IMproved). Přináší vylepšené doplňování, podporu schránky ve Waylandu, podporu XDG Base Directory (konfigurace v $HOME/.config/vim), vylepšené Vim9 skriptování nebo lepší zvýrazňování změn. Vim zůstává charityware. Nadále vybízí k podpoře dětí v Ugandě. Z důvodu úmrtí autora Vimu Brama Moolenaara a ukončení činnosti jím založené charitativní organizace ICCF Holland projekt Vim navázal spolupráci s charitativní organizaci Kuwasha.
Byl představen editor MonoSketch, webová aplikace pro tvorbu diagramů, technických nákresů, flowchartů a různých dalších vizualizací, to vše jenom z ASCII znaků. Všechny operace běží pouze v prohlížeči uživatele a neprobíhá tedy žádné nahrávání dat na server. Zdrojový kód aplikace (drtivá většina Kotlin, žádné C#) je dostupný na GitHubu pod licencí Apache 2.0.
Byla vydána nová verze 3.7.0 multiplatformního svobodného frameworku pro zpracování obrazu G'MIC (GREYC's Magic for Image Computing, Wikipedie). Přehled novinek i s náhledy nových filtrů na PIXLS.US.
Všem na AbcLinuxu vše nejlepší k Valentýnu aneb Dni lásky ke svobodnému softwaru (I love Free Software Day, Mastodon, 𝕏).
Jako i ostatní moduly knihovny Qt, i modul QtSql má obsáhlou a podrobnou dokumentaci, kteréžto součástí jsou i různé příklady. V následujícím textu shrnu základy práce a doplním snad užitečné postřehy a příklady z praxe.
Poznámka: Příklady jsou většinou určeny pro Sqlite3, protože Sqlite modul/driver je obvykle dostupný ve všech distribučních balících (včetně Mac OS X a MS Windows) a nepotřebuje žádný běžící server.
Pokud chceme v Qt4 pracovat s relační databází, máme čtyři hlavní možnosti:
Jak v dalším textu uvidíme, tak Qt se snaží, pokud použijeme SQL API, stírat rozdíly ve vlastnostech jednotlivých DB technologií a pro vývojáře sjednotit práci s DB na z databázového hlediska platformně nezávislé použití SQL API. Se všemi svými výhodami a nevýhodami.
Qt4 databázový driver implementuje napojení a práci s vlastním DBMS a zároveň unifikuje rozdíly mezi podporovaným databázemi, aby se daly použít v čistě databázově nezávislém SQL API.
Některé drivery jsou už obsaženy v distribučních balících, jiné je třeba ručně přeložit a některé jsou dostupné pouze platícím zákazníkům firmy Nokia, popřípadě přes třetí strany.
V programech je možné používat klasické jednotlivé SQL příkazy, volat uložené procedury anebo jiné techniky, které daný DB produkt podporuje. Ovšem že se tím stírá jakási databázově orientovaná přenositelnost (každý dodavatel si tak nějak dělá věci po svém), ale na druhou stranu tato technika umožní využít celé spektrum vlastností a často až magických nástrojů známých jen zasvěceným.
Na tomto místě je vhodné poznamenat, že „klasický“ přístup (kombinace C++ s vnořeným SQL) sice může působit zastarale, ale je to jediný způsob, jak v Qt zavolat databázovou proceduru (Oracle „domácí“ driver):
QSqlQuery q; q.prepare("s0.admin.tablespace_coalesce(:name, :result)"); q.bindValue(0, "LARGE_DATA"); q.bindValue(1, 0, QSql::Out); q.exec(); qDebug() << “vysledek:“ << q.boundValue(1).toString();
Během psaní článku byly uvolněny všechny DB drivery, které v QtSoftware, dříve Trolltech, napsali. Zkoušet tedy můžete i s „velkými“ DB servery. Pokud si tedy drivery přeložíte.
Pro odvážné hardcoristy anebo pro vývojáře, kteří potřebují použít speciální funkce, jež nabízí pouze klientská knihovna použitého DB stroje, je také k dispozici virtuální metoda QVariant QSqlDriver::handle () const. Následující příklad ukazuje, jak lze použít přímo volání externí sqlite3 C API:
bool Database::enableExtensionLoading(bool enable)
{
QVariant v = QSqlDatabase::database(SESSION_NAME).driver()->handle();
if (!v.isValid()
|| qstrcmp(v.typeName(), "sqlite3*") != 0)
{
exception(tr("DB driver is not valid sqlite3."));
return false;
}
sqlite3 *handle = *static_cast<sqlite3 **>(v.data());
if (handle == 0)
exception(tr("DB handler is not valid"));
if (handle
&& sqlite3_enable_load_extension(handle, enable ? 1 : 0) != SQLITE_OK)
{
if (enable)
exception(tr("Failed to enable extension loading"));
else
exception(tr("Failed to disable extension loading"));
return false;
}
return true;
}
Qt4 přišlo se specifickou implementací principu Model-View, který lze také využít ve spolupráci s QtSql modulem. Modely, které jsou v QtSQL modulu obsaženy, dokáží zobrazit data z DB, aniž by byl třeba další kód, kterým by se ručně plnily GUI widgety.
SQL dotazy lze do M-V architektury dostat pomocí instance třídy QSqlQueryModel. Zde je možné využít výše popsané chování QSqlQuery, a to včetně práce s proměnnými bind, anebo posílat příkazy jako čisté řetězce QString. Data zobrazená tímto způsobem jsou určena pouze pro čtení.
Případný zápis dat, jakási simulace „updatable views“, lze sice realizovat, ale je třeba použít nízkoúrovňové nástroje (např. zjistit ROWID jednotlivých záznamů spojených tabulek, následně pak data měnit ručně atd. Navíc objekty použité v dotazu nemusí být tabulky, ale třeba různé typy pohledů…). Autor si zde nenárokuje patent na rozum, rád se nechá p.t. čtenářstvem poučit, pokud nějakou lepší alternativu znají.
Pokud je třeba zobrazit data z jedné DB tabulky, lze poměrně elegantně využít QSqlTableModel – model, který navíc umožňuje přímou změnu a vkládání dat do DB. Model má několik omezení:

V případě, že je vhodné zobrazit v GUI záznamy „po jednom“, popřípadě editovat data ve specializovaném formuláři, je sice možné používat nízkoúrovňové SQL nástroje a data pak manuálně přehazovat do a z GUI, ale na většinu podobných operací Qt nabízí sofistikovanější nástroj.
QdataWidgetMapper z modulu QtGui ve spolupráci s výše zmíněnými SQL modely odvede stejnou práci automaticky (anebo skoro automaticky).
Qt4 umožňuje použít DB konekci pouze ve vlákně, ve kterém byla vytvořena a zároveň jsou všechny DB operace synchronní. Proto se může stát, že při časově náročnějším dotazu do DB, popř. při síťové chybě, může dojít k „zamrznutí“ GUI, protože se vše odehrává v jediném vlákně a Qt eventy čekají (jsou zablokovány) na odpověď DB serveru.
Proto můžeme použít několik způsobů, jak se problémům vyhnout. Nechat program tak, jak je, občasné zamrznutí prohlásit za vlastnost a počkat, až si uživatel zvykne. Anebo zvolit jednu z klasických metod, kterými uděláme program vícevláknovým – modul QtCore, Threading (vizte Grafické programy v Qt 4 – 5 (regexpy, vlákna a ukazatel průběhu):
Ukázková implementace takového řešení přesahuje rozsah článku (čtenář bude číst: nechce se mi psát), proto čtenáře odkazuji na příklad z praxe (toresultmodel.cpp z TOra a návaznosti). Ukázkové zdrojové kódy použité v článku jsou zde: qt4-sql-priklady.zip.
QtSql je ve vícevláknových programech navíc omezeno následujícím:
Nástroje: Tisk bez diskuse
Tiskni
Sdílej: