V Praze probíhá Flock 2026, tj. konference pro přispěvatele a příznivce Fedory. Přednášky lze sledovat také na YouTube.
Node-RED (Wikipedie, GitHub), webová aplikace postavená na Node.js pro vizuální programování a propojování hardwarových zařízení, API a online služeb, byl vydán ve verzi 5.0. Přehled novinek v příspěvku na blogu.
Byla vydána nová verze 3.27.0 FreeRDP, tj. svobodné implementace protokolu RDP (Remote Desktop Protocol). Opraveno bylo 5 zranitelností.
Řídící výbor GCC schválil záměr do GCC začlenit backend WebAssembly.
Po 9 týdnech vývoje od vydání Linuxu 7.0 oznámil Linus Torvalds vydání Linuxu 7.1. Přehled novinek a vylepšení na LWN.net: první a druhá polovina začleňovacího okna a časem také na Linux Kernel Newbies.
Cheat Engine (Wikipedie) je s verzí 7.7 k dispozici už také pro Linux. Jedná se o proprietární skener/debugger paměti používaný především k cheatování v počítačových hrách.
Vláda USA nařídila společnosti Anthropic pozastavit přístup k modelům Fable 5 a Mythos 5 pro všechny cizince, včetně zaměstnanců Anthropicu.
Společnost Murena představila (YouTube) novou verzi 4.0 mobilního operačního systému /e/OS (Wikipedie) založeného na Androidu a LineageOS bez aplikací a služeb od Googlu.
V Arch User Repository (AUR) bylo kompromitováno přes 400 opomíjených balíčků (jejich seznam). Útočník do nich začlenil škodlivý npm balíček atomic-lockfile, který krade citlivá data uživatelů. Publikována byla předběžná analýza spouštěného malwaru deps.
Homebrew, správce balíčků nejen pro macOS, byl vydán ve verzi 6.0.0 (seznam změn). Hlavními novinkami jsou bezpečnostní mechanismus tap trust kvůli důvěryhodnosti závislostí, vylepšení sandboxingu na Linuxu, interní JSON API nebo zlepšení výkonu.
off64_t cislo = 1024*1024*1024*6; char buffer[500]; sprintf( buffer, "%llu", cislo );Ukáže to 2147483648, což není správně.
test.c:10: warning: integer overflow in expression test.c:10: warning: overflow in implicit constant conversionMusíte alespoň za jedno číslo přidat ULL.
$ ./test 6442450944
sprintf(buffer, "%.0lf", (double) cislo);
off_t je z podstaty věci také znaménkový.
off64_t samozřejmě také.
off64_t cislo = 1024*1024*1024*6; char buffer[500]; sprintf( buffer, "%lld", cislo );=-2147483648 = Špatně
off64_t cislo = 1024LL*1024LL*1024LL*6LL; char buffer[500]; sprintf( buffer, "%lld", cislo );=-2147483648 = Špatně
off64_t cislo = 1024*1024*1024*6; char buffer[500]; sprintf( buffer, "%.0lf", (double)cislo );=-2147483648 = Špatně
off64_t cislo = 1024LL*1024LL*1024LL*6LL; char buffer[500]; sprintf( buffer, "%.0lf", (double)cislo );=6442450944 = OK
.
PRId64', jak jsem vám poradil dříve?
sprintf( buffer, PRId64, cislo );, tak mi to ukázalo chybu, že proměnná není definována. Pak jsem se kouknul do toho hlavičkového souboru a zjistil, že musím před hlavičkový soubor připsat #define __STDC_FORMAT_MACROS. Poté se ale do bufferu dal řetězec "I64d". Pak jsem vyzkoušel sprintf( buffer, "%I64d", cislo); a ono to funguje
. Díky moc za nakopnutí správným směrem.
/* 7.8.1 Macros for format specifiers * * MS runtime does not yet understand C9x standard "ll" * length specifier. It appears to treat "ll" as "l". * The non-standard I64 length specifier causes warning in GCC, * but understood by MS runtime functions. */A pak mi nemá fungovat %lld a %llu.
#include <inttypes.h> ... printf(PRId64, cislo);
Tiskni
Sdílej: