Byla vydána nová stabilní verze 8.0 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 148. Přehled novinek i s náhledy v příspěvku na blogu.
Ve FreeBSD byla nalezena a opravena zranitelnost FatGid aneb CVE-2026-45250. Jedná se o lokální eskalaci práv. Neprivilegovaný uživatel se může stát rootem.
Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).
Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.
Společnost Red Hat oznámila vydání Red Hat Enterprise Linuxu (RHEL) 10.2 a 9.8. Vedle nových vlastností a oprav chyb přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Vypíchnout lze CLI AI asistenta goose. Podrobnosti v poznámkách k vydání (10.2 a 9.8).
Organizace Apache Software Foundation (ASF) vydala verzi 30 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.
Byla vydána nová verze 7.0 svobodného open source redakčního systému WordPress. Kódové jméno Armstrong bylo vybráno na počest amerického jazzového trumpetisty a zpěváka Louise Armstronga (What A Wonderful World).
V Drupalu byla nalezena a opravena kritická zranitelnost SA-CORE-2026-004 (CVE-2026-9082). Útočník může provádět libovolné SQL dotazy na webech používajících databázi PostgreSQL.
Richard Hughes oznámil, že službu Linux Vendor Firmware Service (LVFS) umožňující aktualizovat firmware zařízení na počítačích s Linuxem, nově sponzoruje také společnost HP.
O víkendu proběhla demopárty Outline 2026. Publikována byla prezentovaná dema. Upozornit lze na 16 bajtové, opravdu šestnáct bajtové, zvukově obrazové demo Wake Up! 16b (YouTube).
text.replace(" ", "\\ "); a výsledek pořád stejný, soubor nenalezen kvůli mezeře...
Poraďte prosím.
Řešení dotazu:
Runtime run = Runtime.getRuntime();
String text = jTextFieldSoundPath.getText();
//text = "'"+text+"'";
try{
run.exec("vlc " + text);
}
catch (Exception e){}
String[] cmd = {"vlc", text};
Process p = Runtime.getRuntime().exec(cmd);
Runtime run = Runtime.getRuntime();
String stext = jTextFieldSoundPath.getText();
String[] cmd = {"vlc", stext};
try
{
run.exec(cmd);
}
catch (Exception e) {
//...
}
vlc vyhledávat v cestě, zvlášť když tam předáváte prázdný seznam proměnných prostředí.
public static void main z jejího parametru. Shell tenhle seznam vytváří tak, že vezme mezeru jako oddělovač a to, co napíšete na příkazovém řádku, podle mezer rozseká na jednotlivé parametry. Zpětné lomítko nebo uvozovky jsou záležitostí shellu – jemu tím řeknete "tuhle mezeru při rozsekání na seznam parametrů neber v úvahu", operační systém ani program s tím nic nedělá.
Vytvořit správný seznam parametrů je tedy ve vašem případě vaší úlohou. Když použijete některou z metod Runtime.exec(), které mají jako první parametr String, použije se StringTokenizer pro rozsekání vámi zadaného řetězce na argumenty podle bílých znaků (mezery, tabulátory, konce řádků). Žádné escapování tam nefunguje, takže mezera vždy způsobí rozdělení na dva argumenty. Musíte tedy použít některou z metod, která jako první parametr přijímá pole Stringů – tím připravíte přesně to pole, které pak Java předá operačnímu systému a ten nově spuštěnému programu. Jako první prvek pole je samotný program, který chcete spustit.
Jinak když vám nějaká třída v Javě nedělá, co od ní čekáte, je dobré si přečíst příslušný JavaDoc – tam byste se tohle (trochu stručněji) dozvěděl.
Tiskni
Sdílej: