Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
static int file_info(const char *fpath, const struct stat *sb, int tflag, struct FTW *ftwbuf) { if (tflag == FTW_D) { //tady bych chtel volat dalsi funkci //fce((struct tree *)first); printf("%s, D(%d), %d\n", fpath, ftwbuf->level, (long long)sb->st_size); } else if (tflag == FTW_F) printf("%s, F(%d), %d\n", fpath,ftwbuf->level, (long long)sb->st_size); return(0); } int main(int argc, char *argv[]) { int flags = 0; //flags |= FTW_DEPTH; //flags |= FTW_PHYS; nftw(argv[1], file_info, 20, 0); exit(EXIT_SUCCESS); }Potrebuji volat z funkce file_info() dalsi funkci, ktere bych predal ukazatel na strukturu (kde budou ulozeny informace o souborech). Jedno reseni je pouzit dlobalni promenne a nebo promene ve funkci kterou chci volat pouzit jako staticke. A nebo posledni reseni nepouzit ftw()/nftw() a napsat si to cele sam. Poradi nekdo?
nftw
vidím poprvé. Asi to ale nedělá nic víc, než bych sám svedl s opendir
/stat
...
V mé manuálové stránce je napsáno These functions are provided for compatibility with legacy code. New code should use the fts(3)
functions.. Co ty na to?
Funkce, kterým se předává nějaký callback, který pak ony volají, obvykle umožňují použít jeden pointer právě na nějaká vlastní data, které tomu callbacku chceme propašovat. Viz např. pthread_create
. U nftw
ale nic takového nevidím, přístup fts
je v tomhle tedy lepší.
Tiskni Sdílej: