Byla vydána nová verze 2.50.0 distribuovaného systému správy verzí Git. Přispělo 98 vývojářů, z toho 35 nových. Přehled novinek v příspěvku na blogu GitHubu a v poznámkách k vydání.
Infrastrukturu pro chatovací aplikaci Telegram provozuje člověk s vazbami na ruské zpravodajské služby. Upozorňují na to investigativní novináři z redakce iStories. „Vedneev dodává služby ruskému státu včetně jeho jaderného institutu nebo zpravodajské službě FSB,“ říká v podcastu Antivirus novinář Jan Cibulka. Uživatelům, kteří si chtějí své informace chránit, doporučuje Telegram vůbec nepoužívat, a raději zvolit jednu z alternativ, WhatsApp nebo Signal.
The Trump Organization spustila ve Spojených státech mobilní síť Trump Mobile s neomezeným tarifem The 47 Plan za 47,45 dolarů měsíčně a představila vlastní značku telefonů The T1 Phone s Androidem za 499 dolarů.
Vývojáři KiCadu se na svém blogu rozepsali o problémech KiCadu v desktopových prostředích nad Waylandem. KiCad běží, ale s významnými omezeními a problémy, které podstatně zhoršují uživatelský komfort a vývojáři je nedokážou vyřešit na úrovni KiCadu. Pro profesionální používání doporučují desktopová prostředí nad X11.
Na čem aktuálně pracují vývojáři GNOME a KDE Plasma? Pravidelný přehled novinek v Týden v GNOME a Týden v KDE Plasma.
Byla vydána (𝕏) nová verze 2025.2 linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek se seznamem nových nástrojů v oficiálním oznámení na blogu.
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.
public class Program { public static void main(String[] args) { int age=18; if(age>0){ if(age>17){ System.out.println("Jsi vitan"); }else{ System.out.println("Moc mlady"); }else{ System.out.println("chyba"); } } } }Děkuji za radu.
Když si to správně naformátuješ/odsadíš, tak na to přijdeš asi i sám :-)
public class Program { public static void main(String[] args) { int age = 18; if (age > 0) { if (age > 17) { System.out.println("Jsi vitan"); } else { System.out.println("Moc mlady"); } } else { System.out.println("chyba"); } } }
Měl jsi tam jednu } závorku o pár řádků níž, než měla být.
public class Program { public static void main(String[] args) { int age = 18; if (age > 0) { if(age > 17) { System.out.println("Jsi vítán"); } else { System.out.println("Moc mladý"); } } else { System.out.println("chyba"); } } }
Dvě poznámky:
Tak to už bych úplně nedoporučoval.
Mít identifikátory i komentáře anglicky je celkem klíčové kvůli pozdějšímu případnému sdílení kódu. Cokoliv tam bude "neanglicky", to bude představovat obrovský technologický dluh.
Proto má Java od začátku Unicode
Což ale neplatí pro zdrojový kód, kde se předpokládá „na platformě závislé kódování“.
Platí to i pro zdrojový kód, pokud jde o řetězcové literály — pro Stringy s hláškami pro lokalizaci neexistuje jiný rozumný způsob, jak je správně uložit přímo ve zdrojáku, než UTF-8. Escape-sekvence nepovažuji za rozumný způsob; údržba takové lokalizace je jeden velký horor. Teoreticky by bylo možné mít je v oddělených textových souborech, které nebudou zdrojáky — a v některých jazycích je tohle opravdu nutné —, ale … proč takové věci dělat v Javě, když javac
má volbu -encoding
? Dokonce i bez -encoding
se použije kódování implicitní na dané platformě, což u rozumných systémů bude UTF-8. (Ale samozřejmě je lepší vždy -encoding
specifikovat, kvůli některým notoricky nestandardním platformám a tak celkově pro jistotu.)
Samozřejmě tady nemluvím o identifikátorech — ty nepotřebují diakritiku, protože mají být anglicky, stejně jako komentáře, kvůli možnosti sdílet kód, najmout lidi odkudkoliv atd.
3.1. Unicode Programs are written using the Unicode character set.Nižšie v tom istom paragrafe je síce upresnenie:
Except for comments (§3.7), identifiers, and the contents of character and string literals (§3.10.4, §3.10.5), all input elements (§3.5) in a program are formed only from ASCII characters (or Unicode escapes (§3.3) which result in ASCII characters).Inak povedané, vo všetkých častiach programu, ktorých lexikálnu podobu si do nejakej miery volí používateľ, je možné napísať akýkoľvek Unicode junk. A skutočne sme mali v komentári nášho zdrojového kódu nejaký notový zápis. Ani argumentácia, že je to tak len teraz, neobstojí:
Versions of the Java programming language prior to JDK 1.1 used Unicode 1.1.5. Upgrades to newer versions of the Unicode Standard occurred in JDK 1.1 (to Unicode 2.0), JDK 1.1.7 (to Unicode 2.1), Java SE 1.4 (to Unicode 3.0), Java SE 5.0 (to Unicode 4.0), Java SE 7 (to Unicode 6.0), Java SE 8 (to Unicode 6.2), Java SE 9 (to Unicode 8.0), and Java SE 11 (to Unicode 10.0).Nota bene, javovský zdroják je a vždy bol Unicode by definition.
Hnidopišsky lze podotknout, že Unicode character set nic nepraví o kódování.
A teď trochu praxe z manuálové stránky javac:
-encoding encoding Sets the source file encoding name, such as EUC-JP and UTF-8. If the -encoding option is not specified, then the platform default converter is used.
A jednoduchý pokus:
$ cat test.java public class test { public static void main(String[] args) { System.out.println("Vařila myšička kašičku."); } } $ file test.java test.java: C source, UTF-8 Unicode text $ javac test.java test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ test.java:3: error: unmappable character for encoding ASCII System.out.println("Va??ila my??i??ka ka??i??ku."); ^ 10 errors
Důvod je prostý – závisí na platformě, například na locale.
$ LC_ALL=cs_CZ.UTF-8 javac test.java
projde, protože kódování zdrojového kódu a platformy se náhodou shoduje.
Až tak přesně se shodovat nemusí; UTF-8 projde bez ohledu na zvolený jazyk. A pokud systém nemá UTF-8 jako implicitní kódování, je někde zásadní chyba (nejspíš mezi židlí a klávesnicí), kterou Java beztak nevyřeší.
Tiskni
Sdílej: