Wasmer byl vydán ve verzi 7.0. Jedná se o běhové prostředí pro programy ve WebAssembly. Zdrojové kódy jsou k dispozici na GitHubu pod licencí MIT.
V reakci na nepopulární plán Microsoftu ještě více ve Windows prohloubit integraci umělé inteligence Copilot, Opera na sociální síti 𝕏 oznámila, že připravuje nativní linuxovou verzi prohlížeče Opera GX. Jedná se o internetový prohlížeč zaměřený pro hráče, přičemž obsahuje všechny základní funkce běžného prohlížeče Opera. Kromě integrace sociálních sítí prohlížeč například disponuje 'omezovačem', který umožňuje uživatelům omezit využití sítě, procesoru a paměti prohlížečem, aby se tak šetřily systémové zdroje pro jinou aktivitu.
NVIDIA vydala nativního klienta své cloudové herní služby GeForce NOW pro Linux. Zatím v beta verzi.
Open Gaming Collective (OGC) si klade za cíl sdružit všechny klíčové projekty v oblasti linuxového hraní počítačových her. Zakládajícími členy jsou Universal Blue a Bazzite, ASUS Linux, ShadowBlip, PikaOS a Fyra Labs. Strategickými partnery a klíčovými přispěvateli ChimeraOS, Nobara, Playtron a další. Cílem je centralizovat úsilí, takže namísto toho, aby každá distribuce udržovala samostatné opravy systému a podporu hardwaru na
… více »V kryptografické knihovně OpenSSL bylo nalezeno 12 zranitelností. Opraveny jsou v upstream verzích OpenSSL 3.6.1, 3.5.5, 3.4.4, 3.3.6 a 3.0.19. Zranitelnosti objevila společnost AISLE pomocí svého autonomního analyzátoru.
Desktopové prostředí Xfce bude mít vlastní kompozitor pro Wayland s názvem xfwl4. V programovacím jazyce Rust s využitím stavebních bloků z projektu Smithay jej napíše Brian Tarricone. Úprava stávajícího xfwm4 tak, aby paralelně podporoval X11 i Wayland, se ukázala jako špatná cesta.
Desktopové prostředí KDE Plasma 6.8 poběží už pouze nad Waylandem. Vývojáři, kteří s rozhodnutím nesouhlasí, vytvořili fork KDE Plasma s názvem SonicDE (Sonic Desktop Environment) s cílem zachovat a vylepšovat podporu X11.
Byla vydána nová stabilní verze 7.8 dnes již jedenáctiletého webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 144. Přehled novinek i s náhledy v příspěvku na blogu.
GNU gettext (Wikipedie), tj. sada nástrojů pro psaní vícejazyčných programů, dospěl do verze 1.0. Po více než 30 letech vývoje. Přehled novinek v souboru NEWS.
Chris Kühl (CEO), Christian Brauner (CTO) a Lennart Poettering (Chief Engineer) představili svou společnost Amutable. Má přinést determinismus a ověřitelnou integritu do linuxových systémů.
Na niektoré novinky C++ sa zvyká ľahko, napríklad std::function, std::span, std::string_view, concepts, pretiahnuté (Slováci, nesmejte sa) pipe operátory, coroutines atď., ale sú veci, pre ktoré nachádzam v praxi využitie len ťažko. Napr. std::move alebo r-value referencie. Vždy, keď ma napadne použiť napr. std::move, tak to vlastne ani nemá moc veľký zmysel. Pri návratových hodnotách to optimalizuje kompilátor používajúci RVO a keď tam použijem move sémantiku, tak by som správnej optimalizácii mohol skôr zabrániť zabrániť.
Ako si viem predstaviť, kde sa to preúvanie asi oplatí používať, napríklad pri práci s veľkými kontainermi, polami, teda najmä s grafikou, alebo možno pri sortovacích a vyhľadávacích algoritmoch. Párkrát som to aj použil, ale väčšinou to bola zbytočná optimalizácia, ktorá ušetrila možno jednu milisekundu. Neviete mi ukázať nejaké konkrétne prípady z reálneho sveta? Keď už mám ten C++ k dispozícii a iné jazyky túto vlastnosť nemajú (pozn: tak možno ešte Carbon a Rust??? ale o tom nemám info). Tak nech túto vychytávku využijem aspoň v jazyku, kde je to podporované.
Tiskni
Sdílej:
std::unique_ptr se bez move sémantiky nedal implementovat.
Neviete mi ukázať nejaké konkrétne prípady z reálneho sveta?Kromě výkonu a zmíněného
unique_ptr je move občas užitečný na přesunutí různých RAII guards z jednoho místa na jiné, např. zamčené zámky, otvřené soubory apod.
pozn: tak možno ešte Carbon a Rust??? ale o tom nemám infoRust nemá r-value reference, protože je nepotřebuje, move sémantiku podporuje přímo kompilátor, což je lepší v tom, že kompilátor zajistí, že přesunutou hodnotu nemůžeš na původním místě znova použít. V Rustu je move default, v C++ je default kopie. Tj. kód
foo.bar(baz); v Rustu bude move, v C++ kopie hodnoty baz. V C++ je potřeba explicitně provést move pomocí std::move(baz), v Rustu je potřeba explicitně udělat kopii pomocí baz.clone().
V Rustu je také možné přesouvat jakékoli typy, ne pouze ty, které to podporují díky správným konstruktorům. Druhá strana téhle mince je, že když je potřeba move zabránit, dělá se to trochu nešikovně přes Pin wrapper a projekce.