UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.3. Současně oznámila, že nadcházející větší vydání 24.04-2.0 bude mít modernější webový prohlížeč.
Ploopy po DIY trackballech či sluchátkách představuje nový externí DIY trackpoint se čtyřmi tlačítky Bean. Obsahuje snímač Texas Instruments TMAG5273, spínače Omron D2LS-21 a řadič RP2040, používá firmware QMK. Schémata jsou na GitHubu; sadu lze předobjednat za 69 kanadských dolarů (bez dopravy a DPH).
Mozilla před dvěma týdny na svém blogu oznámila, že díky Claude Mythos Preview bylo ve Firefoxu nalezeno a opraveno 271 bezpečnostních chyb. Včera vyšel na Mozilla Hacks článek s podrobnějšími informacemi. Z 271 bezpečnostních chyb mělo 180 chyb vysokou závažnost, 80 chyb střední závažnost a 11 chyb nízkou závažnost. Celkově bylo v dubnu ve Firefoxu opraveno 423 bezpečnostních chyb. Čísla CVE nemusí být přiřazována jednotlivým chybám. CVE-2026-6784 například představuje 154 bezpečnostních chyb.
Před týdnem zranitelnost Copy Fail. Dnes zranitelnost Dirty Frag. Běžný uživatel může na Linuxu získat práva roota (lokální eskalaci práv). Na většině linuxových distribucí vydaných od roku 2017. Aktuálně bez oficiální záplaty a CVE čísla [oss-security mailing list].
Ačkoli je papež Lev XIV. hlavou katolické církve a stojí v čele více než miliardy věřících po celém světě, také on někdy řeší všední potíže. A kdo v životě neměl problémy se zákaznickou linkou? Krátce poté, co nastoupil do úřadu, musel papež se svou bankou řešit změnu údajů. Operátorka ale nechtěla uvěřit, s kým mluví, a Svatému otci zavěsila.
Incus, komunitní fork nástroje pro správu kontejnerů LXD, byl vydán ve verzi 7.0 LTS (YouTube). Stejně tak související LXC a LXCFS.
Google Chrome 148 byl prohlášen za stabilní. Nejnovější stabilní verze 148.0.7778.96 přináší řadu novinek z hlediska uživatelů i vývojářů. Vypíchnout lze Prompt API (demo) pro přímý přístup k AI v zařízení. Podrobný přehled v poznámkách k vydání. Opraveno bylo 127 bezpečnostních chyb. Vylepšeny byly také nástroje pro vývojáře.
Richard Hughes oznámil, že po společnostech Red Hat a Framework a organizacích OSFF a Linux Foundation, službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzorují také společnosti Dell a Lenovo. Do dnešního dne bylo díky LVFS provedeno více než 145 milionů aktualizací firmwarů od více než 100 různých výrobců na milionech linuxových zařízení.
Americké technologické společnosti Microsoft, Google a xAI souhlasily, že vládě Spojených států poskytnou přístup k novým modelům umělé inteligence (AI) před jejich uvedením na trh. Oznámila to americká vláda, která tak bude moci prověřit, zda modely nepředstavují hrozbu pro národní bezpečnost. Oznámení podtrhuje rostoucí obavy Washingtonu z rizik spojených s výkonnými AI systémy. Americké úřady chtějí v rámci předběžného přístupu
… více »Společnost Valve zveřejnila (GitLab) nákresy ovladače Steam Controller a puku. Pro všechny, kdo by jej chtěli hacknout nebo modifikovat, případně pro ně navrhnout nějaké příslušenství. Pod licencí Creative Commons (CC BY-NC-SA 4.0).
Učím se psát jednodušší skriptíky v Bashi. Chystám se napsat v Bashi "prográmek". Tak jsem vytvořil takovou knihovničku funkcí pro práci s čísly. A rád bych se s vámi o ni podělil. Doufám, že vám k něčemu bude, i když třeba jenom pro pobavení.
#!/bin/bash
#********************************************************************************************
## numbers.sh
## autor: Václav Radoměřský
## leden 2009
## licence: GNU GPL verze 2 nebo 3 nebo novější, nebo modifikovaná ("trojbodová") BSD licence
#********************************************************************************************
# Je to vlastně jakási "knihovna" funkcí, kterou můžete do svého shellového skriptu
# vložit příkazem source (.), příklad:
# source /cesta/numbers.sh
# nebo: . /cesta/numbers.sh
# Otestováno (je funkční) v Bash verze 3.2.39(1). Pokud nemáte extrémně starou verzi Bashe,
# tak by to mělo jet.
success=0
# hodnota, kterou budou funkce vracet v případě "úspěchu" (pravdy)
error=-1
# To je hodnota, kterou navrátí vybrané funkce v případě chyby
rrandom_number=-1
# rrandom_number je proměnná, ve které bude návratová hodnota funkce random_number
max_random=32767
# max_random udává největší pseudonáhodné číslo vrácené Bashem
min_random=0
# nejmenší pseudonáhodné číslo vracené Bashem
is_zero()
{
# Vrátí $succes, jestliže parametr číslo jedna je nula, jinak vrátí $error.
# Testujeme, zda byl funkci předán aspoň jeden argument
if [ $# -lt 1 ]
then
return $error
fi
# Testuje, zda dané číslo je rovno 0.
# napravo od =~ je regulární výraz
if [[ "${1}" =~ 0 ]]
then
return $success
else
return $error
fi
}
is_positive_number()
{
# Otestuje, zda $1 je kladné číslo. Vrátí hodnotu proměnné success, pokud argument je kladné číslo,
# jinak vrátí hodntou proměnné "error" (tedy ${error}).
# Testujeme, zda funkci byl předán aspoň jeden parametr ("argument")
if [ $# -lt 1 ]
then
return $error
fi
#
# Testujeme, zda první parametr je kladné číslo
# napravo od =~ je regulární výraz
if [[ "${1}" =~ ^[+]?[1-9]+[0-9]*$ ]]
then
return $success
else
return $error
fi
}
is_negative_number()
{
# Vrátí $succes, jestliže parametr číslo jedna je záporné číslo, jinak vrátí $error.
if [ $# -lt 1 ]
then
return $error
fi
# Napravo od =~ je regulární výraz.
if [[ "${1}" =~ ^-[1-9]+[0-9]*$ ]]
then
return $success
else
return $error
fi
}
is_nonnegative_number()
{
# Vrátí $success, pokud argument je nezáporné číslo, jinak vrátí $error.
if is_zero $1 || is_positive_number $1
then
return $success
else
return $error
fi
}
is_nonpositive_number()
{
# Vrátí $success v případě nekladného arguemntu (parametru), jinak vrátí $error.
if [ $# -lt 1 ]
then
return $error
fi
if is_zero $1 || is_negative_number $1
then
return $success
else
return $error
fi
}
is_number()
{
# Vrátí $succes, jestliže první parametr je číslo, jinak vrátí $error.
if [ $# -lt 1 ]
then
return $error
fi
if is_nonnegative_number $1 || is_nonpositive_number $1
then
return $success
else
return $error
fi
}
compare_numbers()
{
# Funkce porovná dvě čísla -- $1 a $2.
# Vrátí $success, pokud je druhý parametr funkce větší než první.
# Jinak vrátí hodnotu $error.
#
# Otestujeme, zda jsme dostali aspoň dva parametry (argumenty) a zda to jsou čísla.
if [ $# -ge 2 ] && is_number $1 && is_number $2
then
if [ $2 -gt $1 ]
then
return $success
else
return $error
fi
else
return $error
fi
}
random_number()
{
# Vrátí pseudonáhodné číslo z intervalu <$1;$2>.
# $1 musí být menší než $2.
# Tato funkce využívá "proměnné" RANDOM.
# Otestujeme, zda jsme dostali aspoň dva parametry ("argumenty"). V případě že ne, skončím s chybou.
if [ $# -lt 2 ]
then
return $error
fi
# Funkce compare_numbers nám zkontroluje, zda se jedná o čísla a zda je $2 > $1.
if compare_numbers $1 $2
then
rrandom_number=$RANDOM
# "Proměnná" RANDOM generuje pseudonáhodá čísla, viz man bash.
delka_intervalu=$(($2-$1))
max_delka_intervalu=$(($max_random-$min_random))
procentni_podil=$((( $rrandom_number-$min_random )*100/$max_delka_intervalu))
rrandom_number=$(($1+$procentni_podil*$delka_intervalu/100))
else
return $error
fi
}
Tiskni
Sdílej:
Není to zbytečně komplikované ? Jakou výhodu má třeba použití funkce is_nonnegative_number() místo klasického [[ $X -ge 0 ]] ? Taky mi příjde trošku těžkopádné používat regulární výrazy na to abych zjistil, zda je proměnná rovna nule.
Ale jako tréningový script to není špatné.
\u@\h:\w$ a=blarf
\u@\h:\w$ [ $a -eq 0 ] && echo 1;
[: 2: Illegal number: blarf
\u@\h:\w$ [ $a -eq 0 ] || echo 0;
[: 3: Illegal number: blarf
0
Ale jako tréningový script to není špatné.
Díky. 
Načo je dobré používať blok na jeden príkaz?
if [ $# -lt 1 ]
then
return $error
fi
.. namiesto ..
[ $# -lt 1 ] && return $error
Vidieť to v skriptoch dosť často, tak neviem, asi to príde niekomu prehľadnejšie.
then na stejném řádku s if a tělo bylo odsazené, považoval bych to za přehlednější.
Zdravim.
Dobry napad
ale trochu se mi nelibi ta kontrola poctu argumentu. Teda ona ta kontrola samotna je v poradku, ale i kdyz funkci nepredate pozadovany pocet argumentu, tak pokracujete v behu funkce. Pouze funkce compare_numbers se takto nechova, ale ja bych i tam tu kontrolu rozdelil na dva ify - v prvnim pocet argumentu a az v pripade spravneho poctu kontrola, zda to jsou cisla.
No a pokracovat muzete rozsirenim na desetinna cisla a na osmickova a hexa-cisla
.