Dánské ministerstvo pro digitální záležitosti má v plánu přejít na Linux a LibreOffice [It's FOSS News].
V úterý Google vydal Android 16. Zdrojové kódy jsou k dispozici na AOSP (Android Open Source Project). Chybí (zatím?) ale zdrojové kódy specifické pro telefony Pixel od Googlu. Projekty jako CalyxOS a GrapheneOS řeší, jak tyto telefony nadále podporovat. Nejistá je podpora budoucích Pixelů. Souvisí to s hrozícím rozdělením Googlu (Google, Chrome, Android)?
Byla vydána (𝕏) květnová aktualizace aneb nová verze 1.101 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.101 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.
V Brně na FIT VUT probíhá třídenní open source komunitní konference DevConf.CZ 2025. Vstup je zdarma, nutná je ale registrace. Na programu je celá řada zajímavých přednášek, lightning talků, meetupů a workshopů. Přednášky lze sledovat i online na YouTube kanálu konference. Aktuální dění lze sledovat na Matrixu, 𝕏 nebo Mastodonu.
Vyloučení technologií, které by mohly představovat bezpečnostní riziko pro stát, má umožnit zákon o kybernetické bezpečnosti, který včera Senát schválil spolu s novelami navazujících právních předpisů. Norma, kterou nyní dostane k podpisu prezident, počítá rovněž s prověřováním dodavatelů technologií pro stát. Normy mají nabýt účinnosti od třetího měsíce po jejich vyhlášení ve Sbírce zákonů.
Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.6.
Po Red Hat Enterprise Linuxu a AlmaLinuxu byl v nové stabilní verzi 10.0 vydán také Rocky Linux. Přehled novinek v poznámkách k vydání.
Bylo vydáno Eclipse IDE 2025-06 aneb Eclipse 4.36. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.
Americká filmová studia Walt Disney a Universal Pictures podala žalobu na provozovatele populárního generátoru obrázků pomocí umělé inteligence (AI) Midjourney. Zdůvodňují to údajným porušováním autorských práv. V žalobě podané u federálního soudu v Los Angeles označují firmu za „bezednou jámu plagiátorství“, neboť podle nich bez povolení bezostyšně kopíruje a šíří postavy z filmů jako Star Wars, Ledové království nebo Já, padouch, aniž by do nich investovala jediný cent.
Ultra Ethernet Consortium (UEC), jehož cílem je optimalizace a další vývoj Ethernetu s důrazem na rostoucí síťové požadavky AI a HPC, vydalo specifikaci Ultra Ethernet 1.0 (pdf, YouTube).
javac
. Prace na Scale byla motivovana touhou prekonat
omezeni dana zpetnou kompabilitou Javy. Scala neni rozsirenim Javy
(superset), ale zachovava si schopnost spoluprace (interoperability)
Jeden z duvodu pro pouziti Scaly je vyssi produktivita v porovnani s
Javou (pozn. prek: neni tak ukecana) pri zachovani rychlosti,
pouzitelnosti Java knihoven a dalsich vyhod JVM. Scala ma strucnost
dynamickych jazyku jako Ruby nebo Python, ale je staticky typovana jako
Java. Dalsi vyhodou je lepsi podpora vice vlaknoveho programovani.
V italstine Scala znamena schody. V tomto clanku je dvanact kroku
(schodu) ktere vam pomohou zacit se Scalou.
bin
adresari
najdete prekladac, interpret shell apod. Aby vse fungovalo je treba
pridat tento adresar do promnene prostredi (env. variable)
PATH
. Take je treba mit nainstalovanou JRE 1.4 nebo
novejsi.
scala
, najdete ho v adresari 'bin'.
Po spusteni vypise toto:
$ scala This is an interpreter for Scala. Type in expressions to have them evaluated. Type :help for more information. scala>Je mozne vkladat vyrazi jako 1+2, interpret pak odpovy vysledkem.
scala> 1 + 2 unnamed0: Int = 3Vysledek obsahuje:
scala.Int
. Tato trida
odpovida int
nebo Integer
z Javy. Vlastne
vsechny primitivni typy z Javy maji protejsek ve Scale. Scala sama o
sobe nezna primitivni datove typy, vse se tvari jako objekt. Ale
prekladac provadi optimalizace a pouziva primitivni datove typy pro
lepsi vykon.
unnamedX
muze byt odkazovan z dalsich radku. Napriklad:
scala> unnamed0 * 3 unnamed1: Int = 9Pro vytisteni nezbytneho 'Hello world' muzeme pouzit toto:
scala> println("Hello, world!") Hello, world! unnamed2: Unit = ()Datovy typ vysledku je 'Unit' to odpovida 'void' v Jave. Scala nezna 'void' ve smyslu 'zadna navratova hodnota'. Pro pripady jako
println
je proto zaveden typ 'Unit' ktery ma jedinou
moznou hodnotu ()
. Pro nas ale bude ted stacit ze Unit a
void jsou totozne (pozn. prek: na urovni bytecode je Unit prelozen na
void)
val
(konstantami) ktere mohou byt
prirazeny pouze jednou a var
, ktere mohou byt prirazeny
vicekrat. (pozn. prek: val je var s javovskym 'final'). Zde je ukazka
definice konstanty:
scala> val msg = "Hello, world!" msg: java.lang.String = Hello, world!Toto zavadi novou konstantu s datovym typem String a hodnotou 'Hello...'. Tento priklad take ukazuje dulezitou a velmi uzitecnou vlastnost Scaly: type inference (pozn. prek: odvozovani typu?). Typ 'String' neni treba uvadet u definice, protoze je uz znam pri inicializaci. Interpet/prekladac pozna hodnotu jakou je konstanta initializovana a podle toho prida k definici jeji datovy typ. Prekladac zvladne doplnit datovy typ u vetsiny definic. Vetsinou je lepsi ponechat tuto praci na nem, ale obcas muze byt nezbytne definovat datovy typ manualne. Definice typu neni pred promnenu jako v Jave, ale za, oddelene dvojteckou:
scala> val msg2: String = "Hello again, world!" msg2: java.lang.String = Hello, world!Konstanty neni mozne modifikovat, proto v nekterych pripadech je treba pouzit
var
promnenou:
scala> msg = "Goodbye cruel world!" console:5 error: assignment to non-variable val unnamed4 = {msg = "Goodbye cruel world!";msg} scala> var greeting = "Hello, world!" greeting: java.lang.String = Hello, world! scala> greeting = "Leave me alone, world!" greeting: java.lang.String = Leave me alone, world!
scala> def max(x: Int, y: Int): Int = if (x < y) y else x max: (Int,Int)IntDefinice metody zacina 'def'. Nazev metody 'max' je nasledovan vyctem parametru v zavorkach oddelenymi carkami. Kazdy parametr musi mit definovan typ (type inference zde nefunguje). V tomto pripade ma metoda 'max' dva parametry 'x' a 'y' s typem 'Int'. Dale nasleduje navratova hodnota ':Int'. U metod funguje odvozovani typu, takze ve vetsine pripadu to vynechat. Zde lze jednoduse odvodit ze navratovy typ bude vzdy 'Int'. Pokud napiseme metodu bez navratoveho typu, bude to fungovat:
scala> def max2(x: Int, y: Int) = if (x < y) y else x max2: (Int,Int)IntNazev metodu, parametry a navratovy typ tvori 'signature' metody (pozn.prek: tohle bych asi neprekladal). Zbytek je telo metody. V tomto pripade telo obsahuje jen jeden vyraz, takze neni nutno pouzit zavorky. Tuto metodu lze ale napsat take se zavorkami:
scala> def max3(x: Int, y: Int) = { if (x < y) y else x } max3: (Int,Int)Int scala> max(3, 5) unnamed6: Int = 5Lze take definovat metodu bez parametru:
scala> def greet() = println("Hello, world!") greet: ()Unit //zavolani: scala> greet() Hello, world! unnamed7: Unit = () //nebo bez zavorek: scala> greet Hello, world! unnamed8: Unit = ()Vsimnete si ze greet nema zadnou navratovou hodnotu, ale interpret stejne pise 'Unit = ()'. Metody bez parametru je mozne volat s nebo bez zavorek. Konvence je pouzivat zavorky, pouze u get metod ktere pouze vraci promnenou, zavorky nepouzivat.
Tiskni
Sdílej:
Prosim nepiste do diskuze veci, ktere se primo netykaji Scaly (minule bylo na 250 irelevantnich prispevku)....dal bych si pivo...
to bol dneska zase hic, čo?
Autorovo svoleni jsem zatim neresil.A kdy tak hodláš učinit, když jsi to "nestihl" před vydáním překladu? :)
Ze začátku jsem byl nedůvěřivý, ale musím přiznat, že scala mi přijde (subjektivní názor) sympatyčtější než například groovy. Pro psani krátkých scriptů je celkem vhodná ...
V nějakém dalším díle čekám, že bude příklad zdrojáku, jeho překlad a spuštění i s argumenty.
ps: pro emacsomily: Scala, Emacs and Yasnippet