Anthropic patrně omylem zveřejnil celý zdrojový kód svého CLI nástroje Claude Code prostřednictvím přiloženého sourcemap souboru v npm balíčku. Únik odhalil doposud nijak nezveřejněné funkce jako je například režim v utajení, autonomní agent 'KAIROS', orchestrace multi‑agentů, režim snění nebo dokonce virtuální mazlíček Buddy. Zajímavostí je detekce naštvání uživatele pomocí obyčejného regexpu. Anthropic rychle odstranil sourcemap a vydal opravu, nicméně kopie kódu se již stihly na GitHubu rozšířit mezi prostým lidem.
Copilot automaticky vkládal do pull requestů 'propagační tipy', reklamní text se na GitHubu objevil ve více než jedenácti tisících pull requestech. Po vlně kritiky byla tato funkce zablokována a produktový manažer Tim Rogers připustil, že umožnit Copilotovi upravovat cizí pull requesty bez vědomí autorů byla chyba.
Je 31. března a tedy Světový den zálohování (World Backup Day). Co by se stalo, kdyby Vám právě teď odešel počítač, tablet nebo telefon, který používáte?
Digitální a informační agentura (DIA) přistupuje ke změně formátu důvěryhodného seznamu České republiky z verze TLv5 na verzi TLv6, která nastane 29. dubna 2026 v 00:00 (CET). Ke změně formátu důvěryhodných seznamů členských států (tzv. Trusted Lists) dochází na základě změn příslušné unijní legislativy. Důvěryhodné seznamy se používají v rámci informačních systémů a aplikací zejména pro účely ověřování platnosti elektronických
… více »Rspamd (Wikipedie), tj. open source systému pro filtrování nevyžádané pošty, byl vydán v nové major verzi 4.0.0. Přehled novinek v Changelogu.
SolveSpace (Wikipedie), tj. multiplatformní open source parametrický 2D/3D CAD, byl vydán v nové verzi 3.2. Přehled novinek v Changelogu na GitHubu. Vyzkoušet lze novou oficiální webovou verzi.
Organizátoři Dne IPv6, tradiční akce věnované tématům spojeným s tímto protokolem, vyhlásili Call for Abstracts. Na webu konference mohou zájemci přihlašovat příspěvky o délce 20 nebo 40 minut či 10minutové lighting talky a to až do 30. dubna. Tvůrci programu uvítají návrhy přednášek z akademického i komerčního sektoru, které mohou být technického i netechnického zaměření. Den IPv6 se letos uskuteční 4. června a místem konání bude i
… více »Euro-Office (Wikipedie) je evropský fork open source kancelářského balíku OnlyOffice. Za forkem stojí koalice firem IONOS, Nextcloud, Eurostack, XWiki, OpenProject, Soverin, Abilian a BTactic. Cílem je zajistit digitální suverenitu Evropy a snížit závislost na neevropských platformách. Projekt vznikl mimo jiné v reakci na nedávné uzavření cloudové služby OnlyOffice. OnlyOffice obviňuje Euro-Office z porušení licenčních podmínek. Na možné problémy upozorňuje i Collabora Online. Jednostranná změna licence není v pořádku.
Byly zpracovány a na YouTube zveřejněny videozáznamy jednotlivých přednášek z letošního Installfestu.
Během akce Arduino Days 2026 byl publikován Arduino Open Source Report 2025 (pdf) a oznámeno 7 nových produktů kompatibilních s deskou UNO Q (Arduino USB-C Power Supply, USB-C Cable, USB-C Hub, UNO Media Carrier, UNO Breakout Carrier, Bug Hopper, Modulino LED Matrix).
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: