Byla vydána nová verze 12.0.0 vizuálního programovacího jazyka Snap! (Wikipedie) inspirovaného jazykem Scratch (Wikipedie). Přehled novinek na GitHubu.
Počítačovou hru Gravity Circuit (ProtonDB) lze do 14. června do 19:00 získat na Steamu zdarma. Napořád.
Nejnovější X.Org X server 21.1.23 a Xwayland 24.1.12 řeší 9 bezpečnostních chyb.
npm balíčky @redhat-cloud-services byly kompromitovány.
Byly publikovány informace o zranitelnosti CVE-2026-46243 pojmenované CIFSwitch v Linuxu od roku 2007. Běžný uživatel může získat práva roota (lokální eskalaci práv). V upstreamu je již opraveno.
Nvidia na své konferenci NVIDIA GTC Taipei 2026 představila řadu novinek. Společně s Microsoftem představili superčip NVIDIA RTX Spark (až 6 144 jader GPU, 20 jader CPU, 1 petaflop AI výkonu v FP4 a 128 GB jednotné paměti). První notebooky a stolní počítače s tímto čipem od Nvidie místo Intelu nebo AMD by se měly na trh dostat na podzim letošního roku.
Na Kickstarteru běží kampaň na podporu kapesního počítače s Linuxem CardputerZero od společnosti M5Stack. Postaven je na Raspberry Pi Compute Module 0. Podporuje moduly M5. Koupit lze s rozšířeními LoRa a CC1101.
Tento týden se bude vyznačovat zejména deštěm, a proto vás může zajímat, že již v úterý proběhne 63. Virtuální Bastlírna, která se bude odehrávat přímo v teple vašich domovů a bastlíren. Proto se připojte k této volné otevřené diskuzi bastlířů, techniků, vědců, ve které se probírají novinky a zajímavá témata z techniky. Mezi největší novinky bude tentokrát patrně patřit oznámení hackerského nástroje Flipper One. Zároveň úspěšně probíhá
… více »86Box (Wikipedie), tj. emulátor retro počítačů založených na x86, byl vydán ve verzi 6.0. Přibyly například zvuky pevného disku. Na GitHubu jsou vedle zdrojových kódů ke stažení také připravené balíčky ve formátu AppImage.
Byla vydána nová verze 4.6 audio přehrávače Audacious (Wikipedie). Z novinek lze vypíchnout nový plugin pro procházení soubory, podporu audio formátu Musepack SV8 nebo přechod na build systém Meson.
char *end; //pouzito pro kontrolu konverze
unsigned int pocet_zidli= strtoul(argv[1], &end, 0);
if (*end != '\0')
{//osetreni vstupu argv[1]
fprintf(stderr, "%s\n", chybove_zpravy[CHYBA_ARGV1]);
return -1;
}
zkoušel jsem to takhle. strtoul ale převádí string na unsigned long a já to uložím do unsigned int, je to problém?
A pak ještě mi to hází když zadám např -1, nějaké hodně velké číslo, jak to prosím ošetřím děkuji.
char *end;
int pocet_zidli= strtoul(argv[1], &end, 0);
if (errno == ERANGE || *end != '\0' || pocet_zidli < 0)
{//osetreni vstupu argv[1]
fprintf(stderr, "%s\n", chybove_zpravy[CHYBA_ARGV]);
return -1;
}
btw nejsou nekde man. stranky v CZ, angličtinu neovladam a resim skolni projekt s procesy a vubec nevim kde hledat info :/ jak zacit. Pritom pri prihlasovani na Bc. nikde nebylo psano, ze vsechno bude v AJ, kdyz se anglictina vyucuje az na Bc. To uz je jina kapitola..
strtoul převádí na unsigned long, nikoliv unsigned int. Pokud to rovnou převedete na unsigned int, nemáte šanci detekovat přetečení mezi UINT_MAX a ULONG_MAX. Takže lépe si takto nadefinujte strtoui:
int strtoui(const char *str, char **end, int base)
{
unsigned long l = strtoul(str, end, base);
if (l > UINT_MAX) {
errno = ERANGE;
return UINT_MAX;
}
return l;
}
A nezapomeňte na to, že strtoul nemaže errno, pokud nedošlo k chybě, takže si jej před jejím voláním vymažte, tedy volání by mělo vypadat nějak takto:
char *end;
errno = 0;
unsigned int pocet_zidli = strtoui(argv[1], &end, 0);
if (errno == ERANGE || *end != 0) {
// Chyba
}
man strtoul:
Negative values are considered valid input and are silently converted to the equivalent unsigned long int value.Takže řešení je použít
strtol (strtoll pokud chcete celý rozsah unsigned long) a ošetřit obě meze.
Tiskni
Sdílej: