Eric Lengyel dobrovolně uvolnil jako volné dílo svůj patentovaný algoritmus Slug. Algoritmus vykresluje text a vektorovou grafiku na GPU přímo z dat Bézierových křivek, aniž by využíval texturové mapy obsahující jakékoli předem vypočítané nebo uložené obrázky a počítá přesné pokrytí pro ostré a škálovatelné zobrazení písma, referenční ukázka implementace v HLSL shaderech je na GitHubu. Slug je volným dílem od 17. března letošního
… více »Sashiko (GitHub) je open source automatizovaný systém pro revizi kódu linuxového jádra. Monitoruje veřejné mailing listy a hodnotí navrhované změny pomocí umělé inteligence. Výpočetní zdroje a LLM tokeny poskytuje Google.
Cambalache, tj. RAD (rapid application development) nástroj pro GTK 4 a GTK 3, dospěl po pěti letech vývoje do verze 1.0. Instalovat jej lze i z Flathubu.
KiCad (Wikipedie), sada svobodných softwarových nástrojů pro počítačový návrh elektronických zařízení (EDA), byl vydán v nové major verzi 10.0.0 (𝕏). Přehled novinek v příspěvku na blogu.
Letošní Turingovou cenu (2025 ACM A.M. Turing Award, Nobelova cena informatiky) získali Charles H. Bennett a Gilles Brassard za základní přínosy do oboru kvantové informatiky, které převrátily pojetí bezpečné neprolomitelné komunikace a výpočetní techniky. Jejich protokol BB84 z roku 1984 umožnil fyzikálně zaručený bezpečný přenos šifrovacích klíčů, zatímco jejich práce o kvantové teleportaci položila teoretické základy pro budoucí kvantový internet. Jejich práce spojila fyziku s informatikou a ovlivnila celou generaci vědců.
Firefox 149 dostupný od 24. března přinese bezplatnou vestavěnou VPN s 50 GB přenesených dat měsíčně (s CZ a SK se zatím nepočítá) a zobrazení dvou webových stránek vedle sebe v jednom panelu (split view). Firefox Labs 149 umožní přidat poznámky k panelům (tab notes, videoukázka).
Byla vydána nová stabilní verze 7.9 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 146. Přehled novinek i s náhledy v příspěvku na blogu.
Dle plánu byla vydána Opera GX pro Linux. Ke stažení je .deb i .rpm. V plánu je flatpak. Opera GX je webový prohlížeč zaměřený na hráče počítačových her.
GNUnet (Wikipedie) byl vydán v nové major verzi 0.27.0. Jedná se o framework pro decentralizované peer-to-peer síťování, na kterém je postavena řada aplikací.
Byly publikovány informace (technické detaily) o bezpečnostním problému Snapu. Jedná se o CVE-2026-3888. Neprivilegovaný lokální uživatel může s využitím snap-confine a systemd-tmpfiles získat práva roota.
const char XYFileID[7] = "NiecoXY"; // toto mi prekladac nedovoli
const char XYFileID[8] = "NiecoXY"; // musim definovat totoDalej chcem nadefinovat hlavicku binarneho suboru takto:
struct XYFileHeader {
const char Id[7] = XYFileID; // rovnaky problem ako v prvom pripade
float Width;
float Height;
float DpiX;
float DpiY;
char Codec[10];
};
Ale opat je tam problem s ukoncovacim znakom. Prekladac C++ mi ho tam chce za kazdu cenu vnutit. Takze musim to riesit takto:
const char XYFileID[8] = "NiecoXY";
struct XYFileHeader {
char Id[7];
float Width;
float Height;
float DpiX;
float DpiY;
char Codec[10];
XYFileHeader() {
strcpy(Id, XYFileID);
}
};
co prinasa 2 problemy: Id vramci struktury neni const takze sa da prepisat. Musim tie znaky kopirovat az v konstruktore cez strcpy co samozrejme neni tak samovysvetlujuce. Poznate nejaky lepsi sposob? Ale prosim prehladny. Toto za prehladne nepovazujem:
const char XYImageID[7] = { 'N', 'i', 'e', 'c', 'o','X', 'Y' };
Ta struktura je jako hlavička formátu prakticky nepoužitelná* - to Id tam bude mít stejně 1B padding. A rozhodně bych nedoporučoval se to snažit "opravit" pomocí pragma pack nebo podobných rozšíření. Většina formátů ten magic definuje jako nějaký integer, i když ta hodnota je "textová".
* pro usecase "připlácnout strukturu na paměť". Korektně číst po bajtech lze samozřejmě libovolnou hlavičku, ale veškeré příčetné hlavičky jsou navrhovány jako zarovnané.
lepší způsob?? nóóóó použít objekt a všecko v něm poschovávat protože c++ :O ;D
#define HEADER_FILE_ID ({'N', 'i', 'e', 'c', 'o','X', 'Y'})
a v kode budes mat:
const char Id[7] = HEADER_FILE_ID;Ak Ti ide o funkcnost, tak si daj vygenerov hpp subor s definicou tejto strukturou s normalnej nam ludmi definovanom variante (cez make, Makefile a pod.). Napr.:
#!/bin/bash
ID="NiecoXY"
ID_STRUCT=`for a in 0 1 2 3 4 5 6; do echo -n "'${ID:a:1}',"; done;`
ID_STRUCT=${ID_STRUCT:0:-1}
echo $ID_STRUCT
FILE *fp = fopen ("necoNeco", "wb");
if (fp != nullptr) {
fwrite (tvojeStruktura, sizeof (tvojeStruktura), 1, fp);
fclose( fp);
}
A nebo musis jednotlive polozky naformatovat jak uznas za vhodne:
fwrite (tvojeStruktura.polozka1, sizeof (tvojeStruktura.polozka1), 1, fp);
nebo:
fwrite (tvojeStruktura.polozka1, 7, 1, fp);
fwrite (tvojeStruktura.polozka2, sizeof (tvojeStruktura.polozka2), 1, fp);
fwrite (tvojeStruktura.polozka3, sizeof (tvojeStruktura.polozka3), 1, fp);
Tiskni
Sdílej: