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.
Snažim se napsat kód, kterej ze vstupního parametru kterým může být ip adresa nebo hostname vytvoří strukturu in_addr. Pokud se zadá existující ip nebo jméno, tak vše funguje jak má. Pokuď se ale zadá nějakej nesmyslnej řetězec, nedostane se kód do větve s výpisem chyby, ale "zastaví" se. Netušíte někdo, kde je chyba?
struct in_addr ip;
/* Ziskani ip adresy serveru */
if (inet_aton(argv[1], &ip) == 0) {
if((ph = gethostbyname(argv[1])) != NULL)
memcpy(&ip.s_addr, ph->h_addr, sizeof(ip.s_addr));
else
printf("%s: unknown host %s", basename(argv[0]), basename(argv[1]));
}
To jo, ale to už čeká následující kód, který se stará o samotné TCP spojení. Mám tomu teda rozumět tak, že pokud není ip adresa pro dané jméno nalezena, není to chyba a gethostbyname() nevrací NULL?
Pokud ano, existuje nějaká jednoduchá metoda, jak zjistit zda dané jméno skutečně existuje v rozumném čase (například jako u www prohlížečů)? Nebo se to řeší nějakým signálem po určené době?
Chybu vrací tak, jak je specifikováno (nepamatuji si z hlavy, jak to přesně je). Jen to není hned, ale až ve chvíli, kdy to resolver vzdá (obvykle po několika sekundách). Nezkoumal jsem, jestli ten timeout lze nějak ovlivnit.
Tak zpět... Problém je ten, že mi v tom printf() chybí '\n' a chybová hláška se mi nevypsala na obrazovku...
Tiskni
Sdílej: