Příspěvek na blogu Codean Labs rozebírá zranitelnost CVE-2024-4367 v PDF.js, tj. mj. prohlížeči PDF souborů ve Firefoxu. Při otevření útočníkem připraveného pdf souboru může být spuštěn libovolný kód v JavaScriptu. Vyřešeno ve Firefoxu 126.
Lazygit byl vydán ve verzi 0.42.0. Jedná se o TUI (Text User Interface) nadstavbu nad gitem.
K open source herní konzole Picopad přibyla (𝕏) vylepšená verze Picopad Pro s větším displejem, lepšími tlačítky a větší baterii. Na YouTube lze zhlédnout přednášku Picopad - open source herní konzole z LinuxDays 2023.
Byla vydána (𝕏) nová major verze 17 softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech GitLab (Wikipedie). Představení nových vlastností i s náhledy a videi v oficiálním oznámení.
Sovereign Tech Fund, tj. program financování otevřeného softwaru německým ministerstvem hospodářství a ochrany klimatu, podpoří vývoj FFmpeg částkou 157 580 eur. V listopadu loňského roku podpořil GNOME částkou 1 milion eur.
24. září 2024 budou zveřejněny zdrojové kódy přehrávače Winamp.
Google Chrome 125 byl prohlášen za stabilní. Nejnovější stabilní verze 125.0.6422.60 přináší řadu oprav a vylepšení (YouTube). Podrobný přehled v poznámkách k vydání. Opraveno bylo 9 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
Textový editor Neovim byl vydán ve verzi 0.10 (𝕏). Přehled novinek v příspěvku na blogu a v poznámkách k vydání.
Byla vydána nová verze 6.3 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.15.
Dnes ve 12:00 byla spuštěna první aukce domén .CZ. Zatím největší zájem je o dro.cz, kachnicka.cz, octavie.cz, uvycepu.cz a vnady.cz [𝕏].
grep(1)
$ echo `date +%Y/%m/%d--%k:%M:%S` `ping -c 3 www.google.com | head -n 4 | tail -n 1` 2008/08/14--16:27:08 64 bytes from fx-in-f104.google.com (74.125.39.104): icmp_seq=1 ttl=240 time=22.0 ms
Z obratu
echo `příkaz`
mi vždycky trochu běhá mráz po zádech. :-)
echo $$ `echo \$\$`
3925 3925
To nebyl dobrý příklad, protože ve vašem případě ke spuštění subshellu zrovna dojde, přestože příkaz je interní (nebo spíš právě proto). Zkuste si napsat prográmek showpid
, který vám jen zobrazí své PID, např.:
#include <stdio.h> #include <unistd.h> int main() { printf("%lu\n", (unsigned long) getpid()); return 0; }
Pak si napište obdobu toho vašeho skriptu:
#!/bin/bash ./showpid echo $$ `echo \$\$` ./showpid
Dostanete výstup
15683 15682 15682 15685
zatímco po zakomentování prostředního řádku
15697 15698
echo $$ `perl -e 'print getppid;'`
echo
je v bashi interní (builtin) příkaz. Zkuste si to pustit pod 'strace -f
', uvidíte, že execve()
se spouští pouze dvakrát, a to na showpid
. Navíc tam jasně uvidíte write()
, kterým proces s "vynechaným" PID posílá svému rodiči jeho (ne svoje) PID.
echo `ls -1 /`
ls -1 | tr "\n" " "
Já přeci netvrdím, že jste neměl pravdu v ničem. Jen jsem vás upozornil, že ten příklad v příspěvku z 20:03 je naproto nevhodný, protože to je zrovna ukázkový příklad situace, kdy nový proces vznikne. Pokud se se mnou chcete hádat, polemizujte, prosím, jen s tím, co jsem napsal. Chcete-li tvrdit, že nemám pravdu, pak ukažte konkrétní nepravdivé tvrzení, kterého jsem se dopustil.
pokud se podle Vas opravdu spousti subshell v novem procesu, tak proc je $$ stejna, hmm?
Že by proto, že v této situaci onen samostatný proces (kterým je stále bash, žádné execve()
se tam nevolá) jako $$
záměrně neuvádí své skutečné PID, ale hodnotu zděděnou od svého rodiče, hmm? Právě proto, aby to vypadalo, jako by builtin příkaz běžel stále v kontextu téhož shellu, hmm? Udělejte si ten pokus a podívejte se na výstup 'strace -f
', tam to uvidíte naprosto zřetelně.
( date ; ping -c 1 www.seznam.cz | grep icmp ) | awk '{ printf "%s: ", $0; getline; print }'
tr -d "\n"
Tiskni Sdílej: