Richard Biener oznámil vydání verze 16.1 (16.1.0) kolekce kompilátorů pro různé programovací jazyky GCC (GNU Compiler Collection). Jedná se o první stabilní verzi řady 16. Přehled změn, nových vlastností a oprav a aktualizovaná dokumentace na stránkách projektu. Některé zdrojové kódy, které bylo možné přeložit s předchozími verzemi GCC, bude nutné upravit.
Zulip Server z open source komunikační platformy Zulip (Wikipedie, GitHub) byl vydán ve verzi 12.0. Přehled novinek v příspěvku na blogu.
Před 30 lety, tj. v úterý 30. dubna 1996, byl spuštěn Seznam.cz.
Byly zpracovány a zveřejněny všechny videozáznamy, které stojí za zveřejnění, z konference FOSDEM 2026.
Od úterý 28. dubna musí nově uváděné notebooky v Evropské unii podporovat nabíjení přes USB-C. Jednotná nabíječka byla schválena Evropským parlamentem v říjnu 2022.
Byly publikovány informace o kritické zranitelnosti CVE-2026-31431 pojmenované Copy Fail v Linuxu, konkrétně v kryptografii (AF_ALG). Běžný uživatel může získat práva roota (lokální eskalaci práv). Na všech distribucích Linuxu vydaných od roku 2017. Pomocí 732bajtového skriptu. V upstreamu je již opraveno. Zranitelnost byla nalezena pomocí AI Xint Code.
Textový editor Zed dospěl do verze 1.0. Představení v příspěvku na blogu.
Vývojáři svobodného 3D softwaru Blender představili (𝕏, Mastodon, Bluesky) nejnovějšího firemního sponzora Blenderu. Je ním společnost Anthropic stojící za AI Claude a úroveň sponzoringu je Patron, tj. minimálně 240 tisíc eur ročně. Anthropic oznámil sponzorství v tiskové zprávě Claude for Creative Work.
VNC server wayvnc pro Wayland kompozitory postavené nad wlroots - ne GNOME, KDE nebo Weston - byl vydán ve verzi 0.10.0. Vydána byla také verze 1.0.0 související knihovny neatvnc.
Bylo oznámeno vydání Fedora Linuxu 44. Ve finální verzi vychází šest oficiálních edic: Fedora Workstation a Fedora KDE Plasma Desktop pro desktopové, Fedora Server pro serverové, Fedora IoT pro internet věcí, Fedora Cloud pro cloudové nasazení a Fedora CoreOS pro ty, kteří preferují neměnné systémy. Vedle nich jsou k dispozici také další atomické desktopy, spiny a laby. Podrobný přehled novinek v samostatných článcích na stránkách
… více »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: