Byla vydána verze 5.30 dnes již open source operačního systému RISC OS (Wikipedie).
V aktuálním příspěvku na blogu počítačové hry Factorio (Wikipedie) se vývojář s přezývkou raiguard rozepsal o podpoře Linuxu. Rozebírá problémy a výzvy jako přechod linuxových distribucí z X11 na Wayland, dekorace oken na straně klienta a GNOME, změna velikosti okna ve správci oken Sway, …
Rakudo (Wikipedie), tj. překladač programovacího jazyka Raku (Wikipedie), byl vydán ve verzi #171 (2024.04). Programovací jazyk Raku byl dříve znám pod názvem Perl 6.
Společnost Epic Games vydala verzi 5.4 svého proprietárního multiplatformního herního enginu Unreal Engine (Wikipedie). Podrobný přehled novinek v poznámkách k vydání.
Byl vydán Nextcloud Hub 8. Představení novinek tohoto open source cloudového řešení také na YouTube. Vypíchnout lze Nextcloud AI Assistant 2.0.
Vyšlo Pharo 12.0, programovací jazyk a vývojové prostředí s řadou pokročilých vlastností. Krom tradiční nadílky oprav přináší nový systém správy ladících bodů, nový způsob definice tříd, prostor pro objekty, které nemusí procházet GC a mnoho dalšího.
Microsoft zveřejnil na GitHubu zdrojové kódy MS-DOSu 4.0 pod licencí MIT. Ve stejném repozitáři se nacházejí i před lety zveřejněné zdrojové k kódy MS-DOSu 1.25 a 2.0.
Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.
Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.
Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.
1 7 3 4 5 6 2 8skript.sh:
#!/bin/bash # ktory < za ktory=2 za=7 subor="vstup" vystup="vystup" riadkov=`cat vstup|wc -l` # uvod cat vstup |head -n $((ktory-1)) > vystup # za cat vstup |head -n $za | tail -n 1 >> vystup # medzi ktory za cat vstup |head -n $((za-1)) | tail -n $((za-ktory-1)) >> vystup # ktory cat vstup |head -n $ktory | tail -n 1 >> vystup # koniec cat vstup | tail -n $((riadkov-za)) >> vystup
#!/usr/bin/env bash if [[ "$2" -gt "$1" ]]; then p1="$1" p2="$2" else p1="$2" p2="$1" fi cp data.txt data.out.txt r1=$(sed -n "${p1}p" data.out.txt) r2=$(sed -n "${p2}p" data.out.txt) sed -i " ${p1}i${r2} ${p1}d ${p2}i${r1} ${p2}d " data.out.txt cat data.out.txt
[localhost tip]$ time bash skript.sh real 0m0,023s user 0m0,014s sys 0m0,018s [localhost tmp]$ time bash skript_Ja.sh 2 7 real 0m0,016s user 0m0,007s sys 0m0,009s
Tolik UUOC nejen bije do očí, ale možná už i dokonce smrdí z terminálu.
#!/bin/bash # ktory < za ktory=2 za=6 riadkov=`cat data.txt|wc -l` # uvod cat << EOF > data.out.txt `head -n $((ktory-1)) data.txt` `head -n $za data.txt | tail -n 1` `head -n $((za-1)) data.txt| tail -n $((za-ktory-1))` `head -n $ktory data.txt| tail -n 1` `tail -n $((riadkov-za)) data.txt` EOF cat data.out.txt
Chápu to správně tak, že to má vzájemně prohodit nějaké dva řádky a že to má být jenom v Bashi?
Tak potom bych tady měl obecnější prasárnu, která těch záměn umí několik, ale funguje jen tehdy, pokud se soubor vejde do paměti. Definuje funkci swaplines
, která přijímá jako parametry dvojice číslel řádků (od 0) k prohození, oddělené pomlčkou. Například tohle by desetiřádkový vstup převrátilo naruby:
swaplines 0-9 1-8 2-7 3-6 4-5
A teď ta funkce swaplines
:
swaplines() { local -a -i from_to local -a file local -i from local -i to local aux for aux in "$@"; do from_to["${aux%%-*}"]="${aux##*-}" done readarray -t file for from in "${!from_to[@]}"; do to="${from_to[from]}" aux="${file[from]}" file[from]="${file[to]}" file[to]="$aux" done for aux in "${file[@]}"; do echo "$aux" done }
Čte to standardní vstup, píše to na standardní výstup a nemá to vůbec žádnou kontrolu chyb syntaxe — tu bych s chutí ponechal čtenáři za cvičení.
#!/bin/bash vim -e -c '5m 8' -c '7m 4' -c 'wq' soubor.txt
echo -e "5m8\n8-m5-\nw\nq\n" | ed -s subor.txt
Ano, že má být něco „v bashi“, to se dá chápat různými způsoby. Já vycházím z toho, vim
není bash
.
Třeba 5 řádek za 159.5 za 159, nebo 5. za 159.?
Tiskni Sdílej: