O víkendu (15:00 až 23:00) probíhá EmacsConf 2023, tj. online konference vývojářů a uživatelů editoru GNU Emacs. Sledovat ji lze na stránkách konference. Záznamy jsou k dispozici přímo z programu.
Na čem aktuálně pracují vývojáři GNOME a KDE? Pravidelný přehled novinek i s náhledy aplikací v Týden v GNOME a Týden v KDE.
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.
#!/bin/sh function testip() { n=`echo $1|grep '^[0-9][0-9]*\.[0-9][0-9]*\.[0-9][0-9]*\.[0-9][0-9]*$'|wc -l` if [ $n -ge 1 ]; then return 0 else return 1 fi } if testip $1; then echo OK else echo Not an IP fi
[[ "$1" =~ "[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}" ]] && echo ano
[[ "$1" =~ "^[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$" ]] && echo anopředtím by totiž prošly i věci jako 10.10.10.10.10.10
[[ "$1" =~ "^1[0-9]{1,2}\.[0-5]{1,3}\.[0-5]{1,3}\.[0-5]{1,3}$" ]] && echo ano
[[ "$1" =~ "^1[0-9]{1,2}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}$" ]] && echo anosamozřejmě tento vzor vyhoví i nesmyslným adresám jako: 192.168.999.999
#!/bin/bash echo $1 | awk -F '.' ' { if($1>0 && $1 <=255 && $2>0 && $2 <=255 && $3>0 && $3 <=255 && $4>0 && $4 <=255) { print $0; } }' >
deb http://ftp.cz.debian.org/debian jessie main contrib non-free
pokud je IP adresa, vytiskne ji; pokud neni, nevytiskne nicA je funkční, takže je vítězem ;) Ale ještě jednou díky všem. Problém vyřešen. Mějte se, smějte se#!/bin/bash echo $1 | awk -F '.' ' { if($1>0 && $1 <=255 && $2>0 && $2 <=255 && $3>0 && $3 <=255 && $4>0 && $4 <=255) { print $0; } }' >
#!/bin/bash echo $1 | awk -F '.' ' { if( NF==4 ) if($1>0 && $1 <=255 && $2>0 && $2 <=255 && $3>0 && $3 <=255 && $4>0 && $4 <=255) { print $0; } }'výše uvedenému totiž vyhoví řetězce jako 192.168.10.10.10.10.10.10
$x>0
by mela byt $x>=0
deb http://ftp.cz.debian.org/debian jessie main contrib non-free
#!/usr/bin/awk -f BEGIN { FS="."; } { if(NF==4 && $1>=0 && $1 <=255 && $2>=0 && $2 <=255 && $3>=0 && $3 <=255 && $4>=0 && $4 <=255) print; }
deb http://ftp.cz.debian.org/debian jessie main contrib non-free
#!/bin/bash [[ "${1//[0-9]/}" == "..." ]] || exit 1 for i in ${1//./ }; do let count++ [[ $i -ge 0 && $i -le 255 ]] || exit 1 done [[ $count -eq 4 ]] || exit 1 exit 0Pripadne sa da IFS=. Kto ako chce
Dobry den.
Sice uz je to vyresene, ale ciste v bash bez dalsich binarek to tady jeste nebylo:
if [[ "$ADRESA" =~ "^ *([0-9]+)\.([0-9]+)\.([0-9]+)\.([0-9]+) *$" ]] \ && [ "${BASH_REMATCH[1]}" -lt 256 ] \ && [ "${BASH_REMATCH[2]}" -lt 256 ] \ && [ "${BASH_REMATCH[3]}" -lt 256 ] \ && [ "${BASH_REMATCH[4]}" -lt 256 ] then $ADRESA="${BASH_REMATCH[1]}.${BASH_REMATCH[2]}.${BASH_REMATCH[3]}.${BASH_REMATCH[4]}" else echo "error: \"$ADRESA\" je neplatna" 1>&2 exit 3; fi
Omlouvam se uz bylo..
marek
[[
který tam nakonec už je jednou použit.
$ type echo [ [[ test echo is a shell builtin [ is a shell builtin [[ is a shell keyword test is a shell builtin[[ je v bashi rychlejší než [
root@duron:/bin# ls -l /bin | grep '\[' -rwxr-xr-x 1 root root 25256 2007-06-09 03:12 [U mě je to binárka na disku. Leda, že se [ v bashi použije přednostně.
type
.
bash$ type [ [ is a shell builtin bash$ type /usr/bin/[ /usr/bin/[ is /usr/bin/[Takže je rozdíl jestli napíšete
[ 0 -eq 1 ]
nebo /usr/bin/[ 0 -eq 1 ]
IP=[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\} ip="123.123.123.123" if [[ "$ip" =~ ^$IP$ ]]; then echo "OK" else echo "ERR" fi echo "$ip" | grep -q "^$IP$" - if [ $? -eq 0 ] ; then echo "OK" else echo "ERR" fi
#!/bin/bash
#oket 1 - 4
o1=1
o2=255
o3=0
o4=999
[ $(( $o1/256 )) == 0 ] &&
[ $(( $o2/256 )) == 0 ] &&
[ $(( $o3/256 )) == 0 ] &&
[ $(( $o4/256 )) == 0 ] && echo "je to IP adresa"
Tiskni
Sdílej: