Canonical vydal (email) Ubuntu 25.10 Questing Quokka. Přehled novinek v poznámkách k vydání. Jedná se o průběžné vydání s podporou 9 měsíců, tj. do července 2026.
ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzi 1.5.0.
Byla vydána nová verze 1.12.0 dynamického programovacího jazyka Julia (Wikipedie) určeného zejména pro vědecké výpočty. Přehled novinek v příspěvku na blogu a v poznámkách k vydání. Aktualizována byla také dokumentace.
V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).
Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.
Společnost Meta představila OpenZL. Jedná se o open source framework pro kompresi dat s ohledem na jejich formát. Zdrojové kódy jsou k dispozici na GitHubu.
Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.
Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.
Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.
Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.
#define EVENT_SIZE ( sizeof (struct inotify_event) ) #define BUF_LEN ( 1024 * ( EVENT_SIZE + 16 ) ) int main(int argc, char **argv) { int length, i = 0; int fd; int wd; char buffer[BUF_LEN]; fd = inotify_init(); if (fd < 0) { perror("inotify_init"); } wd = inotify_add_watch(fd, "/home/tomesh/Dropbox/C/sync", IN_ALL_EVENTS); if (length < 0) { perror("read"); } while (1) { length = read(fd, buffer, BUF_LEN); struct inotify_event *event = (struct inotify_event *) &buffer[ i ]; if (event->len) { if (event->mask & IN_CREATE) { if (event->mask & IN_ISDIR) { printf("The directory %s was created.\n", event->name); } else { printf("The file %s was created.\n", event->name); } } if (event->mask & IN_DELETE) { if (event->mask & IN_ISDIR) { printf("The directory %s was deleted.\n", event->name); } else { printf("The file %s was deleted.\n", event->name); } } if (event->mask & IN_MODIFY) { if (event->mask & IN_ISDIR) { printf("The directory %s was modified.\n", event->name); } else { printf("The file %s was modified.\n", event->name); } } if (event->mask & IN_MOVED_FROM) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was moved from.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was moved from.\n", event->name, event->cookie); } } if (event->mask & IN_MOVED_TO) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was moved to.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was moved to.\n", event->name, event->cookie); } } if (event->mask & IN_MOVE_SELF) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %ds was itself moved.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was itself moved.\n", event->name, event->cookie); } } if (event->mask & IN_DELETE_SELF) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was itself deleted.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was itself deleted.\n", event->name, event->cookie); } } if (event->mask & IN_OPEN) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was opened.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was opened.\n", event->name, event->cookie); } } if (event->mask & IN_ATTRIB) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d attr was changed.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d attr was changed.\n", event->name, event->cookie); } } if (event->mask & IN_ACCESS) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was accessed.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was accessed.\n", event->name, event->cookie); } } } } (void) inotify_rm_watch(fd, wd[0]); (void) close(fd); exit(0); }
Řešení dotazu:
i += EVENT_SIZE + event->len;
#define EVENT_SIZE ( sizeof (struct inotify_event) ) #define BUF_LEN ( 1024 * ( EVENT_SIZE + 16 ) ) int main(int argc, char **argv) { int length, i; int fd; int wd; char buffer[BUF_LEN]; struct inotify_event *event; fd = inotify_init(); if (fd < 0) perror("inotify_init"); wd = inotify_add_watch(fd, "/home/tomesh/Dropbox/C/sync", IN_ALL_EVENTS); while (1) { i = 0; length = read(fd, buffer, BUF_LEN); if (length < 0) perror("read"); if (length == 0) sleep(1); while (i < length) { event = (struct inotify_event *) &buffer[i]; if (event->mask & IN_CREATE) { if (event->mask & IN_ISDIR) { printf("The directory %s was created.\n", event->name); } else { printf("The file %s was created.\n", event->name); } } if (event->mask & IN_DELETE) { if (event->mask & IN_ISDIR) { printf("The directory %s was deleted.\n", event->name); } else { printf("The file %s was deleted.\n", event->name); } } if (event->mask & IN_MODIFY) { if (event->mask & IN_ISDIR) { printf("The directory %s was modified.\n", event->name); } else { printf("The file %s was modified.\n", event->name); } } if (event->mask & IN_MOVED_FROM) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was moved from.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was moved from.\n", event->name, event->cookie); } } if (event->mask & IN_MOVED_TO) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was moved to.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was moved to.\n", event->name, event->cookie); } } if (event->mask & IN_MOVE_SELF) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %ds was itself moved.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was itself moved.\n", event->name, event->cookie); } } if (event->mask & IN_DELETE_SELF) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was itself deleted.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was itself deleted.\n", event->name, event->cookie); } } if (event->mask & IN_ATTRIB) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d attr was changed.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d attr was changed.\n", event->name, event->cookie); } } if (event->mask & IN_ACCESS) { if (event->mask & IN_ISDIR) { printf("The directory %s with cookie %d was accessed.\n", event->name, event->cookie); } else { printf("The file %s with cookie %d was accessed.\n", event->name, event->cookie); } } i += sizeof(struct inotify_event) +event->len; } } (void) inotify_rm_watch(fd, wd); (void) close(fd); exit(0); }
Tiskni
Sdílej: