ČTK (Česká tisková kancelář) upozorňuje (X), že na jejím zpravodajském webu České noviny byly dnes dopoledne neznámým útočníkem umístěny dva smyšlené texty, které nepocházejí z její produkce. Jde o text s titulkem „BIS zabránila pokusu o atentát na nově zvoleného slovenského prezidenta Petra Pelligriniho“ a o údajné mimořádné prohlášení ministra Lipavského k témuž. Tyto dezinformace byly útočníky zveřejněny i s příslušnými notifikacemi v mobilní aplikaci Českých novin. ČTK ve svém zpravodajském servisu žádnou informaci v tomto znění nevydala.
Byla založena nadace Open Home Foundation zastřešující více než 240 projektů, standardů, ovladačů a knihoven (Home Assistant, ESPHome, Zigpy, Piper, Improv Wi-Fi, Wyoming, …) pro otevřenou chytrou domácnost s důrazem na soukromí, možnost výběru a udržitelnost.
Společnost Meta otevírá svůj operační systém Meta Horizon OS pro headsety pro virtuální a rozšířenou realitu. Vedle Meta Quest se bude používat i v připravovaných headsetech od Asusu a Lenova.
Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.
Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.
50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.
Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.
Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].
Ještě letos vyjde Kingdom Come: Deliverance II (YouTube), pokračování počítačové hry Kingdom Come: Deliverance (Wikipedie, ProtonDB Gold).
Thunderbird 128, příští major verze naplánovaná na červenec, přijde s nativní podporou Exchange napsanou v Rustu.
rm
aby smazal jenom [A-Z]
soubory?
..omlouvám se, je to stupidní ale nic mě nenapadá, tj. ani pod čím bych to našel... (Když nic tak aspoň script, please ;) )
rm $(ls | egrep '^[A-Z]+$')
rm: too few arguments
Try `rm --help' for more information.
je přesně to co to vrátí. Jinak soubory mají tvar XXX.xxx
až XXX~1.xxx
, typická ošklivá DOS
jména...
rm "$(ls |egrep '^[A-Z]+.h3m')"
a vrátilo mi to:
cannot remove \nXXX.h3m
Takže už zbývá jenom odtázka jak převést \n
na mezeru?
man sed
/n
nebo ho opravit v následujícím příkazu budu ti jen vděčný.
rm "$(ls | egrep '^[A-Z][A-Z]+.h3m')"
..operace je prováděna na FAT32 disku
..dotaz jsem dodatečně upřesnil
ls
hodí na jeden řádek víc jmen a s tím se (e)grep neporadí...
for i in *; do if [ "$(echo $i | egrep '^[A-Z ]+$')" ]; then rm "$i" fi done
DOS 8.3 name
, tudíž i s mezerami
~
a číslo/a
[A-Z,.-_ ]
, všechny znaky povolené znaky v DOSu si už prostě nepamatuju.
hynek[~]$ echo a | egrep '[A-Z]' a hynek[~]$
echo a | egrep '[A-Z]*'
? To by bylo v pořádku.
echo a
není vůbec žádný znak z ropzsahu [A-Z]
. Mě se ta úloha nedaří vyřešit jinak, než grep -v '[a-z]'
. Můj grep i bash si prostě myslí, že když napíšu [A-Z]
, měl jsem patrně na mysli [a-zA-Z]
a asi jsem byl jen línej.
[e]grep
a bash
poněkud nas... echo a | perl -ne 'm/[A-Z]/ && print'
"Many locales sort characters in dictionary order, and in these locales [a-d] is typically not equivalent to [abcd]; it might be equivalent to [aBbCcDd], for example. To obtain the traditional interpretation of bracket expressions, you can use the C locale by setting the LC_ALL environment variable to the value C."
Takže následující funguje podle očekávání:
dunric@darkstar:~$ echo a | LC_ALL=C grep '[A-Z]'
dunric@darkstar:~$
dunric@darkstar:~$ echo A | LC_ALL=C grep '[A-Z]'
A
dunric@darkstar:~$
$ locale LANG=cs_CZ.UTF-8 LC_CTYPE="cs_CZ.UTF-8" LC_NUMERIC="cs_CZ.UTF-8" LC_TIME="cs_CZ.UTF-8" LC_COLLATE=C LC_MONETARY="cs_CZ.UTF-8" LC_MESSAGES="cs_CZ.UTF-8" LC_PAPER="cs_CZ.UTF-8" LC_NAME="cs_CZ.UTF-8" LC_ADDRESS="cs_CZ.UTF-8" LC_TELEPHONE="cs_CZ.UTF-8" LC_MEASUREMENT="cs_CZ.UTF-8" LC_IDENTIFICATION="cs_CZ.UTF-8" LC_ALL= $ grep '[á-é]' Neoprávněný přístup do paměti (SIGSEGV)Zkusím se na to někdy o víkendu kouknout...
grep
namá, jak se zdá, regexp připravený na unicode.
Within a bracket expression, a range expression consists of two charac- ters separated by a hyphen. It matches any single character that sorts between the two characters, inclusive, using the locale's collating sequence and character set. For example, in the default C locale, [a-d] is equivalent to [abcd]. Many locales sort characters in dictio- nary order, and in these locales [a-d] is typically not equivalent to [abcd]; it might be equivalent to [aBbCcDd], for example. To obtain the traditional interpretation of bracket expressions, you can use the C locale by setting the LC_ALL environment variable to the value C.To je ale záludnost
hynek[~]$ LC_ALL=C hynek[~]$ echo a | egrep '[A-Z]' hynek[~]$Řešením je samozřejmě použít i [:upper:]. Funguje to například i v
rm [[:upper:]]*případně
find -name '[[:upper:]]*' -print0 | xargs -0 rm(Maže soubory začínající na velké písmeno)
Tiskni Sdílej: