Rspamd (Wikipedie), tj. open source systému pro filtrování nevyžádané pošty, byl vydán v nové major verzi 4.0.0. Přehled novinek v Changelogu.
SolveSpace (Wikipedie), tj. multiplatformní open source parametrický 2D/3D CAD, byl vydán v nové verzi 3.2. Přehled novinek v Changelogu na GitHubu. Vyzkoušet lze novou oficiální webovou verzi.
Organizátoři Dne IPv6, tradiční akce věnované tématům spojeným s tímto protokolem, vyhlásili Call for Abstracts. Na webu konference mohou zájemci přihlašovat příspěvky o délce 20 nebo 40 minut či 10minutové lighting talky a to až do 30. dubna. Tvůrci programu uvítají návrhy přednášek z akademického i komerčního sektoru, které mohou být technického i netechnického zaměření. Den IPv6 se letos uskuteční 4. června a místem konání bude i
… více »Euro-Office (Wikipedie) je evropský fork open source kancelářského balíku OnlyOffice. Za forkem stojí koalice firem IONOS, Nextcloud, Eurostack, XWiki, OpenProject, Soverin, Abilian a BTactic. Cílem je zajistit digitální suverenitu Evropy a snížit závislost na neevropských platformách. Projekt vznikl mimo jiné v reakci na nedávné uzavření cloudové služby OnlyOffice. OnlyOffice obviňuje Euro-Office z porušení licenčních podmínek. Na možné problémy upozorňuje i Collabora Online. Jednostranná změna licence není v pořádku.
Byly zpracovány a na YouTube zveřejněny videozáznamy jednotlivých přednášek z letošního Installfestu.
Během akce Arduino Days 2026 byl publikován Arduino Open Source Report 2025 (pdf) a oznámeno 7 nových produktů kompatibilních s deskou UNO Q (Arduino USB-C Power Supply, USB-C Cable, USB-C Hub, UNO Media Carrier, UNO Breakout Carrier, Bug Hopper, Modulino LED Matrix).
Google v pátek spustil v Česku Vyhledávání Live. Tato novinka umožňuje lidem vést plynulou konverzaci s vyhledávačem v češtině. A to prostřednictvím hlasu, nebo prostřednictvím toho, na co ukážou svým fotoaparátem či kamerou v mobilu. Rozšíření této multimodální funkce je možné díky nasazení Gemini 3.1 Flash Live, nového hlasového a audio modelu, který je od základu vícejazyčný, takže umožňuje lidem po celém světě mluvit na vyhledávač přirozeně a v jazyce, který je jim nejbližší.
Jsongrep je open-source nástroj, který efektivně prohledává JSON dokumenty (editovat je neumí). Kompiluje regulérní jazyk dotazu do podoby deterministického konečného automatu (DFA), díky čemuž prochází strom JSON dokumentu pouze jednou a je v tom tedy rychlejší než jiné nástroje jako jsou například jq, JMESPath nebo jql. Jsongrep je napsaný v programovacím jazyce Rust, zdrojový kód je dostupný na GitHubu.
O víkendu probíhá v Praze na Karlově náměstí 13 konference Installfest 2026. Na programu je celá řada zajímavých přednášek a workshopů. Vstup na konferenci je zcela zdarma, bez nutnosti registrace. Přednášky lze sledovat i online na YouTube.
Mozilla a společnost Mila oznámily strategické partnerství za účelem rozvoje open source a suverénní AI. Cílem je ukázat, že open source AI může konkurovat uzavřeným systémům. Obě organizace chtějí posílit technologickou suverenitu a snížit závislost na hrstce velkých technologických firem.
Pro účely tohoto článku byl vytvořen ilustrační miniprojekt, kterého účelem je vytvořit dva provázané fiktivní produkty:
Uvedené aplikace se omezí pouze na to, že vypíší parametry připojení. Pro zjednodušení jim budeme dále zkráceně říkat klient a server.
Kompletní kompilovatelný projekt si můžete stáhnout zde. Autor jej vytvořil s přesvědčením, že může být pro vás inspirací pro vaše projekty. Pokud jej vylepšíte, bude vděčný za vaše připomínky a návrhy.
Struktura projektu je znázorněna na následujícím obrázku:

V hlavním adresáři se nacházejí tři soubory. Soubor
build.xml obsahuje hlavní antovský skript, kterého
jediným účelem je inkrementovat číslo buildu nacházející
se v souboru build.number a spouštět Antovské
skripty pro klienta a server, umístěné v příslušných podadresářích
src/client a src/server.
Soubor build.properties obsahuje pouze odkaz na příslušný
konfigurační profil definovaný v podadresáři conf:
# Soubor nastaveni pro build file je ulozen v prislusnem konfiguracnim
|

Konfigurační profil dmi.properties používá vývojář
dmi na svém počítači, který se jmenuje dmi.
Kromě definice některých proměnných dále větví konfigurační profil
pomocí odkazů na soubory v podadresářích jdbc a
jndi. Tzn. nenastavuje zbytečně mnoho proměnných, které by
se v každém profilu opakovaly, ale obsahuje přepínač na konkrétní sadu
nastavení, v tomto případě typ jdbc driveru a typ aplikačního serveru.
Adresář src obsahuje dva izolované podprojekty.
Následující obrázek ukazuje strukturu podprojektu klienta:

Podadresář build obsahuje soubory vznikající během buildu,
tedy zkompilované soubory a výsledný zabalený produkt
(package), včetně knihoven.
Adresář java obsahuje zdrojové
kódy tříd projektu, lib knihovny nezbytné pro kompilaci a
spuštění (skript by je měl nakopírovat do package).
Adresář rsrc obsahuje další soubory (resources), které aplikace potřebuje za běhu. Tyto soubory jsou rozděleny do dvou skupin.
Soubory v adresáři etc se přibalí k výslednému jar
souboru, takže jsou dostupné v classpath za běhu aplikace.
Soubory v adresáři main se nakopírují do hlavního adresáře
produktu - typicky se jedná o spouštěcí dávky.
Zajímavé na souborech v adresáři rsrc je, že obsahují
odkazy na proměnné definované v konfiguračním profilu. Např.
spouštěcí dávka run.sh je napsána velmi obecně. Zvlášť
zajímavé je předání hodnot client.property1
a client.property2, které jsou pak aplikaci k dispozici
pomocí volání System.getProperty("client.property1");
a System.getProperty("client.property2");:
#/bin/sh
|
Výhoda substituce parametrů rsrc souborů pomocí konfiguračních profilů
se stane zřejmá, když potřebujeme stejný parametr použít na více místech.
Jelikož klient by měl být alternativě spustitelný také pomocí
jnlp souboru, přijde vhod možnost předat klientovi stejné
parametry také pomocí jnlp spouštěče:
<?xml version="1.0" encoding="UTF-8" ?>
|
Teorie bylo už dost, podívejme se na výstup klientské aplikace pro jednotlivé konfigurační profily:
Profil dmi:
01 Ant Demo, build 6
|
Profil prof2:
01 Ant Demo, build 6
|
Ve dvou výše uvedených výstupech vidíme následující rozdíly:
Serverová aplikace je strukturována téměř identickým způsobem jako
klient. Rozdíl je pouze ve struktuře adresáře package,
který zahrnuje podadresáře lib a etc.
Narozdíl od klienta není obsah adresáře rsrc/etc
přibalován přímo do výsledného jar souboru,
ale ponechán jako adresář, který je přidán do classpath
ve spouštěcí dávce. Díky tomu lze měnit konfiguraci nainstalovaného
produktu bez nutnosti rebuildu (hesla, nastavení logu apod.).
Ant poskytuje vše, co je třeba pro robustní strukturu projektu. Klíčovým prvkem je možnost nastavovat proměnné a při kopírování provádět substituci ve zdrojových souborech. Tímto jsme však nahlédli pouze do jedné z mnoha kapitol podpory projektu, kterou Ant přináší. Pro Ant existuje celá řada užitečných tasků, ať již integrovaných nebo třetích stran - generátorů kódu (XDoclet), formáterů zdrojových kódů, kontrol kvality zdrojového kódu, podpory pro unit testing apod.
Pokud jste ještě Ant nikdy nepoužili, vyzkoušejte jej - a uvidíte, že si pak bez něj nebudete dokázat představit svůj programátorský život. Je velmi dobře zdokumentovaný, obsahuje jak úvod typu "snadno a rychle", tak solidní referenční příručku.
Nástroje: Tisk bez diskuse
Tiskni
Sdílej: