Ubuntu 26.04 (Resolute Raccoon) už nebude v desktopové instalaci obsahovat GUI nástroj 'Software & Updates'. Důvodem jsou obavy z jeho složitosti pro běžné uživatele a z toho plynoucích bezpečnostních rizik. Nástroj lze doinstalovat ručně (sudo apt install software-properties-gtk).
Thomas Dohmke, bývalý CEO GitHubu, představil startup Entire - platformu pro spolupráci vývojářů a agentů umělé inteligence. Entire získalo rekordních 60 milionů dolarů na vývoj databáze a nástrojů, které mají zefektivnit spolupráci mezi lidmi a agenty umělé inteligence. Dohmke zdůrazňuje potřebu přepracovat tradiční vývojové postupy tak, aby odpovídaly realitě, kdy většinu kódu produkuje umělá inteligence.
Toyota Connected North America oznámila vývoj open-source herního enginu Fluorite, postaveného na frameworku Flutter. Pro renderování grafiky využívá 3D engine Filament od společnosti Google a dle svého tvrzení cílí na konzolovou kvalitu her. Fluorite je zřejmě navržen tak, aby fungoval i na méně výkonném hardware, což naznačuje možnost použití přímo v ICE systémech vozidel. Zdrojový kód zatím zveřejněný není.
Byl vytvořen nástroj a postup pro překonání věkového ověření platforem Discord, Kick, Twitch, Snapchat (a možná dalších), kód je open-source a dostupný na GitHubu. Všechny tyto sítě používají stejnou službu k-ID, která určuje věk uživatele scanem obličeje a na původní server posílá pouze šifrovaná metadata, ty ale sociální síť už nedokáže sama nijak validovat, 'útok' spočívá ve vygenerování a podstrčení legitimně vypadajících ověřovacích metadat.
Jihokorejská kryptoměnová burza Bithumb přiznala vážné selhání interních systémů, které ji vystavilo riziku sabotáže a nezabránilo chybné transakci v hodnotě přes 40 miliard dolarů (814 miliard Kč). Druhá největší kryptoměnová burza v Koreji minulý týden při propagační akci omylem rozeslala zákazníkům zhruba 620 000 bitcoinů místo 620 000 wonů (8700 Kč). Incident vyvolal pokles ceny bitcoinu o 17 procent. Většinu
… více »Google Chrome 145 byl prohlášen za stabilní. Nejnovější stabilní verze 145.0.7632.45 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Zpátky je podpora grafického formátu JPEG XL, viz Platform Status. Odstraněna byla před třemi lety. Nový dekodér JPEG XL jxl-rs je napsán v Rustu. Zobrazování JPEG XL lze vyzkoušet na testovací stránce. Povolit lze v nastavení chrome://flags (Enable JXL image format).
Byla vydána nová verze 1.26 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.
CrossOver, komerční produkt založený na Wine, byl vydán ve verzi 26. Přehled novinek v ChangeLogu. CrossOver 26 vychází z Wine 11.0, D3DMetal 3.0, DXMT 0.72, Wine Mono 10.4.1 a vkd3d 1.18. Do 17. února lze koupit CrossOver+ se slevou 26 %.
KiCad je nově k dispozici také jako balíček ve formátu AppImage. Stačí jej stáhnout, nastavit právo na spouštění a spustit [Mastodon, 𝕏].
Šenčenská firma Seeed Studio představila projekt levného robotického ramena reBot Arm B601, primárně coby pomůcky pro studenty a výzkumníky. Paže má 6 stupňů volnosti, dosah 650 mm a nosnost 1,5 kilogramu, podporované platformy mají být ROS1, ROS2, LeRobot, Pinocchio a Isaac Sim, krom toho bude k dispozici vlastní SDK napsané v Pythonu. Kompletní seznam součástek, videonávody a nejspíš i cena budou zveřejněny až koncem tohoto měsíce.
… více »
Prosím Vás, jak docílím uložení výstupu příkazu do proměnné v bashi?
Standartně je syntaxe:
c=$(pwr)
echo "Output ${c}"
To tak FUNGUJE!
--------------------------------------------------------------------------
c=$(nc -v -z 192.168.1.222 80)
echo "Output ${c}"
Toto NEFUNGUJE
Ve výstupu mám:
Connection to 192.168.1.222 80 port [tcp/http] succeeded! OutputProměnná "c" je prázdná. Jak prosím uložím příkaz "nc" do proměnné? Všem moc děkuji za pomoc Lukáš
O=$(curl http://192.168.0.1/index.html)
c=$(nc -v -z 127.0.0.1 80 1 2>&1)Pořád mi přijde curl pro daný úkol snadnější, porovnej curl:
# curl www.root.cz <!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML 2.0//EN"> <html><head> <title>301 Moved Permanently</title> </head><body> <h1>Moved Permanently</h1> <p>The document has moved <a href="https://www.root.cz/">here</a>.</p> <hr> <address>Apache/2.4.25 (Debian) OpenSSL/1.0.2l Server at www.root.cz Port 80</address> </body></html>čili:
# curl https://www.root.cz <!DOCTYPE html> <!-- Zdá se, že se zajímáš o náš zdrojový kód... Hledáme posilu do našeho týmu! @erik.dvorak@iinfo.cz --><html id="css" class="js-inactive design-html" lang="cs"> (...)vs nc:
# nc -v -z www.root.cz 80 Connection to www.root.cz 80 port [tcp/http] succeeded!
nc -z), ne poslat HTTP požadavek.
nc -v -z 127.0.0.1 81 && echo OTEVRENY || echo ZAVRENY;
-v.
nazev_promenne=="$(příkaz)" uloží do proměnné standardní výstup (stdout) příkazu. Každý program spuštěný ze shellu má ve výchozím stavu tyto výstupy:
# standardní výstup jde do souboru příkaz >soubor # standardní vstup jde ze souboru příkaz <soubor # standardní výstup příkaz1 jde na standardní vstup příkaz2 příkaz1 | příkaz2Můžete si všimnout toho, že všechny případy se týkají jen standardního vstupu a výstupu. Chybový výstup jde ve výchozím nastavení do terminálu. Pokud ho chcete přesměrovat do souboru, vypadá to takto:
# chybový výstup jde do souboru příkaz 2>souborTa dvojka znamená file descriptor číslo 2, tedy stderr. Podobně můžete nastavit i jiné FD než stdout a stderr, ale to v praxi většinou nepoužijete. Můžete také přesměrovat stderr do stdout tím, že do cílového souboru napíšete
&2 (FD číslo 2)2:
# chybový výstup (fd 2) se sloučí se standardním (fd 1), takže je veškerý výstup na standardním příkaz 2>&1To můžete pak vzít a přesměrovat do souboru nebo jiného příkazu:
# chybový výstup (fd 2) se sloučí se standardním (fd 1), standardní se pak směruje do souboru příkaz 2>&1 >soubor # chybový výstup příkazu 1 (fd 2) se sloučí se standardním příkazu 1 (fd 1), standardní se pak směruje do příkazu 2 (příkaz 2 už má ale opět oba výstupy) příkaz1 2>&1 | příkaz2
nc tuto hlášku vypisuje na standardní chybový výstup, takže je chceme sloučit a to potom uložit do proměnné:
c="$(nc -vz 192.168.1.222 80 2>&1)"
a=$(echo lorem ipsum) b="$(echo lorem ipsum)"Po vyhodnocení
$(…) bash vidí toto:
a=lorem ipsum b="lorem ipsum"První řádek znamená „spusť příkaz „ipsum“ s proměnnou prostředí „a“ nastavenou na „lorem“. Druhý řádek znamená „ulož do proměnné „b“ text „lorem ipsum“. Toto je častý zdroj chyb v bashových programech.
exec je možné použít ke směrování file deskriptorů samotného shellu.
if příkaz1
then
toto se provede pokud příkaz1 uspěl
fi
if příkaz2
then
toto se provede pokud příkaz2 uspěl
else
toto se provede pokud příkaz2 neuspěl
fi
Pokud máte v shellu proměnnou, pište ji do uvozovek. Srovnejte tyto dva zápisy:a=$(echo lorem ipsum) b="$(echo lorem ipsum)"Po vyhodnocení$(…)bash vidí toto:a=lorem ipsum b="lorem ipsum"První řádek znamená „spusť příkaz „ipsum“ s proměnnou prostředí „a“ nastavenou na „lorem“. Druhý řádek znamená „ulož do proměnné „b“ text „lorem ipsum“. Toto je častý zdroj chyb v bashových programech.
Obecně máte pravdu, ale zrovna u přiřazení je to trochu složitější, takže ten váš příklad nefunguje tak, jak tvrdíte:
mike@lion:~> var=$(echo lorem ipsum) mike@lion:~> echo ">$var<" >lorem ipsum<
To hlášení píše nc na chybový výstup, nikoliv na standardní výstup. Proto se objevuje na terminálu a ne v proměnné.
c="$(netcat -v -z 2a02:xxxx:yyyy:2:defb:48ff:fe28:4f42 80 2>&1)"
Takhle^^^ mi to normálně funguje:
$ echo "$c" Connection to 2a02:xxxx:yyyy:2:defb:48ff:fe28:4f42 80 port [tcp/http] succeeded!
Tiskni
Sdílej: