CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.
Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].
Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.
Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.
Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.
Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.
Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.
Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.
Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.
Google na včerejší akci The Android Show | I/O Edition 2026 (YouTube) představil celou řadu novinek: Gemini Intelligence, notebooky Googlebook, novou generaci Android Auto, …
diff -coznaci radky, ktere jsou jine, vykricnikem:(!) na zacatku radku. No a napadlo me brat dycky radek po radku z kazdeho souboru do nejakeho tmp (tmp='tmpfile' kvuli bezpecnosti), ty porovnat diffem, pokud je radek stejny, tak appendnout
>>do tmp souboru, pokud je radek jiny, diff ho oznaci a taky (oznaveny) radek pripne do tmp soubor. Pak tmp prepise puvodni soubor. Pseudoskript by vypadal nejak takto:
#!/bin/bash
while read line; do
echo $line > tmp #vezme radek
#zde porovnava s druhym, ale jak, nejakou vhodnou funkci?
cat tmp >> temporary #pripina do dalsiho docasneho postupne radek po radku, vcetne oznacenych
done < "sample.txt"
Byl bych rad, kdyby me nekdo nakopnul spravnym smerem.
Řešení dotazu:
tmpfile=`mktemp`. Je lepsi pouzit mktemp nez vytvoreni noveho docasneho souboru (kvuli symlink vulnerability). Pro potreby pseudokodu je to vsak irelevantni (navic mktemp umozni bezproblemove spusteni skriptu na jednom pocitaci vicekrat). Kdyby slo porovnat soubory diffem tak, aby mi tako vystup hodil jiz oznacene soubory, bylo by to fajn. Ale nevim, jak to udelat, nikde jsem takovou moznost nevygooglil, proto me napadl ten postup s porovnanim radek po radku. Zkratka, kdyz mam v jednom souboru:
aaaaa bbbbba v druhem:
aaaaa ccccctak chci, aby vystup skriptu byly soubory, ve kterych by byly nejak oznacene radky, ktere se neshoduji, napr v prvnim souborU:
aaaaa (!)bbbbbv druhem:
aaaaa (!)ccccc
#! /bin/bash
input1="$1"
input2="$2"
while read line
do
if grep -e "$line" "$input2" &>/dev/null
then
sed -i "s/$line/\!$line/" "$input1" "$input2"
fi
done <./"$input1"
Ako zaklad by to mohlo byt. Docasnymi subormi by som sa netrapil, iba to komplikuje vec. Staci spravit zalohu originalu pre spustenim skriptu.
Treba opravit sed, lebo v danom skripte pri prvej zhode konci. Spravne to ma byt:
sed -i "s/$line/\!$line/g" "$input1" "$input2"
Aj ste to skusali spustit ??? Bo robi to, co ste chceli. Ak porovnavam dva subory a hladam zhodu, tak ak sa prejde cely prvy subor riadok po riadku, tak nie je dovod kontrolovat kazdy riadok z druheho a porovnavat s riadkami v prvom subore.
Vid ukazku:
#! /bin/bash
input1="$1"
input2="$2"
while read line
do
if grep -w -e "$line" "$input2" &>/dev/null
then
sed -i "s/$line/\!$line/" "$input1" "$input2"
fi
done <"$input1"
test2.file
aaaaa fdsafasdsdafbbbbb cccccsfdsfsd fffffff gggggasfsdf hjlkk ewiorjodsfsdfsdf ad;kl jlkfsfafaf xxxxxxdfsdfaf
test1.file
aaaaa bbbbb ccccc fffffff ggggg hjlkk ewiorjo ad;kl jlk xxxxxx
Po spusteni skriptu je vysledok nasledovny:
Lucias-MacBook-Pro:~ lucka$ grep -n ^! test*.file test1.file:1:!aaaaa test1.file:2:!bbbbb test1.file:4:!fffffff test1.file:6:!h!jlkk test1.file:8:!ad;kl test2.file:1:!aaaaa test2.file:4:!fffffff test2.file:6:!h!jlkk test2.file:8:!ad;kl Lucias-MacBook-Pro:~ lucka$ grep -v -n ^! test*.file test1.file:3:ccccc test1.file:5:ggggg test1.file:7:ewiorjo test1.file:9:jlk test1.file:10:xxxxxx test2.file:2:fdsafasdsdaf!!bbbbb test2.file:3:cccccsfdsfsd test2.file:5:gggggasfsdf test2.file:7:ewiorjodsfsdfsdf test2.file:9:jlkfsfafaf test2.file:10:xxxxxxdfsdfaf
Subory vyzeraju samozrejme inak, len som chcel ukazat zhody osve od riadkov, kde ku zhodam nedoslo, aby si si to mohol porovnat a videl dovod, preco je iba mrhanim prostriedkov konat inak.
sed: -e expression #1, char 47: unknown option to `s' sed: -e expression #1, char 40: unknown option to `s' sed: -e expression #1, char 44: unknown option to `s' sed: -e expression #1, char 51: unknown option to `s'Jeda se vzdy o ukoncovaci tagy. Da se tohle nejak obejit?
]$ ./compare.sh file1.txt file2.txt sed: -e expression #1, char 84: unknown option to `s' sed: -e expression #1, char 28: unknown option to `s' sed: -e expression #1, char 74: unknown option to `s'Poukazuji na to, ze problem je v samotnych textovych souborech, ktere obsahuji tagy. Vypada to nejak takto:
<s> veta </s> <s>druha veta </s>Soubory samotne modifikovat modifikovat nijak nemuzu, format vety uzavrenych mezi tagy musi zustat zachovan.
Jaky prikaz mate na mysli? Spusteni skriptu?
Ne, pochopitelně příkaz sed, který vám tu chybu hlásí. Bez toho, abyste ukázal, s jakými parametry ho voláte, můžu jen hádat naslepo.
sed -e "s/^${line//\//\\/}$/\!&/"
(stříška a dolar jsou nutné, aby to nenašlo i řádky, které obsahují řádek z prvního souboru jako podřetězec), ale stejně tam budou dělat problémy všechny ostatní konstrukce regulárních výrazů, např. tečka. Další chyba je v použití "read line", které odstraní počáteční a koncové mezery. A konečně se při upravování druhého souboru mění soubor, vůči kterému porovnáváme další řádky. Takže když už to dělat takhle, tak spíš
#!/bin/bash
matches1=`mktemp`
matches2=`mktemp`
i=1
while read; do
line="$REPLY"
j=1
while read; do
if [ "$line" = "$REPLY" ]; then
echo $i >>"$matches1"
echo $j >>"$matches2"
fi
: $[j++]
done <"$2"
: $[i++]
done <"$1"
aux=`mktemp`
prev=0
exec 3<"$1"
sort -n -u "$matches1" | while read next; do
for ((i=prev; i<next; i++)); do
read <&3
echo "$REPLY" >>"$aux"
done
read <&3
echo "!$REPLY" >>"$aux"
done
rm -f "$matches1"
mv -f "$aux" "$1"
aux=`mktemp`
prev=0
exec 3<"$2"
sort -n -u "$matches2" | while read next; do
for ((i=prev; i<next; i++)); do
read <&3
echo "$REPLY" >>"$aux"
done
read <&3
echo "!$REPLY" >>"$aux"
done
rm -f "$matches2"
mv -f "$aux" "$2"
(píšu to z hlavy a nemám čas to zkoušet, takže tam asi budou nějaké chybičky)
sed -i "s#$line#!$line#g" "$input1" "$input2"A zda se, ze to dela co potrebuju.
…nebo kterýkoli znak nebo kombinace znaků, které mají v regulárních výrazech speciální význam. A samozřejmě to bude matchovat i podřetězce.
Gratuluji, podařilo se vám úspěšně ignorovat všechno, co jsem napsal ve svém příspěvku. Hlavně že jste si to označil jako řešení…
sed -e "s/^${line//\//\\/}$/\!&/"
nefunguje. Skript neudela nic, nic neoznaci.
Mně to funguje:
mike@unicorn:~> line=x/y
mike@unicorn:~> sed -e "s/^${line//\//\\/}$/\!&/" <<EOT
ax/yb
x/y
xy
EOT
ax/yb
!x/y
xy
comm (ale pozor, funguje jen na seřazené soubory).
Psal jsem, ze chci nakopnoutV tom případě použij oblíbený vyhledávač a zadej "bash mapfile" - ale raději si ověř, že v zadání bylo bash skript.
Tiskni
Sdílej: