V Bolzanu probíhá konference SFSCON (South Tyrol Free Software Conference). Jean-Baptiste Kempf, zakladatel a prezident VideoLAN a klíčový vývojář VLC media playeru, byl na ní oceněn cenou European SFS Award 2025 udělovanou Free Software Foundation Europe (FSFE) a Linux User Group Bolzano‑Bozen (LUGBZ).
Open-source minimalistický trackball Ploopy Nano byl po modelech modelech Classic a Thumb Trackball také aktualizován. Nová verze Nano 2 používá optický senzor PAW3222 a k původně beztlačítkovému designu přidává jedno tlačítko, které ve výchozí konfiguraci firmwaru QMK přepíná režim posouvání koulí. Sestavený trackball nyní vyjde na 60 kanadských dolarů (bez dopravy a DPH).
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.
# find /tmp -not -iregex '^/tmp.*' # PARAM="-not -iregex '^/tmp.*'" # find /tmp $PARAM /tmp /tmp/.ICE-unix /tmp/backup.cpio /tmp/mc-root /tmp/.font-unix /tmp/.font-unix/fs7100 # echo $PARAM -not -iregex '^/tmp.*'
<14:53:25> find /tmp -not -iregex '^/tmp.*' <14:53:52> PARAM='-not -iregex ^/tmp.*' <14:54:14> find /tmp $PARAM <14:54:23>
... a escapovat pro bash se mi teda moc nechce...Je uplne jedno ci sa Ti to chce alebo nie.
Kolega ma teoriu, ze kazdy problem z regexpami treba zacat riesit zdvojnasobovanim poctu spatnych lomitok. No ale mam tu aj skript, kde na prepasovanie jedneho spatneho lomitka cielovemu programu je potrebnych 10 spatnych lomitok v skripte.
Díky
-x, t.j. napisat skript z hlavickou
#! /bin/sh -x
$PARAM se pravděpodobně předá jako jeden parametr, shell už jej nerozdělí na tři. Pokud je akceptovatelné omezení na konkrétní shell, třeba bash, tak řešení je pole:
PARAM=(-not -iregex '^/tmp.*'); find /tmp ${PARAM[@]}
${PARAM[@]} expanduje právě na řadu oddělených položek z pole.
find /tmp "-not -iregex '^/tmp.*'"
tak find vrátí
find: invalid predicate `-not -iregex '^/tmp.*''
A tedy že pokud by to předalo v jednom parametru, tak by to psal také. Nevím, proč find tuto chybu nehlásil, nicméně s kulatými závorkami to funguje. Díky!
Co bych tedy měl napsat, abych nemusel používat pole? Celé to uvodit ještě do jedněch uvozovek?
String se expanduje jen při přiřazení, ne při použití. -- jak mám rozumnět tomuhle? Když dám přeci
echo $PARAMS
tak to vypíše ty parametry správně, tudíž se tedy expanduje, nebo ne?
Díky za zpřesnení
# a=a; b=b:$a; a=c; echo $b:$a b:a:cAle ono to pro expanzi cest neplatí, jak jsme si myslel, protože ta se koná až úplně na konci po expanzi proměnných ... takže když tam z nějaké proměnné vypadne hvězdička, tak ta se ještě potom expanduje, což jsem předtím myslel, že ne.
No stručně řečeno, mám v tom sám pěkný borčus, jak zjišťuju. Odvolávám, co jsme odvolal a řešení s polem je asi nejlepší. Jen jsem tam myslím nakonec zapomněl uvozovky, správně je to takhle:
# PARAMS=(-not -iregexp '*'); echo "${PARAMS[@]}"
-not -iregexp *
Bez uvozovek na konci by se hvězdička ještě expandovala. Uvozovky v PARAMS= zas zajistí, že se nebude expandovat při přiřazení. Jak jedny tak druhé uvozovky nakonec zmizí.
Řešení bez pole a bez nutnosti vše escapovat mě teď nenapadá. Protože pokud má být v proměnné víc oddělených parametrů, je nutné ji přesvěčit, aby se jako celek rozsekala (takže ji nejde dát při použití celou do uvozovek), ale zároveň aby se neexpandovaly kusy uvnitř a zároveň aby v ní nezustaly žádné přebytečné uvozovky. A to mě fakt nenapadá jak.
Totiž, ono ten tvůj původní kód má ještě jednu zradu:
# touch \'pokus\' # ls a.txt b.txt c.txt 'pokus' # PARAMS="-not -iregexp '*'"; echo $PARAMS -not -iregexp 'pokus'tedy dokonce ani korektně neescapuje. Teď už fakt nevím přesně proč, ale zdá se, že uvozovka vypadlá z expanze proměnné se chová jako literal uvozovka a ne jako escape. Takže IMO to bez pole nijak normálně nejde. Dokonce i důsledné escapování se chová divně:
# touch \\pokus # ls \pokus # PARAMS="-not -iregexp \*"; echo $PARAMS -not -iregexp \*Tady už fakt nechápu, proč tam zároveň zůstal backslash a zároveň nechytl ten soubor, co skutečně začíná backslashem ...
No, měl jsem pocit, že bash celkem chápu, ale zdá se, že moc ne ...
)
Tiskni
Sdílej: