Svobodná historická realtimová strategie 0 A.D. (Wikipedie) byla vydána ve verzi 28 (0.28.0). Její kódový název je Boiorix. Představení novinek v poznámkách k vydání. Ke stažení také na Flathubu a Snapcraftu.
Multimediální server a user space API PipeWire (Wikipedie) poskytující PulseAudio, JACK, ALSA a GStreamer rozhraní byl vydán ve verzi 1.6.0 (Bluesky). Přehled novinek na GitLabu.
UBports, nadace a komunita kolem Ubuntu pro telefony a tablety Ubuntu Touch, vydala Ubuntu Touch 24.04-1.2 a 20.04 OTA-12.
Byla vydána (Mastodon, 𝕏) nová stabilní verze 2.0 otevřeného operačního systému pro chytré hodinky AsteroidOS (Wikipedie). Přehled novinek v oznámení o vydání a na YouTube.
WoWee je open-source klient pro MMORPG hru World of Warcraft, kompatibilní se základní verzí a rozšířeními The Burning Crusade a Wrath of the Lich King. Klient je napsaný v C++ a využívá vlastní OpenGL renderer, pro provoz vyžaduje modely, grafiku, hudbu, zvuky a další assety z originální kopie hry od Blizzardu. Zdrojový kód je na GitHubu, dostupný pod licencí MIT.
Byl představen ICT Supply Chain Security Toolbox, společný nezávazný rámec EU pro posuzování a snižování kybernetických bezpečnostních rizik v ICT dodavatelských řetězcích. Toolbox identifikuje možné rizikové scénáře ovlivňující ICT dodavatelské řetězce a na jejich podkladě nabízí koordinovaná doporučení k hodnocení a mitigaci rizik. Doporučení se dotýkají mj. podpory multi-vendor strategií a snižování závislostí na vysoce
… více »Nizozemský ministr obrany Gijs Tuinman prohlásil, že je možné stíhací letouny F-35 'jailbreaknout stejně jako iPhony', tedy upravit jejich software bez souhlasu USA nebo spolupráce s výrobcem Lockheed Martin. Tento výrok zazněl v rozhovoru na BNR Nieuwsradio, kde Tuinman naznačil, že evropské země by mohly potřebovat větší nezávislost na americké technologii. Jak by bylo jailbreak možné technicky provést pan ministr nijak nespecifikoval, nicméně je známé, že izraelské letectvo ve svých modifikovaných stíhačkách F-35 používá vlastní software.
Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 162 (pdf).
Sdružení CZ.NIC, správce české národní domény, zveřejnilo Domain Report za rok 2025 s klíčovými daty o vývoji domény .CZ. Na konci roku 2025 bylo v registru české národní domény celkem 1 515 860 s koncovkou .CZ. Průměrně bylo měsíčně zaregistrováno 16 222 domén, přičemž nejvíce registrací proběhlo v lednu (18 722) a nejméně pak v červnu (14 559). Podíl domén zabezpečených pomocí technologie DNSSEC se po několika letech stagnace výrazně
… více »Google představil telefon Pixel 10a. S funkci Satelitní SOS, která vás spojí se záchrannými složkami i v místech bez signálu Wi-Fi nebo mobilní sítě. Cena telefonu je od 13 290 Kč.
Řešení dotazu:
while read line; do
echo $line;
done < soubor.txt
IFSThe Internal Field Separator that is used for word splitting after expansion and to split lines into words with the
readbuiltin command. The default value is ''<space><tab><newline>''.
Zdravim,
ak sa snazis robit nieco v bash-i, tak sa to treba snazit robit v bash-i a nie volat daky iny program zbytocne. Najma ak je to nieco jednoduche a bash samotny ma toto implementovane. Samozrejme, su pripady, kedy je lepsie zavolat externy program, ktory to spravi rychlejsie, ale nie v tomto pripade. ;)
#! /bin/bash
while read LINE
do
# ${PREMENNA%%;*} - vymaze najdlhsi nalez od konca hodnoty premennej po znak ; (bodkociarka)
echo "${LINE%%;*}"
done< ./seznam.txt
#!/bin/bash seznam=seznam.txt # zde se předpokládá, že seznam.txt leží ve stejném adresáři jako samotný skript - jinak se musí pochopitelně uvést cesta k souboru se seznamem cat $seznam | while read x ; do cesta="$( echo $x | cut -d ";" -f 1 )" soubor="$( echo $x | cut -d ";" -f 3 )" heslo="$( echo $x | cut -d ";" -f 2 )" mkdir "$cesta" cp "$soubor.zip" "$cesta" cd "$cesta" unzip -P "$heslo" "$soubor.zip" rm -rvf "$soubor.zip" cd .. done
Zdravim,
vidiet, ze ste sa snazili a zrejme ste s nim aj spokojny. V podstate robi, co ma, az kym nenastanu problemy.
1. Ziadne overovanie, ci dany subor ci adresar existuju. Vid prikaz test a if v bash-i.
2. cat $seznam moze narobit paseku, ak sa v ceste alebo adresari nachadza medzera. Vid uvodzovanie v bash-i.
3. Ziadne overovanie, ci seznam.txt je to, co potrebujete a taktiez moznost zadania ineho umiestnenia je pomocou upravy skriptu. Vid pozicne parametry v bash-i.
Mozno je tam toho aj viac, ale ja musim spat k svojej praci. A neberte to nijak zle, ja napr. vzdy ocenujem, ked ma niekto napomenie. ;)
Tu je aj moja verzia. Mozte to upravit alebo ignorovat. Akokolvek, nebolo to ani raz otestovane, takze mozu tam byt chyby a preto to otestujte prv na necisto, teda ak to vobec pouzijete.
#!/bin/bash
declare -i E_SEZNAM
declare DEF_SEZNAM SEZNAM
E_SEZNAM=1
SEZNAM='seznam.txt'
# vychodzi zoznam sa nachadza v aktualnom adresari, podla mojho nazoru lepsie riesenie
DEF_SEZNAM="${PWD}"/"${SEZNAM}"
# tvoje riesenie, ked sa vychodzi zoznam nachadza v adresari so skriptom
# odkomentuje, ak to chces a zakomentuje predchadzajucu definiciu DEF_SEZNAM
# ${PREMENNA%/*} odstrani najkratsi nalez od konca hodnoty premennej po /
# ${0} je cesta ku skriptu
#DEF_SEZNAM="${0%/*}"/"${SEZNAM}"
# Ak nebol zadany pomocou tento_script cesta_k_seznamu, tak sa pouzije seznam.txt z
# aktualneho adresara, ak existuje.
SEZNAM="${1:-${DEF_SEZNAM}}"
SEZNAM="$(readlink -f "${SEZNAM}")"
if [[ $? -eq 0 && -r "${SEZNAM}" ]]
then
echo "Nacitavam seznam z: ${SEZNAM}"
# odkomentuj, ak chces mat aj moznost prerusenia skriptu v pripade,
# ze seznam.txt nie je to, co si si myslel alebo co si chcel spracovat.
# echo -e "Citam prvych 5 riadkov v ${SEZNAM}\
# ---------------------------------------"
# head -n 5 "${SEZNAM}"
# echo -e "---------------------------------------\n"
# read -p 'Pokracovat ? ' && exit ${E_SEZNAM}
else
echo "${SEZNAM} neexistuje. Koncim."
exit ${E_SEZNAM}
fi
while read LINE
do
# vymaze najdlhsi nalez od konca po znak ;
# pracujeme s absolutnymi cestami, mozno (teda som si isty ;) ) by tu bolo vhodne dat overovanie
# ci ta cesta aj existuje, aby sa predislo nahodnemu prepisaniu niektoreho doleziteho
# suboru. To je na tebe. ;) Celkom jednoducha podmienka pomocou if to vyriesi. A to rovnako
# pri CESTA i pri SOUBOR
CESTA="$(readlink -f "${LINE%%;*}")"
# vymaze najdlhsi nalez od zaciatku po znak ;
SOUBOR="$(readlink -f "${LINE##*;}")"
# zobrazi hodnotu medzi dvoma znakmi ;
HESLO="$(expr match "${LINE}" ".*;\(.*\);.*")"
# nie je nutne pouzit prikaz cd, kedze pracujeme s absolutnymi cestami.
mkdir "${CESTA}"
cp "${SOUBOR}".zip "${CESTA}"
unzip -P "${HESLO}" "${SOUBOR}".zip
rm -rvf "${SOUBOR}".zip
done < "${SEZNAM}"
# nie je nutne pouzit prikaz cd, kedze pracujeme s absolutnymi cestami.
mkdir "${CESTA}"
cp "${SOUBOR}".zip "${CESTA}"
unzip -P "${HESLO}" "${SOUBOR}".zip
V zipu nebudou absolutní cesty, takže cd (nebo parametr zipu -d) je nutné, výchozí chování je rozbalovat do aktuálního adresáře, ne do adresáře se zipem. Spíš není nutné to kopírování:
mkdir "${CESTA}" &&
unzip -P "${HESLO}" -d "${CESTA}" "${SOUBOR}.zip" &&
rm -rvf "${SOUBOR}.zip"
-r jsem tam dal jen vinou copy&paste, ale u souboru samozř. není potřeba.
Mohol som to dopisat kompletne, ale nedopisal som a bol na to dovod. Z toho titulu si nemyslim, ze mi usla pointa alebo nieco v tom zmysle. Ja sam by som testoval existenciu adresarov, ich prava atd. Ak si vsimnete, tak je tam prave toto napisane v komente priamo v skripte. Ja som nechcel vsetko spravit za neho, kedze od doby, kedy zalozil temu, tu prezentoval aj svoj vlastny progres v tejto veci. Tak som mu chcel dat priestor aj na sebarealizaciu. O vyuziti pozicnych parametroch tam nebolo nic v jeho povodnom skripte, to som teda napisal. Dalej vsak isiel spravne, tak som predpokladal, ze to chape a teda mu bude jednoduche upravit prave tu cast, aby kontrolovalo existenciu, opravnenia, atd. v slucke while.
if [[ -r soubor.txt ]]; then while read line; do foo done < soubor.txtje totéž, jako
while read line; do foo done < soubor.txtakorát druhá varianta vám řekne
line 3: soubor.txt: No such file or directory
zatímco ta první tiše selže. Takže buď můžete kontrolovat a psát vlastní chybová hlášení, nebo to nechat na bashi. Mnoho věcí na bashi nechat lze. Závislost mezi příkazy (unzip file.zip && rm file.zip) nikoliv, TO je potřeba ošetřit.
Dakujem za tip. Takto som nad kontrolou suboru, ci je citatelny pre sluckou while, nikdy nepremyslal. To sa isto zide. ;) Samozrejme suhlasim aj s ostatkom.
Ako som uz povedal, chyby tam mozu byt a nasli sa. Stravil som nad tym dakych 15 minut a ziadne otestovanie. Moj postup bol prepis povodneho skriptu a neuvedomil som si, ze unzip to rozbali uplne niekde inde. Moja chyba.
readlink -f zipu v ničem nepomůže a s použitím cd to nesouvisí. Nebo jsem vás asi nepochopil. Proto jsem to považoval za vhodné zmínit.
Ostatní věci jako absence kontroly úspěšnosti unzip nebo cp dřív, než originální zip smažu, bych nepovažoval za nepozornost či únavu po 15 minutách ošetřování vstupů, ale za hrubou chybu ;) Samozřejmě je to subjektivní, hlavně zálohovat :D
Hruba chyba urcite by to bola, ale tu som to neosetril prave skrz toho, ze som to chcel nechat na zakladatela a tak som to aj poznamenal v komente v skripte. Akokolvek, tento vas nazor nie je ani tak subjektivny ako objektivny. ;)
#!/bin/bash while IFS=';' read cesta heslo soubor; do mkdir -p "$cesta" cd "$cesta" unzip -P "$heslo" "../$soubor.zip" cd - done <seznam.txt
#!/bin/bash while IFS=';' read cesta heslo soubor; do mkdir -p "$cesta" && unzip -P "$heslo" -d "$cesta" "$soubor.zip" done < seznam.txt
Tiskni
Sdílej: