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.
char a[25]="Dobrý";
char b[25]=" den";
char ab[25]= a || b;
a píše to chybu:
neco.cpp:82:36: error: array must be initialized with a brace-enclosed initializer
Řešení dotazu:
strncpy, aby mu nepřetekl buffer.
char a[]="Dobrý"; char b[]=" den"; char ab[25]; snprintf(ab, 25, "%s%s", a, b);A třeba to převedení čísla na řetězec:
snprintf(buf, 100, "Číslo má hodnotu %i", 1000);
#define CHAR_A "Dobrý" #define CHAR_B " den" #define CHAR_AB CHAR_A CHAR_B char a[25] = CHAR_A; char b[25] = CHAR_B; char ab[25] = CHAR_AB;
char *a = "Dobrý"; char *b = " den"; char *c; c = malloc(strlen(a) + strlen(b) + 1); strcpy(c, a); strcat(c, b); // ... free(c);
const char a[] = "....";a
const char *a = "....";není ekvivalentní, viz např. dsohowto (používání bez const je pak vůbec zajímavé, a byť někdy užitečné, obecně ho nelze doporučit, pokud přesně nevíte proč a jak). Také by pole znaků narozdíl od pointerů umožnily použít sizeof() namísto strlen(), i když optimalizující kompilátor bude schopen vyhodnotit i ten strlen() staticky. Především ale proboha použij nějakou knihovnu pro práci s řetezci, která má alespoň něco jako g_strconcat() z GLib (příklad implementace takové funkce je jako concat() i přímo v manuálu glibc). Nebo string v C++ -- těžko řící, v jakém to mělo být jazyce, ale koncovka souboru je .cpp, takže by to snad mohlo být C++.
. Ale zas používat knihovnu a představovat si, jakou magii vykonovává taky není dobré, obzvlášť v C (u skriptovacích jazyků je to jiná - tam interpret přístup mimo paměť a leaky většinou ošetří).
Tiskni
Sdílej: