Po více než 7 měsících vývoje od vydání verze 6.8 byla vydána nová verze 6.9 svobodného open source redakčního systému WordPress. Kódové jméno Gene bylo vybráno na počest amerického jazzového klavíristy Gene Harrise (Ray Brown Trio - Summertime).
Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za listopad (YouTube).
Google Chrome 143 byl prohlášen za stabilní. Nejnovější stabilní verze 143.0.7499.40 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 13 bezpečnostních chyb.
Společnost Valve aktualizovala přehled o hardwarovém a softwarovém vybavení uživatelů služby Steam. Podíl uživatelů Linuxu dosáhl 3,2 %. Nejčastěji používané linuxové distribuce jsou Arch Linux, Linux Mint a Ubuntu. Při výběru jenom Linuxu vede SteamOS Holo s 26,42 %. Procesor AMD používá 66,72 % hráčů na Linuxu.
Canonical oznámil (YouTube), že nově nabízí svou podporu Ubuntu Pro také pro instance Ubuntu na WSL (Windows Subsystem for Linux).
Samsung představil svůj nejnovější chytrý telefon Galaxy Z TriFold (YouTube). Skládačka se nerozkládá jednou, ale hned dvakrát, a nabízí displej s úhlopříčkou 10 palců. V České republice nebude tento model dostupný.
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 25.11.1. Přehled novinek v Changelogu.
Byla vydána nová verze 15.0 svobodného unixového operačního systému FreeBSD. Podrobný přehled novinek v poznámkách k vydání.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04 1.1 a 20.04 OTA-11. Vedle oprav chyb a drobných vylepšení je řešen také středně závažný bezpečnostní problém.
I letos vyšla řada ajťáckých adventních kalendářů: Advent of Code 2025, Perl Advent Calendar 2025, CSS Advent Calendar 2025, Advent of A11Y 2025, Advent of AI Security 2025, Advent of Agents (in Google) 2025, Advent of Svelte 2025, …
if $a < $b; then echo "a < b" fiprosim vas ako ? najeko sa stale mocem dokola a nejde mi to ...?
if [ $(bc << EOF $a < $b EOF ) -eq 1 ]; then echo "a < b" else echo "a > b" fi
[ $(dc <<<"[1pq]sa$a $b>a0p") -eq 1 ] && echo "a < b" || echo "a > b"
function rnle() {
test `echo -e "$1\\n$2" | sort -g | head -n 1` = $1
}
function rnge() {
test `echo -e "$1\\n$2" | sort -g | head -n 1` = $2
}
rnlt() {
if [ ${1:0:1} == '-' -a ${2:0:1} == '-' ]
then
rngt ${1:1} ${2:1}
return $?
fi
IFS='.'
a=($1)
b=($2)
[ ${a[0]} -lt ${b[0]} ] && return 0
[ ${a[0]} -gt ${b[0]} ] && return 1
i=0
while :
do
[ -z "${a[1]:$i:1}" -a -n "${b[1]:$i:1}" ] && return 0
[ -z "${b[1]:$i:1}" ] && return 1
[ ${a[1]:$i:1} -lt ${b[1]:$i:1} ] && return 0
let i++
done
}
rngt() {
if [ ${1:0:1} == '-' -a ${2:0:1} == '-' ]
then
rnlt ${1:1} ${2:1}
return $?
fi
IFS='.'
a=($1)
b=($2)
[ ${a[0]} -gt ${b[0]} ] && return 0
[ ${a[0]} -lt ${b[0]} ] && return 1
i=0
while :
do
[ -n "${a[1]:$i:1}" -a -z "${b[1]:$i:1}" ] && return 0
[ -z "${a[1]:$i:1}" ] && return 1
[ ${a[1]:$i:1} -gt ${b[1]:$i:1} ] && return 0
let i++
done
}Teda zatím to není úplně blbuvzdorné a používá se to.rnlt $a $b && echo 'a < b' || echo 'a >= b'
function rnle() {
[ ${1/.*} -lt ${2/.*} ] && return 0
[ ${1/.*} -gt ${2/.*} ] && return 1
if [ ${1:0:1} = '-' ]; then
[ ! ${1#*.}0 \> ${2#*.}0 ]
else
[ ! ${2#*.}0 \> ${1#*.}0 ]
fi
}
$ rnle 3.45 3.345 && echo OK OK $ rnle 3 3.345 && echo OK $Nicméně, když na to teď s odstupem koukám, tak je to fakt hnus, co takhle:
rnle() {
IFS='.'
a=($1)
b=($2)
[ $a -lt $b ] && return 0
[ $a -gt $b ] && return 1
if [ ${a:0:1} == '-' ]
then
a[0]=${b[1]}
b=${a[1]}
else
a=${a[1]}
b=${b[1]}
fi
for((i=${#a};i<${#b};i++)); do a=${a}0; done
for((i=${#b};i<${#a};i++)); do b=${b}0; done
[ $a -ge $b ] && return 1
return 0
}
function rnle() {
[ ${1/.*} -lt ${2/.*} ] && return 0
[ ${1/.*} -gt ${2/.*} ] && return 1
if [ ${1:0:1} = '-' ]; then
[ ! ${2#*.}0 \> ${1#*.}0 ]
else
[ ! ${1#*.}0 \> ${2#*.}0 ]
fi
}
rnlt() {
if [ ${1/.*} -ne ${2/.*} ]
then [ ${1/.*} -lt ${2/.*} ]
elif [ ${1:0:1} = '-' ]
then [ ${1#*.}0 \> ${2#*.}0 ]
else [ ${2#*.}0 \> ${1#*.}0 ]
fi
}Tak dnešní kontest jsi vyhrál
function rnlt()
{
celacast_1=`echo $1|cut -d. -f 1`;
descast_1=`echo $1|cut -d. -f 2`;
celacast_2=`echo $2|cut -d. -f 1`;
descast_2=`echo $2|cut -d. -f 2`;
if [ $celacast_1 -eq $celacast_2 ]
then
if [ $celacast_1 -lt 0 ]
then
descast_1=`expr -1 \* $descast_1`;
descast_2=`expr -1 \* $descast_2`;
fi
[ $descast_1 -lt $descast_2 ]&& return 0;
return 1;
else
[ $celacast_1 -lt $celacast_2 ]&& return 0;
return 1;
fi
}
${variable#pattern}, ${variable%pattern} a používat IFS by ušetřilo hodně zbytečných subprocesů.
Tiskni
Sdílej: