Byla vydána (𝕏) nová verze 24.7 open source firewallové a routovací platformy OPNsense (Wikipedie). Jedná se o fork pfSense postavený na FreeBSD. Kódový název OPNsense 24.7 je Thriving Tiger. Přehled novinek v příspěvku na fóru.
Binarly REsearch upozorňuje na bezpečnostní problém PKFail (YouTube) v ekosystému UEFI. Stovky modelů zařízení používají pro Secure Boot testovací Platform Key vygenerovaný American Megatrends International (AMI) a jeho privátní část byla při úniku dat prozrazena. Do milionů zařízení (seznam v pdf) po celém světě tak útočníci mohou do Secure Bootu vložit podepsaný malware. Otestovat firmware si lze na stránce pk.fail. Ukázka PoC na Linuxu na Windows na YouTube.
Mobilní operační systém /e/OS (Wikipedie) založený na Androidu / LineageOS, ale bez aplikací a služeb od Googlu, byl vydán ve verzi 2.2 (Mastodon, 𝕏). Přehled novinek na GitLabu. Vypíchnuta je rodičovská kontrola.
Společnost OpenAI představila vyhledávač SearchGPT propojující OpenAI modely umělé inteligence a informace z webů v reálném čase. Zatím jako prototyp pro vybrané uživatele. Zapsat se lze do pořadníku čekatelů.
Distribuce Linux Mint 22 „Wilma“ byla vydána. Je založená na Ubuntu 24.04 LTS, ale s desktopovým prostředím Cinnamon (aktuálně verze 6.2), příp. MATE nebo Xfce, balíkem aplikací XApp, integrací balíčků Flatpak a dalšími změnami. Více v přehledu novinek a poznámkách k vydání.
Příspěvek na blogu Truffle Security: Kdokoli může přistupovat ke smazaným a privátním repozitářům na GitHubu.
Byla vydána nová verze 14 integrovaného vývojového prostředí (IDE) Qt Creator. Podrobný přehled novinek v cgitu. Vypíchnout lze podporu rozšíření v Lua.
Byla vydána verze 1.80.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Apple oznámil, že v beta verzi spustil své Apple Maps na webu. Podporován je také webový prohlížeč Chrome. Ne však na Linuxu.
Portál Stack Overflow po roce opět vyzpovídal své uživatele, jedná se především o vývojáře softwaru, a zveřejnil detailní výsledky průzkumu. Průzkumu se letos zúčastnilo více než 65 tisíc vývojářů. Z Česka jich bylo 710. Ze Slovenska 246.
Řešení dotazu:
$(...)
je command substitution (tradičně `...`
), $((...))
je arithmetic expansion (tradičně $[...]
).
$(...)
spustí příkaz(y) v subshellu
$((...))
provádí matematické výpočty (např. $(( 100 * 100 ))
)
$(...)
spustí příkaz(y) v subshellu
Především expanduje na výstup toho příkazu; na samotné spuštění v subshellu stačí (...)
$(...)
s $((...))
. Oboje má i neexpandující verze: (...)
a ((...))
.
???
man dash1. Takže jen potvrzujete, že smyslem command substitution je poskytnout výstup příkazu jako výsledek expanze.
2. Tazatel se výslovně ptal na bash, takže citace z manuálové stránky jiného shellu není zrovna nejvhodnější argument. :-)
$(...)
. Je to jeho účel, jak je popsáno i v té manuálové stránce: spustí příkaz(y) v subshellu a nahradí se za jejich standardní výstup. Navíc to nijak nepopírám. Znova opakuji, srovnával jsem $(...)
s $((...))
. Oboje dělá substitution (jak se můžete v manuálových stránkách dočíst (...) | while ...
? Taky to používám nesmyslně a mám používat $(...)
, protože to první nemá jako účel vracení standardního výstupu?
DELETED_FILES="$(find . -name *.old -exec rm {} \; -print)"
, používám to tedy špatně, protože spouštění příkazů není účel $(...)
?
$(...)
slouží ke spuštění příkazů v subshellu a vrácení jejich standardního výstupu. Doporučuji si to přečíst alespoň čtyřikrát, třeba to pochopíš.
$(...)
nebo `...`
, a zkuste sám sobě upřímně odpovědět na otázku, proč jste (primárně) tuto konstrukci použil. Jestli to bylo proto, aby se ten příkaz provedl v subshellu, nebo proto, abyste mohl jeho výstup uložit do proměnné, použít coby argument(y) nebo jiným způsobem dále zpracovat.
jeho výstup se vrátilje zásadní vlastnost té konstrukce. Když část o vrácení výstupu vynecháš, tedy chceš pouze něco spustit v subshellu, použiješ (...), tedy jinou konstrukci. Toto vše ovšem už bylo několikrát řečeno, takže to asi přestává mít cenu...
$(...) spustí příkaz(y) v subshelluPodstatné je, že vráti štandardný výstup príkazu, ktorý sa da ďalej použije ako argument pre premennú (resp. operátor priradenia) alebo funkciu. To je jeho ǔčel. Príkaz sa pritom len tak mimochodom spustí v subshelli, toť vše. Čo píšeš je rovnaké, ako hovoriť, že by primárnym účelom spaľovacieho motora v automobile bolo vytvárať teplo a len mimochodom ho používame na získanie krútiaceho momentu/hybnej sily. Pritom jeho primárny účel je práve to zabezpečenie hybnej sily, vznikajúce teplo je len technický detail, nie zámerný, ani účelný, ale skrátka to jednoduchým spôsobom inak nejde - vznietenie paliva je exotermická reakcia.
slouží ke spuštění příkazů v subshellu a vrácení jejich standardního výstupu.Správna formulácia by mala byť slúži k vráteniu štandardného výstupu z príkazu, a časť "pričom ho spustí v subshelli" je len technický detail, pretože inak to snáď ani nejde. Skrátka reagovali na to, že si to vo svojom prvom príspevku napísal zle. Nepoužívaš ten príkaz na spustenie subshellu, ale kvôli vráteniu štd. výstupu, čo je jeho účel.
cmpxchg
? Je snad jeho účelem ty hodnoty prohodit a to porovnávání dělá jen tak mimochodem?
Tiskni
Sdílej: