Byla vydána verze 1.96.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.
Společnosti IBM a Red Hat představily Project Lightwell s investicí 5 miliard dolarů. Jedná se o důvěryhodné clearingové centrum pro bezpečnost open source softwaru a zabezpečení dodavatelských řetězců s novým AI modelem a globální skupinou více než 20 000 softwarových inženýrů. Služby centra budou dostupné prostřednictvím komerčních předplatných. Project Lightwell staví na iniciativách jako Anthropic Glasswing nebo OpenAI Trust Access for Cyber.
Open source 3D herní a simulační engine Open 3D Engine (O3DE) byl vydán v nové verzi 26.05. Podrobný přehled novinek v poznámkách k vydání.
Český stát by v budoucnu mohl provozovat vlastní alternativu ke komunikačním aplikacím typu WhatsApp, Signal, Telegram, Facebook Messenger a podobně. Cílem je zajistit bezpečnou datovou komunikaci pro stát a jeho důležité subjekty, jako jsou bezpečnostní složky, ministerstva a další organizace.
Už za týden, ve čtvrtek 4. června, se v Národní technické knihovně v pražských Dejvicích uskuteční další konference věnovaná tématům spojeným s IPv6 - Den IPv6. Program akce a registrační formulář jsou k dispozici na webu akce. Kapacita konference je omezená, proto organizátoři doporučují, aby se vážní zájemci přihlásili včas (k dnešnímu dni zbývá přibližně 30 volných míst). Konferenci Den IPv6 2026 organizují i letos společně sdružení CESNET, CZ.NIC a NIX.CZ.
Zařízení Steam Deck OLED bylo znovu naskladněno, ale vlivem rostoucích cen pamětí a úložišť má novou, vyšší cenovku. Steam Deck OLED 512 GB stojí nově 779 EUR (stál 569 EUR) a Steam Deck OLED 1 TB stojí 919 EUR (stál 679 EUR). Samotné zařízení se nijak nezměnilo a nové ceny tedy pouze odráží aktuální náklady na komponenty a další globální logistické výzvy, se kterými se potýká celá branže.
Český telekomunikační úřad zahajuje novou etapu využívání vysokofrekvenčního rádiového spektra v pásmu 26 GHz. Toto pásmo bude od 1. 7. 2026 otevřeno pro provoz moderních bezdrátových sítí, zejména sítí páté generace (5G), pevných bezdrátových přístupových sítí (FWA) a lokálních či průmyslových sítí určených například pro výrobní areály, logistická centra nebo technologické kampusy. Současně s otevřením pásma 26 GHz přistoupil ČTÚ ke zpřístupnění informací o využívání rádiových kmitočtů v tomto pásmu.
Logitech představil myš Signature Comfort Plus M850 L s polstrovanou opěrkou dlaně pro větší pohodlí a sadu s touto myší a klávesnicí s integrovanou opěrkou dlaní Signature Comfort Plus Combo MK880.
Gaël Duval se rozepsal o novinkách a plánech Murena a /e/OS. Počet uživatelů telefonů Murena a mobilního operačního systému /e/OS bez aplikací a služeb od Googlu se blíží 100 000. Ambicí je, aby se /e/OS stal třetí mobilní platformou v Evropě i na světě, s potenciálem dostat se i na PC. Blíží se vydání nové verze 4 s funkcemi zálohování a obnova, import e-mailů z Gmailu a rozpoznávání hlasu. Murena Workspace přinese videohovory, elektronický podpis a správu zařízení (MDM).
Dnes a zítra probíhá Ubuntu Summit 26.04. Na programu je řada zajímavých přednášek. Sledovat je lze na YouTube. Úvodní slovo měli Mark Shuttleworth a Jon Seager.
Tak jsem si řekl, že zkusím programování v nějakém tom „skriptovacím“, opravdu vysokoúrovňovém jazyce, což mi přinese obrovskou produktivitu a pravděpodobně i sex-appeal. Už nějaký čas jsem chtěl prozkoušet Python ale řekl jsem si, že půjdu se současným hype a zkusím Ruby.
Na první pohled se mi Ruby moc líbí. Syntaxe je hezká, opravdu všechno je objekt. Nikdy jsem nepochopil, proč se délka seznamu v Pythonu získá jako len(s) a nikoliv s.len(). V Ruby jsou všechno objekty, kterým se posílají zprávy. Takže s.size. Je to konzistentní a elegantní.
Velmi pěkná je konvence s otazníky a vykřičníky v názvech metod. Metody často mají dvě verze, jednu s vykřičníkem na konci a druhou bez (například downcase a downcase! pro String). Vykřičníková verze změní vnitřní stav objektu. Verze bez vykřičníku vrátí modifikovaný objekt, ale původní objekt zůstane nezměněn. Metody končící otazníkem vracejí booleovskou hodnotu. Tyto konvence zlepšují čitelnost kódu.
Asi nejzásadnější vlastností jsou uzávěry (closures). Je to takové posílání bloků kódu jako parametr. Moc se mi to líbí a skoro jsem se na tom stal závislý. Dají se s tím dělat roztodivná kouzla ale praktický důsledek je ten, že zapomenete psát for-cykly. Výpis prvků seznamu vypadá následovně:
["ahoj", "nazdar", "blekota"].each {|s| puts s}
Mixování modulů do tříd se mi taky líbí. I když vícenásobná dědičnost z Pythonu je asi taky v pohodě (na rozdíl od C++).
Naprosto úchvatná je pružnost jazyka. Například aspektově orientované programování. Dolepit AOP například do Javy znamená buď nějaký preprocesing zdrojáku nebo postprocesing bajtkódu. V Ruby, kde můžete za běhu přejmenovávat metody (a na jejich místo vkládat svoje AOP interceptory), tohle problém není.
Přestože Ruby je z Japonska, jazyk nemá nějakou pořádnou podporu unicode. V podstatě jediná podpora je ta, že stringy můžou být kódované UTF-8 a nehrozí jim poškození. To vlastně není ani není problém, protože jazyky s podporou Unicode jako Java/C# používají kódování UTF-16 a tak funkce pro vrácení délky řetězce obecně nemusí vrátit počet znaků (viz muj starší post o unicode). IMHO lepší takhle mizerná leč konzistentní podpora v Ruby než dva typy řetězců (obyč a unicode) v Pythonu.
Díky přizpůsobivosti jazyka není problém dodat třídě String příslušnou funkcionalitu. Je několik projektů, které navážejí do jazyka Unicode z knihovny ICU, ale bohužel není žádné hotové, standardní a obecně používané řešení.
Vlákna jsou asi největší (a pro mě osobně nepřekonatelná) slabina Ruby. Ruby nepoužívá vlákna operačního systému (jako posix threads), ale má svoji vlastní implementaci. I když interpret vlákna pravidelně střídá a vytváří tak jakous takous preempci, vše běží v jednom systémovém vlákně. V době nástupu vícejádrových procesorů je to nešťastné. Ve webových aplikacích se to dá obejít puštěním více procesů přes (fast)CGI, jenže já chci psát i výkonné desktopové aplikace.
Musím říct, že to byla moc příjemná zkušenost. Programuje se v tom opravdu hezky a zdá se, že opravdu rychleji než třeba v Javě. Samozřejmě jsem v tom nepsal nic velkého (a díky těm zpropadeným vláknům ani nebudu) takže těžko říct, jestli se v tom něco opravdu velkého napsat dá.
Jdu vyzkoušet Groovy 
Tiskni
Sdílej:
„Přestože Ruby je z Japonska, jazyk nemá nějakou pořádnou podporu unicode.“Ne „přestože“, ale „protože“. Japonci mají s Unicode docela problémy. Sice nejsou tak velcí, aby s tím trendem něco, zmohli, ale koušou, potvůrky...
Pokud jde o vlákna, má to i svoje výhody. Vlákna mimo OS mají obrovský výkon (viz Erlang) a Ruby svůj vláknový kód houfně používá pro kontinuace. Navíc díky tomu běhá Ruby i na OS, které vlákna nemají (32b DOS...
) Návrh implementace je zkrátka hromada kompromisů... Navíc Ruby poměrně dost řeší neblokování vláken při interakci se systémem (IO) - no, nevýhoda je ten SMP provoz a některé ty homebrew Cčkové extenze se nemusejí chovat hezky, to je pravda. Ale ono se už něco vaří (přesněji YARV). Věřím, že pro některé účely v jazyku green threads asi zůstanou (mj. pro ty kontinuace), ale vychytat takový složitý model v úplnosti asi nebude sranda. Jsem docela zvědavý...
Holt si to lingvisticky zkazili v polovině prvního tisíciletí n.l.
Na druhou stranu, pak by Japonci nebyli schopni psát tak krásné básně. Co na tom, že jim člověk bez znalosti japonštiny neporozumí a přeložit to nejde.
["a", "b", "c"].each {|s| puts s}“, o kterých se zmiňuješ, se mi moc nelíbí, a dělá mi problém to vůbec přečíst a zorientovat se v tom. I když je pravda, že až donedávna jsem nevěděl, co ta konstrukce vlastně dělá. Raději si tam dám for a rozhodím to na dva řádky, než luštit hromadu závorek a |kolejniček|.
Jak píšeš v druhém odstavci o občas menší objektovosti Pythonu (len(s)), také mě to zezačátku překvapilo. Osobně a skromně si myslím, že je to možná kvůli rychlosti. Jinak fajnovej blogpost, tento typ článků bych na netu viděl rád častěji.
Scheme na vás, holomci...
Ten len() taky musí kontrolovat typ objektu v paměti, žádná výhra. O rychlosti to nebude, spíš o Kvídově „přelétavém návrhu“. Matz měl v tomhle změru jasnou vizi, ostatně to celé postavil na Smalltalku. No, docela si tím zjednodušil práci...
(#inject a spol...)
>>> s = 'abc'
>>> s.__len__()
3
BTW, ta podtržítka by se měla zakázat, to má být ta čitelnost?
Podle mně jsou tam úplně zbytečně...
. Je to trochu nekonzistentní syntaxe. Asi je to proto, že v Pythonu je možné psát čistě procedurálně.
A uzávěry (closures), ty se mi na Smalltaku také líbily, zvláště metody select, accept, reject a tak dále.
. Kdyby mi neslo o vlastnosti jazyka, tak se nebudu ptat na to, jestli jdou Ruby a C-syntax dohromady.
chmod 111
root /devel/sh # chmod 111 ie6 root /devel/sh # ./ie6a IE6 nastartoval
* dev-php5/php-qt
Available versions: !0.0.2
Installed: none
Homepage: http://php-qt.berlios.de
Description: PHP 5 bindings for the Qt4 framework.
) Ale diky.
Takže asi něco jako kdybych ve webové aplikaci používal glib? (Předtím jsem tomu rozuměl tak, že bych přes Qt např. namaloval dialog a on se zobrazil jako webová stránka.)
No tak to by dost možná šlo udělat, jen by se musel udělat poměrně šílený backend (ajaxový?
), kromě stávajícího Xkového, jablečného a wokýnkového...
Já radši dám přednost tomu pluginu do browseru, přijde mi docela sexy.