Před 60 lety, 1. května 1964, byl představen programovací jazyk BASIC (Beginners' All-purpose Symbolic Instruction Code).
Byla vydána nová verze 12.0 minimalistické linuxové distribuce (JeOS, Just enough Operating System) pro Kodi (dříve XBMC) a multimediálního centra LibreELEC (Libre Embedded Linux Entertainment Center). Jedná se o fork linuxové distribuce OpenELEC (Open Embedded Linux Entertainment Center). LibreELEC 12.0 přichází s Kodi 21.0 "Omega".
Microsoft vydal novou velkou aktualizaci 2404.23 v září 2019 pod licencí SIL Open Font License (OFL) zveřejněné rodiny písma Cascadia Code pro zobrazování textu v emulátorech terminálu a vývojových prostředích.
OpenTofu, tj. svobodný a otevřený fork Terraformu vzniknuvší jako reakce na přelicencování Terraformu z MPL na BSL (Business Source License) společností HashiCorp, bylo vydáno ve verzi 1.7.0. Přehled novinek v aktualizované dokumentaci. Vypíchnout lze State encryption.
Spouštět webový prohlížeč jenom kvůli nákupu kávy? Nestačí ssh? Stačí: ssh terminal.shop (𝕏).
Yocto Project byl vydán ve verzi 5.0. Její kódové jméno je Scarthgap. Yocto Project usnadňuje vývoj vestavěných (embedded) linuxových systémů na míru konkrétním zařízením. Cílem projektu je nabídnou vývojářům vše potřebné. Jedná se o projekt Linux Foundation.
Operační systém 9front, fork operačního systému Plan 9, byl vydán v nové verzi "do not install" (pdf). Více o 9front v FQA.
Svobodná webová platforma pro sdílení a přehrávání videí PeerTube (Wikipedie) byla vydána v nové verzi 6.1. Přehled novinek i s náhledy v oficiálním oznámení a na GitHubu. Řešeny jsou také 2 bezpečnostní chyby.
Lennart Poettering na Mastodonu představil utilitu run0. Jedná se o alternativu k příkazu sudo založenou na systemd. Bude součástí systemd verze 256.
Hudební přehrávač Amarok byl vydán v nové major verzi 3.0 postavené na Qt5/KDE Frameworks 5. Předchozí verze 2.9.0 vyšla před 6 lety a byla postavená na Qt4. Portace Amaroku na Qt6/KDE Frameworks 6 by měla začít v následujících měsících.
Broken pipe
.A v tu chvili cely soft spadne a je konec. Uz jsem googlil co se dalo ale nikde jsem nic nenasel nevite nekdo kde by mohla byt chyba? prikladam dve fce ve ktereych se to deje. teda spis si myslim ze to je problem toho Slackwaru nez meho programovani. preklad provadim pomoci g++ "zdroj.cpp" -o "vystup"
. Hlaska se objevi po return
u z fce.
unsigned int exec_command (const char *p_command) { FILE *pipe_cmd=NULL; if ((pipe_cmd=popen(p_command,"w"))==NULL){ fprintf(stderr,"Don't open pipe!\n"); exit(1); } fputs(p_command, pipe_cmd); pclose(pipe_cmd); return 0; }nebo pro cteni
unsigned int read_command (const char *p_command) { FILE *pipe_cmd=NULL; char p_cmd[50]=("cat /var/log/syslog | grep "), vystup[2]; strcat (p_cmd, p_command); if ((pipe=popen(p_cmd,"r"))==NULL) { fprintf(stderr,"Nelze spustit externi prikaz!\n"); exit (1); } if ((fgets(vystup, 2, pipe))!=NULL) { pclose (pipe); return 1; } else { pclose (pipe); return 0; } }
iptables
a to prez cecko asi neporesim. a ja proste potrebuju cist vystup toho prikazu. a prikaz system
vraci jen jestli se provedlo ci nikoliv.
popen
musí být "r"
, ne "w
". Hláška "broken pipe" znamená, že se pokoušíte zapisovat do roury, jejíž druhý konec mezitím druhá strana zavřela. V tomto případě příkaz iptables
skončí, aniž by četl to, co mu posíláte na stadardní vstup.
puts
nekontroluju protoze jsem to testoval. jestli jde aspon spoustet kdyz ne cist. vstupni parametry tech funkci jsou osetreny pri volani tech f-ci. takze v tele samotnych f-ci mi to prijde vcelku zbytecne. jinak dekuji za reakce. stale nehazim flintu do zita a experimentuju. prepisovat do perlu se mi to fakt nechce.
void pipebreak(int sig) { } ... signal(SIGPIPE, pipebreak);(tohle ovsem neni priklad hodny nasledovani). Nicmene podle me tam je nejaka nekonzistence v tom co ty spoustene prikazy vypisuji (asi jina verze na obou pocitaich) a tak to bude asi potreba nejak osetrit.
(tohle ovsem neni priklad hodny nasledovani).Podle mně je to naprosto v pohodě (i když mnohem lepší ignorovat je pomocí
signal(SIGPIPE, SIG_IGN)
(pozn. default je terminate). Potom se ta chyba projeví tak že fputs selže a v errno je EPIPE (tuším).
Každopádně na ladění takových chyb je nejlepší strace -f
1/ spousteny command jsem skladal do pole deklarovaneho jako cmd[300] 2/ udelal jsem z nej dynamicky aloccovane a najednou zacal fungovat i sprintf 3/ ve vstupech do funkci jsem udelal z pointeru na command staicky command[300]a funguje.
Tiskni Sdílej: