PimpMyGRC upravuje vzhled toolkitu GNU Radio a přidává alternativní barevná témata. Primárním cílem autora bylo pouze vytvořit tmavé prostředí vhodné pro noční práci, nicméně k dispozici je nakonec celá škála barevných schémat včetně možností různých animací a vizuálních efektů (plameny, matrix, bubliny...), které nepochybně posunou uživatelský zážitek na zcela jinou úroveň. Témata jsou skripty v jazyce Python, které nahrazují
… více »GIMP 3.2 byl oficiálně vydán (Mastodon, 𝕏). Přehled novinek v poznámkách k vydání.
FRANK OS je open-source operační systém pro mikrokontrolér RP2350 (s FRANK M2 board) postavený na FreeRTOS, který přetváří tento levný čip na plně funkční počítač s desktopovým uživatelským rozhraním ve stylu Windows 95 se správcem oken, terminálem, prohlížečem souborů a knihovnou aplikací, ovládaný PS/2 myší a klávesnicí, s DVI video výstupem. Otázkou zůstává, zda by 520 KB SRAM stačilo každému 😅.
Administrativa amerického prezidenta Donalda Trumpa by měla dostat zhruba deset miliard dolarů (asi 214 miliard Kč) za zprostředkování dohody o převzetí kontroly nad aktivitami sociální sítě TikTok ve Spojených státech.
Projekt Debian aktualizoval obrazy stabilní větve „Trixie“ (13.4). Shrnuje opravy za poslední dva měsíce, 111 aktualizovaných balíčků a 67 bezpečnostních hlášení. Opravy se týkají mj. chyb v glibc nebo webovém serveru Apache.
Agent umělé inteligence Claude Opus ignoroval uživatelovu odpověď 'ne' na dotaz, zda má implementovat změny kódu, a přesto se pokusil změny provést. Agent si odpověď 'ne' vysvětlil následovně: Uživatel na mou otázku 'Mám to implementovat?' odpověděl 'ne' - ale když se podívám na kontext, myslím, že tím 'ne' odpovídá na to, abych žádal o svolení, tedy myslí 'prostě to udělej, přestaň se ptát'.
Po 8. květnu 2026 už na Instagramu nebudou podporované zprávy opatřené koncovým šifrováním. V chatech, kterých se bude změna týkat, se objeví pokyny o tom, jak si média nebo zprávy z nich stáhnout, pokud si je chcete ponechat.
V lednu byla ve veřejné betě obnovena sociální síť Digg (Wikipedie). Dnes bylo oznámeno její ukončení (Hard Reset). Společnost Digg propouští velkou část týmu a přiznává, že se nepodařilo najít správné místo na trhu. Důvody jsou masivní problém s boty a silná konkurence. Společnost Digg nekončí, malý tým pokračuje v práci na zcela novém přístupu. Cílem je vybudovat platformu, kde lze důvěřovat obsahu i lidem za ním. Od dubna se do Diggu na plný úvazek vrací Kevin Rose, zakladatel Diggu z roku 2004.
MALUS je kontroverzní proprietarní nástroj, který svým zákazníkům umožňuje nechat AI, která dle tvrzení provozovatelů nikdy neviděla původní zdrojový kód, analyzovat dokumentaci, API a veřejná rozhraní jakéhokoliv open-source projektu a následně úplně od píky vygenerovat funkčně ekvivalentní software, ovšem pod libovolnou licencí.
Příspěvek na blogu Ubuntu upozorňuje na několik zranitelností v rozšíření Linuxu o mandatorní řízení přístupu AppArmor. Společně jsou označovány jako CrackArmor. Objevila je společnost Qualys (technické detaily). Neprivilegovaný lokální uživatel se může stát rootem. Chyba existuje od roku 2017. Doporučuje se okamžitá aktualizace. Problém se týká Ubuntu, Debianu nebo SUSE. Red Hat nebo Fedora pro mandatorní řízení přístupu používají SELinux.
Poslal jsem také kus zdrojového kódu, obsahující jen to nezbytné.
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <signal.h>
#include <stdio.h>
#include <string.h>
// odstraneni procesu drive, nez se z nej stane zombie
void clean_up_child(int sig_num) {
wait(NULL);
printf("Odstraneni procesu.\n"); fflush(stdout);
}
// vytvori proces, presmeruje in na stdin a spusti prikaz
// vraci cislo procesu potomka a do out ulozi vstupni FD jako vystup dat potomka
int make_child(char **cmd_params, int in, int &out) {
int fds[2];
pid_t pid;
pipe(fds); // vytvoreni pipy
pid = fork(); // vytvoreni potomka
if (pid > 0) { // rodic
close(fds[1]); // uzavreni vystupniho FD
out = fds[0]; // vraceni vstupniho FD
printf("Prikaz '%s', pid=%d, fds[0]=%d, fds[1]=%d, in=%d\n", cmd_params[0], pid, fds[0], fds[1], in); fflush(stdout);
return pid;
}
else if (pid == 0) { // potomek
close(fds[0]); // uzavreni vstupniho FD
// presmerovani stdin na in
close(STDIN_FILENO);
dup2(in, STDIN_FILENO);
close(in);
// presmerovani stdout na FD
close(STDOUT_FILENO);
dup2(fds[1], STDOUT_FILENO);
close(fds[1]);
printf("Before Exec '%s'\n", cmd_params[0]); fflush(stdout);
// spusteni prikazu
execvp(cmd_params[0], cmd_params);
return -1; // exec se vratil - vznikla chyba
}
else { // chyba forku
return -1;
}
return 0;
}
int main(void) {
// zabraneni vzniku zombie procesu
/* struct sigaction sigact;
memset(&sigact, 0, sizeof(sigact));
sigact.sa_handler = &clean_up_child;
sigaction(SIGCHLD, &sigact, NULL);
*/
int out, out1, out_end, r;
int r1, r2, r3;
char *cmd1[] = {"ls", "-laR", "/etc", 0};
char *cmd2[] = {"sort", 0};
char *cmd3[] = {"grep", "bin", 0};
r1 = make_child(cmd1, STDIN_FILENO, out);
r2 = make_child(cmd2, out, out1);
r3 = make_child(cmd3, out1, out_end);
char str_out[256];
if (r1 == -1 || r2 == -1 || r3 == -1) {
printf("Error while making child!\n"); fflush(stdout);
}
// vypsani vystupu posledniho prikazu
while ((r = read(out_end, str_out, 255)) > 0)
write(STDOUT_FILENO, str_out, r);
printf("\n");
close(out_end);
return 0;
}
if (pid > 0) { // rodic. Obycejne se tam i hlidaji vracene return kody. Rekl bych, ze mas problem s casovanim, ze se ti ty prikazy vykonavaji tak rychle jak to jen jde a tedy skoro paralelene a tedy si prikazy navzajem nepredavaji potrebne vstupy a vystupy. Necekaji na sebe.
...
// vypsani vystupu posledniho prikazu
while ((r = read(out_end, str_out, 255)) > 0)
write(STDOUT_FILENO, str_out, r);
printf("\n");
wait(NULL);
close(out_end);
return 0;
}
#include <errno.h>
...
do {
r = read(out_end, str_out, 255);
if (r == -1) {
if (errno == EINTR) {
continue;
} else {
perror("chyba pri cteni");
exit(1);
}
}
write(STDOUT_FILENO, str_out, r);
} while (r != 0);
Ten wait tam přeci vůbec nemusí být, ne? Handler vypíše, že byl potomek ukončen a program skončí.Potomka - zombie odstraní pouze příkaz wait nebo jeho odvozenina. Handler bez funkčního volání příkazu wait si může vypisovat co chce, ale potomka - zombie určite neodstraní.
Teď jsem dal ten výpis před wait a vypsalo ho to jen jednou. Přitom by mělo 3x?
Tiskni
Sdílej: