V Bolzanu probíhá konference SFSCON (South Tyrol Free Software Conference). Jean-Baptiste Kempf, zakladatel a prezident VideoLAN a klíčový vývojář VLC media playeru, byl na ní oceněn cenou European SFS Award 2025 udělovanou Free Software Foundation Europe (FSFE) a Linux User Group Bolzano‑Bozen (LUGBZ).
Open-source minimalistický trackball Ploopy Nano byl po modelech modelech Classic a Thumb Trackball také aktualizován. Nová verze Nano 2 používá optický senzor PAW3222 a k původně beztlačítkovému designu přidává jedno tlačítko, které ve výchozí konfiguraci firmwaru QMK přepíná režim posouvání koulí. Sestavený trackball nyní vyjde na 60 kanadských dolarů (bez dopravy a DPH).
Github publikoval Octoverse 2025 (YouTube), tj. každoroční přehled o stavu open source a veřejných softwarových projektů na GitHubu. Každou sekundu se připojil více než jeden nový vývojář. Nejpoužívanějším programovacím jazykem se stal TypeScript.
Kit je nový maskot webového prohlížeče Firefox.
Mastodon (Wikipedie) - sociální síť, která není na prodej - byl vydán ve verzi 4.5. Přehled novinek s náhledy v oznámení na blogu.
Německo zvažuje, že zaplatí místním telekomunikačním operátorům včetně Deutsche Telekom, aby nahradili zařízení od čínské firmy Huawei. Náklady na výměnu by mohly přesáhnout dvě miliardy eur (bezmála 49 miliard Kč). Jeden scénář počítá s tím, že vláda na tento záměr použije prostředky určené na obranu či infrastrukturu.
Po dvaceti letech skončil leader japonské SUMO (SUpport.MOzilla.org) komunity Marsf. Důvodem bylo nasazení sumobota, který nedodržuje nastavené postupy a hrubě zasahuje do překladů i archivů. Marsf zároveň zakázal použití svých příspěvků a dat k učení sumobota a AI a požádal o vyřazení svých dat ze všech učebních dat.
Úřad pro ochranu hospodářské soutěže zahajuje sektorové šetření v oblasti mobilních telekomunikačních služeb poskytovaných domácnostem v České republice. Z poznatků získaných na základě prvotní analýzy provedené ve spolupráci s Českým telekomunikačním úřadem (ČTÚ) ÚOHS zjistil, že vzájemné vztahy mezi operátory je zapotřebí detailněji prověřit kvůli možné nefunkčnosti některých aspektů konkurence na trzích, na nichž roste tržní podíl klíčových hráčů a naopak klesá význam nezávislých virtuálních operátorů.
Různé audity bezpečnostních systémů pařížského muzea Louvre odhalily závažné problémy v oblasti kybernetické bezpečnosti a tyto problémy přetrvávaly déle než deset let. Jeden z těchto auditů, který v roce 2014 provedla francouzská národní agentura pro kybernetickou bezpečnost, například ukázal, že heslo do kamerového systému muzea bylo „Louvre“. 😀
Z upstreamu GNOME Mutter byl zcela odstraněn backend X11. GNOME 50 tedy poběží už pouze nad Waylandem. Aplikace pro X11 budou využívat XWayland.
Zdravím byl jsem okolnostmi donucennapsat neco v pascalu a zápasím s jedním problémem. Nejlépe to ukázu v nejakém zápise takze
repeat
WriteLn('Zadej volbu');
ReadLn(volba);
until volba=A;
WriteLN('Zadani promene je ok');
WriteLn(volba);
Co tento kousek kodu dela je jasne, cykluje dokud user nezada A a pak vypise promenou volba. Potrebuji do toho dostal cosi jako
until volba=A..D; nebo until volba=A,B,C,D;Proste místo podmínky A zadat rozsah, pri kterém bude splnena. Pokud mozno jednoduse, nejaký extra slozitý zápis nemá moc význam. Díky za prípadné rady.
p.s. s linuxem to má spolecného snad jen to, ze to písu v kdevelop a kompiluju pomocí fpc, ale snad to az tak nevadí.
Tiskni
Sdílej:
( a > neco )and( a < necojinyho )?
until (volba='A') or (volba='B') or ...
To už je lepší převést na vyhodnocování ordinální hodnoty .. větší než 'A' nebo 'a' a menší než 'z' nebo 'Z'.
Ok, doplňte prosím datové typy, jaké jste použil ... stejně jaké chybové hlášky.
repeat
write ('Zadej znak pro konec: ');
readln (zn);
until (zn = 'k') or (zn = 'K');
zn je typu char
Ještě, že zálohuju semestrálky ... kdysi jsem to dělal takhle ...
repeat until keypressed or Stisknuto;
if keypressed
then repeat
cti_klavesu(k)
until (k in ['A','N']) or (k in [#27,#13]);
if k = #27 then Txt(20,18,' ');
if (k in ['A',#13]) or LClicked then konec := true;
if (k = 'N') or RClicked
Jinak mi tam nějak schází uvozovky u toho A, ale už je to dost dlouho, co jsem psal v Packalu. A obecné řešení takéto věci je přes ASCII hodnotu. "A" je tuším 64, takže ta podmínka by mohla být něco jako ord(volba)>63 AND ord(volba)<68 (pokud teda packal píše and jako AND a ne jako ampersandy
)
jasne uvozovky u toho A mají být - psal jsem to jen na ukázku, aby bylo jasné co potrebuji. . Skoda doufal jsem ze jde nejak do té podmínky vpasovat rozsah. Bohuzel evidentne se mu tam nezdá to AND. Stejne tak OR nebo cokoli podobneho
Nemyslís,ze to trochu prehánís?Asi jo
No, podle nadpisu a prvních dvou vět zápisku jsem podlehl dojmu, že budeš jeden z těch neukojených uhrovitých teenagerů, pro které jazyky jako Pascal nebo Java nejsou dost geekovské a co kolem sebe trousí poznámky jako "Java je shit" aby se později ukázalo, že neznají ani QuickSort (prostě takový Jarda Šmíd
)
Takže sorráč
Ne v pohode. Ten paskvil v nadpisu je mysleno jako muj vytvor=paskvil. Nikdy jsem s pascalem do styku neprisel, proto v nem tápu a proto vznikl i tento zápisek - ve kterém jsem doufal, ze mi dobrí lidé poradí jak na to - coz se taky stalo a tímto vsem jeste jednou díky. R
Jseš mladší, než já ... tys nebyl na vejšce? Tam jsem se k Pascalu pořádně dostal ... zkus když tak server Builder, sice jsem ještě hledat nemusel, neživim se tim, ale tam bych začal prvně. Další variantou se zdá být Programátorské heaven.
Takze tam ho po me taky chtej. Nikdy predtim jsem se s ním nesetkal, spís bash a perl, ale jsou tam rozsíly ve kterých zatím plavu
Hm, já psal jen v dosu, v borland pascalu byly v helpu docela dobrý příklady ...
until (ord(volba) >= ord('a')) and (ord(volba) <= ord('d'))
vim ~/.emacsvim ~/.emacs
until ((volba) >= ('a')) and ((volba) <= ('d'));
Funguje jak jsem potreboval. Vrelé díky. Jenom drobnost - proc jsi (jste) pouzil to ord, kdyz i bez nej to funguje jak ma?
Podle tohodle zápisu to je celý nějak divný ... ještě jsem neviděl proměnnou v závorkách, jak je zde.
Znak na ordinální hodnotu se převádí pro lepší přehlednost, jinak není nutno. A hlavně a se závorkama snad je string a znak s apostrofem je char. No a vstupem je char či integer, podle definované vstupní funkce.
Ok, jedna procedura pro příklad ...
(* poskytuje moznosti obsluhy dat, obsluha je pres cisla, konec pres Esc *)
procedure menu;
var volba : char; {ctu volby do menu}
skoncit_menu: boolean; {je-li true, procedura se ukoncuje}
begin
skoncit_menu := false;
repeat
WriteLn(' Nabidka');
WriteLn(' 1: Pridani');
WriteLn(' 2: Vypis');
WriteLn(' 3: Vymaz');
WriteLn(' 4: Nacteni ze souboru');
WriteLn(' 5: Ulozeni do souboru');
WriteLn(' 6: Prikaz DOSu');
WriteLn(' 7: Servis');
WriteLn(' 8: Konec');
repeat
cti_klavesu(volba) {Alt+X,Esc}
until volba in ['1'..'8','x','X','o','O', #45,#27];
case volba of
'1': pridej(prvni);
'2': vypis(prvni, '');
'3': dispous(prvni,1);
'4': nacti_data(prvni, '');
'5': uloz_data(prvni,'');
'6': spust(def.cesta_shellu,'');
'7': nastav;
'O','o': about
else skoncit_menu := true
end
until skoncit_menu; {pri '8','x','X',Esc}
WriteLn
end;
)
Jelikož jsem autorem, tak bych to nechal klidně free ... ať se kultura programování zvyšuje. Nebo ať mne i někdo klidně zdokonalí.
var hotovo:boolean;
volba:char;
begin
repeat
Write('Zadej volbu: ');
ReadLn(volba);
case volba of
'A':hotovo:=true;
'B':hotovo:=true;
'C':hotovo:=true;
'D':hotovo:=true;
else hotovo:=false;
until (hotovo=true);
end;
Mám pocit, že funguje i 'A'..'D' nebo neco podobneho (myslim v syntaxi case-u).
until volba in ['a','b','c','d'];Vsem díky za podnety. R
Jelikož je to na vstupu char (chcete ho tam mít), tak je vezmete první znak ze stringu ... a při té podmínce se testuje, zda je načtená hodnota rovná požadované, dané mnoužinou či podmínkou ... tohle jsou základy a proto by na ně neměly platit, aplikoaet se patenty a licence.
var
Znak: Char;
begin
repeat
Write('Zadej A, B, C nebo D a potvrď Enterem: ');
Read(Znak);
Znak := UpCase(Znak);
WriteLn('Bylo zadáno ', Znak);
until Znak in [ 'A'..'D' ];
end.
A nebo ještě lépe:
uses Crt;
var
Znak: Char;
begin
Write('Stiskni A, B, C nebo D: ');
repeat
Znak := UpCase(ReadKey);
if (Znak = #0) then ReadKey; { Funkční klavesy, šipky a podobné nesmysly se čtou dvakrát }
until Znak in [ 'A'..'D' ];
WriteLn(Znak);
end.