Github publikoval Octoverse 2025 (YouTube), tj. každoroční přehled o stavu open source a veřejných softwarových projektů na GitHubu. Každou sekundu se připojil více než jeden nový vývojář. Nejpoužívanějším programovacím jazykem se stal TypeScript.
Kit je nový maskot webového prohlížeče Firefox.
Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.5. Přehled novinek s náhledy v oznámení na blogu.
Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.
Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.
Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.
Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀
Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
Byl publikován plán na odstranění XSLT z webových prohlížečů Chrome a Chromium. S odstraněním XSLT souhlasí také vývojáři Firefoxu a WebKit. Důvodem jsou bezpečnostní rizika a klesající využití v moderním webovém vývoji.
Desktopové prostředí LXQt (Lightweight Qt Desktop Environment, Wikipedie) vzniklé sloučením projektů Razor-qt a LXDE bylo vydáno ve verzi 2.3.0. Přehled novinek v poznámkách k vydání.
exit je normalni prikaz, neodchytava se. Jestli je ve skriptu, tak napis potrebne veci pred nej. Jestli tam neni, pripis svoje prikazy na konec skriptu.
Pokud mas na mysli signal SIGTERM, kterym se obvykle ukoncuji procesy (napriklad prikazem kill), tak k tomu se pouziva prikaz trap. Zde je priklad:
#!/bin/bash
trap terminator TERM
terminator() {
echo -e "\nSkript byl zabit."
exit 1
}
while true; do
echo -n "."
sleep 1
done
Kdyz ten skript spustis v jednom terminalu, tak se bude vykonavat nekonecna smycka. Kdyz vyvolas jeho ukonceni (treba prikazem killall skript z jineho terminalu), provedou se prikazy popsane ve funkci "terminator" (lze zvolit libovolny jiny nazev). Kdybys chtel odchytit jiny signal, treba SIGINT, ktery se posila pri stisknuti kombinace ctrl-c, nahrad slovo TERM slovem INT. Vice o signalech najdes v man 7 signal nebo v manualu ke kill, killall apod.
exit ve skriptu), trap lze pověsit i na exit přes "sigspec" 0 (resp. EXIT). Tedy v příklady výše: trap terminator 0
Druhá poznámka: napřed bych funkci definoval, potom teprve přiřadil k trap. Takhle v jednu chvíli máme trap odkazující na neexistující volání.
Třetí poznámka je od věci: killall je strašně škaredý zlozvyk, na což člověk při troše smůlu přijde ve chvíli, kdy si sedne před něco, co vypadá jako Linux (něco System V kompatibilního), ale není to Linux. Raději pkill. ;)
Nicméně pokud chcete (třeba centrálně ošetřený úklid, bez nutnosti volat příslušnou funkci před každýmNo tohle bych přesně potřeboval ale nějak jsem vás nepochopil jak to přesně myslíte. Můžete to ještě trochu rozvést případně nějakou ukázku? Díkyexitve skriptu),traplze pověsit i naexitpřes "sigspec" 0 (resp. EXIT). Tedy v příklady výše:trap terminator 0
#!/bin/bash
# Funkce, ktera se ma vykonat pred ukoncenim behu
ukoncovaciFunkce() {
# Treba mazani docasnych adresaru, zde nic
:
# Explicitni ukonceni behu je nutne pouze v pripade, ze zachytavete i
# jine udalosti nez EXIT, zde priklad vzdy vraci 0
exit 0
}
# Nastavi trap pri ukonceni se napred zavola ukoncovaciFunkce
trap ukoncovaciFunkce EXIT
# Vlastni skript, kdekoliv se zaloval exit (nebo beh dojde na konec skriptu),
# vykona se ukoncovaciFunkce
exit 0
Platí i ten zbytek, tj. odkaz na man -s7 signal. Stejnou funkci můžete přiřadit vícero událostem (nejen signály, více je popsáno v manuálu bash), příp. můžete na různé pověsit různá volání. Např. zmiňovanému signálu SIGTERM (15, výchozí kill) nebo typicky chcete zachytávat SIGINT (2, přerušení z klávesnice, onbykle ^C).
Ještě poznámka k EXIT. Nastane při ukončení shellu, takže kdybyste chytal jiné události a také EXIT a prováděl tutéž akci, vykoná se dvakrát (např. jednou při zachycení SIGINT a podruhé při ukončení samotného procesu shellu).
V takom prípade stačí spustiť to spracovávanie hneď za tým spúšťaným skriptom.Tomu moc nerozumím...
echo "test 1" ./skript.sh echo "test 2"tak sa ten druhý príkaz echo spustí po tom, ako sa ukončí skript.sh (či už kvôli chybe, alebo preto, lebo je v ňom exit). Takže ak treba po vykonaní toho skriptu niečo urobiť, netreba používať trap.
v souboru start.sh mám
#!/bin/bash
ukoncovaciFunkce() {
echo "Konec!"
exit 0
}
trap ukoncovaciFunkce EXIT
while [[ 1 ]]
do
./skript1.sh
./skript2.sh
done
exit 0
a v souboru skript1.sh a skript2.sh budu mít třeba jen exit 1 or exit 0 tak se nevypíše "Konec" a hlavní script se stejně neukončí. Ten Trap funguje jenom v tom souboru start.sh, jinak už ne a to nevím jak ošetřit, proto jsem se ptal, jestli to musí být v každém souboru...
trap se nedědí z rodičovského shellu. Ty další skripty jsou samostatně spuštěné procesy bash, viz:
$ trap -p
trap -- '' SIGTSTP
trap -- '' SIGTTIN
trap -- '' SIGTTOU
$ trap /bin/true EXIT
$ trap -p
trap -- '/bin/true' EXIT
trap -- '' SIGTSTP
trap -- '' SIGTTIN
trap -- '' SIGTTOU
$ bash
$ trap -p
trap -- '' SIGTSTP
trap -- '' SIGTTIN
trap -- '' SIGTTOU
Takže si buď v jednotlivých procesech shellu nastavíte vlastní zachytávání, nebo v uvedením případě můžete alternativně ty skripty místo spouštění vkládat a zachytávat pro ně událost RETURN. Pak ale naopak nesmíte ty další skripty ukončovat s exitem, neb jste stále ve stejné procesu a ukončíte si tento:
skript1.sh:
echo "ve skript1.sh"hlavni.sh:
#!/bin/bash
navratovaAkce() {
echo "a jsme zpet"
}
trap navratovaAkce RETURN
echo "vlozime skript1.sh"
source skript1.sh
exit 0
Technicky to možné je, nicméně bych se klonil k první variantě ošetřit si to místně.
Třetí poznámka je od věci:Tesat do kamene! :Dkillallje strašně škaredý zlozvyk, na což člověk při troše smůlu přijde ve chvíli, kdy si sedne před něco, co vypadá jako Linux (něco System V kompatibilního), ale není to Linux. Radějipkill. ;)
Tiskni
Sdílej: