Steve Jobs a superpočítač Cray-1 budou vyobrazeny na pamětních jednodolarových mincích vyražených v příštím roce v rámci série Americká inovace. Série má 57 mincí, tj. 57 inovací. Poslední 4 mince budou vyraženy v roce 2032.
Byl zveřejněn průběžně aktualizovaný program konference OpenAlt 2025 o otevřeném softwaru a datech, IT bezpečnosti, DIY a IoT. Konference proběhne o víkendu 1. a 2. listopadu v prostorách FIT VUT v Brně. Vstup je zdarma.
Senát včera opětovně nepřijal návrh ústavního zákona, který měl do Listiny základních práv a svobod zakotvit právo občanů platit v hotovosti nebo být off-line. Návrh předložila skupina senátorů již v roce 2023. Senát dnes návrh neschválil, ale ani nezamítl. Pokud by ho přijal, dostala by ho k projednání Sněmovna a vyjádřila by se k němu vláda.
V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 13.0 (Mastodon). Forgejo je fork Gitei.
Společnost Eclypsium se na svém blogu rozepsala o bezpečnostním problému počítačů Framework. Jedná se o zranitelnost v UEFI umožňující útočníkům obejít Secure Boot.
Editor kódů Zed (Wikipedie) po macOS a Linuxu s verzí 0.208.4 už běží také ve Windows.
Apple dnes představil 14palcový MacBook Pro, iPad Pro a Apple Vision Pro s novým čipem M5.
Debian pro mobilní zařízení Mobian (Wikipedie) byl vydán ve verzi 13 Trixie. Nová stabilní verze je k dispozici pro PINE64 PinePhone, PinePhone Pro a PineTab, Purism Librem 5, Google Pixel 3a a 3a XL, OnePlus 6 a 6T a Xiaomi Pocophone F1.
Operátor O2 představil tarif Datamanie 1200 GB . Nový tarif přináší 1200 GB dat s neomezenou 5G rychlostí, a také možnost neomezeného volání do všech sítí za 15 Kč na den. Při roční variantě předplatného zákazníci získají po provedení jednorázové platby celou porci dat najednou a mohou je bezstarostně čerpat kdykoli během roku. Do 13. listopadu jej O2 nabízí za zvýhodněných 2 988 Kč. Při průměrné spotřebě tak 100 GB dat vychází na 249 Kč měsíčně.
Byly publikovány informace o útoku na zařízení s Androidem pojmenovaném Pixnapping Attack (CVE-2025-48561). Aplikace může číst citlivá data zobrazovaná jinou aplikací. V demonstračním videu aplikace čte 2FA kódy z Google Authenticatoru.
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 if
y - 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 .