Organizace Apache Software Foundation (ASF) vydala verzi 20 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Desktopové prostředí Cinnamon, vyvíjené primárně pro distribuci Linux Mint, dospělo do verze 6.0. Seznam změn obsahuje především menší opravy a v říjnovém přehledu novinek v Mintu avizovanou experimentální podporu Waylandu.
OpenZFS (Wikipedie), tj. implementace souborového systému ZFS pro Linux a FreeBSD, byl vydán ve verzích 2.2.2 a 2.1.14. Přináší důležitou opravu chyby vedoucí k možnému poškození dat.
V ownCloudu byly nalezeny tři kritické zranitelnosti: CVE-2023-49103, CVE-2023-49104 a CVE-2023-49105 s CVSS 10.0, 8.7 a 9.8. Zranitelnost CVE-2023-49103 je právě využívána útočníky. Nextcloudu se zranitelnosti netýkají.
I letos vychází řada ajťáckých adventních kalendářů. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2023. Pro programátory v Perlu je určen Perl Advent Calendar 2023. Zájemci o UX mohou sledovat Lean UXmas 2023. Pro zájemce o kybernetickou bezpečnost je určen Advent of Cyber 2023…
Byla vydána verze 2.12 svobodného video editoru Flowblade (GitHub, Wikipedie). Přehled novinek v poznámkách k vydání. Videoukázky funkcí Flowblade na Vimeu. Instalovat lze také z Flathubu.
Armbian, tj. linuxová distribuce založená na Debianu a Ubuntu optimalizovaná pro jednodeskové počítače na platformě ARM a RISC-V, ke stažení ale také pro Intel a AMD, byl vydán ve verzi 23.11 Topi. Přehled novinek v Changelogu.
Po 4 měsících vývoje byla vydána nová verze 4.2 multiplatformního open source herního enginu Godot (Wikipedie, GitHub). Přehled novinek i s náhledy v příspěvku na blogu a na YouTube.
Byla vydána nová stabilní verze 23.11 linuxové distribuce NixOS (Wikipedie). Její kódové označení je Tapir. Podrobný přehled novinek v poznámkách k vydání. O balíčky se v NixOS stará správce balíčků Nix.
Národní úřad pro kybernetickou a informační bezpečnost (NÚKIB) upozorňuje na hrozbu spojenou s používáním mobilní aplikace WeChat a její čínské verze Weixin (dále jen WeChat). Ta sbírá velký objem uživatelských dat, a právě to by – v kombinaci se způsobem jejich sběru – mohlo sloužit k přesnému zacílení kybernetických útoků.
Řešení dotazu:
(ls -1 a; ls -1 b)|sort|uniq -c|grep -vE "^ 2"(ale možná někoho napadne něco elegantnějšího)
for NAME in `(ls -1 a; ls -1 b)|sort|uniq -c|grep -vE "^ 2"|sed 's/ 1 //g'`; do find . -name $NAME; done(občas si říkám, jestli skutečně jsem takového prasení schopen ;)
for NAME in `(ls -1 a; ls -1 b)|sort|uniq -c|grep -vE "^ 2"|sed 's/^ 1 //g'`; do find . -name "$NAME"; donekdyby jméno souboru obsahovalo divoké znaky a sekvenci " 1 ".
diff <(ls dir1) <(ls dir2)
diff
i ls
již striktně vzato nesplňují zadání "v BASHi". Ale pokud to vezmete trochu utilitaristicky, tak takhle by to taky šlo (a je to méně pracné).
DIR1="dir1" DIR2="dir2" this_dir_only() { cd "${1}" || return 1 echo "Pouze v: ${1}" for obj in * do [ -e "../${2}/${obj}" ] || echo $obj done cd .. echo } this_dir_only "${DIR1}" "${DIR2}" this_dir_only "${DIR2}" "${DIR1}"
diff -rusq adresář1 adresář2a výsledek pak třeba nějak roztřídit podle potřeba. Vycházím z předpokladu, že v adresářích jsou další podadresáře které mohou něco obsahovat, takže nestačí porovnávat jen první úroveň vnoření jak asi dělá výše uvedená udělej-si-sám funkce.
diff -sq adresář1 adresář2 | grep "Only in adresář1"
find adresář1 adresář2 -maxdepth 1 -type f ! -name '.*' | cut -d "/" -f 2- | sort -u | while read f; do if [[ -f "a/$f" && ! -f "b/$f" ]]; then echo "Jen v adresář1: $f" elif [[ -f "b/$f" && ! -f "a/$f" ]]; then echo "Jen v adresář2: $f" else echo "Oba adresáře: $f"; fi done | sort -u
$ mkdir -p dir1/{x,y} ; touch dir1/{a,b,c,d,e} $ mkdir -p dir2/{y,z} ; touch dir2/{b,c,d,e,f}Varianta a:
$ diff <(ls dir1) <(ls dir2) 1d0 < a 6c5 < x/ --- > f 7a7 > z/Tedy jenom v prvním vlevo, jenom v druhem vpravo. Varianta b:
$ DIR1="dir1" $ DIR2="dir2" $ $ this_dir_only() > { > cd "${1}" || return 1 > echo "Pouze v: ${1}" > for obj in * > do [ -e "../${2}/${obj}" ] || echo $obj > done > cd .. > echo > } $ $ this_dir_only "${DIR1}" "${DIR2}" Pouze v: dir1 a x $ this_dir_only "${DIR2}" "${DIR1}" Pouze v: dir2 f zBuď jsem nepochopil zadání, nebo jste se někde uklep, nebo nevím? Pro úplnost zkoušeno na:
$ bash --version GNU bash, version 3.1.17(2)-release (x86_64-slackware-linux-gnu) Copyright (C) 2005 Free Software Foundation, Inc.a
GNU bash, version 3.2.25(1)-release (i386-pc-solaris2.11) Copyright (C) 2005 Free Software Foundation, Inc.
DIR1="dir1" DIR2="dir2" this_dir_only() { [ -d "${1}" -a -d "${2}" ] || return 1 pfx="" pushd "${1}" &> /dev/null || return 2 echo "Pouze v: ${1}" [ ${2:0:1} == "/" ] || pfx="../" for obj in * do [ -e "${pfx}${2}/${obj}" ] || echo $obj done popd &> /dev/null echo } this_dir_only "${DIR1}" "${DIR2}" this_dir_only "${DIR2}" "${DIR1}"
DIR1="dir1" DIR2="dir2" this_dir_only() { [ -d "${1}" -a -d "${2}" ] || return 1 top_dir="${PWD}" pfx="" pushd "${1}" &> /dev/null || return 2 echo "Pouze v: ${1}" [ ${2:0:1} == "/" ] || pfx="${top_dir}/" for obj in * do [ -e "${pfx}${2}/${obj}" ] || echo $obj done popd &> /dev/null echo } this_dir_only "${DIR1}" "${DIR2}" this_dir_only "${DIR2}" "${DIR1}"
in dir/*
?
function onlyinfirst { for ent in $1/*; do [ -e "$2/${ent##*/}" ] || echo $ent done } onlyinfirst $1 $2 onlyinfirst $2 $1
basename
, protože to už jste mimo BASH. Asi takhle, když už se ptáte:
this_dir_only() { [ -d "${1}" -a -d "${2}" ] || return 1 echo "Pouze v: ${1}" for obj in "${1}"/* do [ -e "${2}/${obj##*/}" ] || echo "${obj##*/}" done echo }
Tiskni
Sdílej: