abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 01:33 | Zajímavý projekt

    Singularity je rootkit ve formě jaderného modulu (Linux Kernel Module), s otevřeným zdrojovým kódem dostupným pod licencí MIT. Tento rootkit je určený pro moderní linuxová jádra 6.x a poskytuje své 'komplexní skryté funkce' prostřednictvím hookingu systémových volání pomocí ftrace. Pro nadšence je k dispozici podrobnější popis rootkitu na blogu autora, případně v článku na LWN.net. Projekt je zamýšlen jako pomůcka pro bezpečnostní experty a výzkumníky, takže instalujte pouze na vlastní nebezpečí a raději pouze do vlastních strojů 😉.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 21:22 | Zajímavý projekt

    Iconify je seznam a galerie kolekcí vektorových open-source ikon, ke stažení je přes 275000 ikon z více jak dvou set sad. Tento rovněž open-source projekt dává vývojářům k dispozici i API pro snadnou integraci svobodných ikon do jejich projektů.

    NUKE GAZA! 🎆 | Komentářů: 0
    včera 03:33 | IT novinky

    Dle plánu certifikační autorita Let's Encrypt nově vydává také certifikáty s šestidenní platností (160 hodin) s možností vystavit je na IP adresu.

    Ladislav Hagara | Komentářů: 8
    17.1. 14:44 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Forgejo byla vydána ve verzi 14.0 (Mastodon). Forgejo je fork Gitei.

    Ladislav Hagara | Komentářů: 3
    17.1. 13:11 | Zajímavý projekt

    Just the Browser je projekt, 'který vám pomůže v internetovém prohlížeči deaktivovat funkce umělé inteligence, telemetrii, sponzorovaný obsah, integraci produktů a další nepříjemnosti' (repozitář na GitHubu). Využívá k tomu skrytá nastavení ve webových prohlížečích, určená původně pro firmy a organizace ('enterprise policies'). Pod linuxem je skriptem pro automatickou úpravu nastavení prozatím podporován pouze prohlížeč Firefox.

    NUKE GAZA! 🎆 | Komentářů: 3
    16.1. 16:44 | Nová verze

    Svobodný multiplatformní herní engine Bevy napsaný v Rustu byl vydán ve verzi 0.18. Díky 174 přispěvatelům.

    Ladislav Hagara | Komentářů: 2
    16.1. 15:11 | IT novinky

    Miliardy korun na digitalizaci služeb státu nestačily. Stát do ní v letech 2020 až 2024 vložil víc než 50 miliard korun, ale původní cíl se nepodařilo splnit. Od loňského února měly být služby státu plně digitalizované a občané měli mít právo komunikovat se státem digitálně. Do tohoto data se povedlo plně digitalizovat 18 procent agendových služeb státu. Dnes to uvedl Nejvyšší kontrolní úřad (NKÚ) v souhrnné zprávě o stavu digitalizace v Česku. Zpráva vychází z výsledků víc než 50 kontrol, které NKÚ v posledních pěti letech v tomto oboru uskutečnil.

    Ladislav Hagara | Komentářů: 25
    16.1. 13:55 | IT novinky

    Nadace Wikimedia, která je provozovatelem internetové encyklopedie Wikipedia, oznámila u příležitosti 25. výročí vzniku encyklopedie nové licenční dohody s firmami vyvíjejícími umělou inteligenci (AI). Mezi partnery encyklopedie tak nově patří Microsoft, Amazon a Meta Platforms, ale také start-up Perplexity a francouzská společnost Mistral AI. Wikimedia má podobnou dohodu od roku 2022 také se společností Google ze skupiny

    … více »
    Ladislav Hagara | Komentářů: 0
    16.1. 02:22 | Nová verze

    D7VK byl vydán ve verzi 1.2. Jedná se o fork DXVK implementující překlad volání Direct3D 5, 6 a 7 na Vulkan. DXVK zvládá Direct3D 8, 9, 10 a 11.

    Ladislav Hagara | Komentářů: 0
    16.1. 02:00 | Nová verze

    Byla vydána verze 12.0.0 knihovny libvirt (Wikipedie) zastřešující různé virtualizační technologie a vytvářející jednotné rozhraní pro správu virtuálních strojů. Současně byl ve verzi 12.0.0 vydán související modul pro Python libvirt-python. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (5%)
     (0%)
     (9%)
     (19%)
     (3%)
     (5%)
     (2%)
     (11%)
     (39%)
    Celkem 510 hlasů
     Komentářů: 14, poslední včera 10:22
    Rozcestník

    Dotaz: Zarovnání českého textu do bloku v terminálu, včetně dělení slov

    26.2.2019 19:15 vencas | skóre: 32
    Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Přečteno: 445×
    Zdravím, potřebuji zarovnat text (monospace písmo) na předem stanovenou šířku, aby byl přitom do bloku (tj do kraje na obou stranách) a fungovalo dělení slov. Funkční ideálně jako filtr v command-lině. Existuje něco takového? Našel jsem paradj.pl, ale ten neumí češtinu, stejně jako např. groff ap. Díky za nápomoc.

    Řešení dotazu:


    Odpovědi

    Josef Kufner avatar 26.2.2019 19:18 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Můžeš zkusit ukecat pandoc jestli by to nějak nenaformátoval.
    Hello world ! Segmentation fault (core dumped)
    26.2.2019 20:38 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Co vím (a pro jistotu jsem ještě ověřoval), pandoc převádí mezi sebou formáty textu, má nějakou vnitřní reprezentaci, ale reprezentací textu se nezabývá.
    Josef Kufner avatar 26.2.2019 23:44 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Pandoc konvertuje z jednoho formátu do druhého a mezi možné výstupní formáty patří i plain text nebo Markdown. Nezkoumal jsem, jak moc to splňuje zadání, ale mohlo by to produkovat použitelný výstup.
    Hello world ! Segmentation fault (core dumped)
    26.2.2019 20:03 debian+
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Webovy prehladavac.
    26.2.2019 20:39 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Tak jsem to zkoušel a text mi do bloku nezarovná. Jestli jste na něco narazil, rád se poučím. Já jsem opravdu nenašel nic. Pro jistotu zdůrazňuju: potřebuju správné dělení slov pro češtinu.
    26.2.2019 21:30 Peter Golis | skóre: 65 | blog: Bežné záležitosti | Bratislava
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    A už to "správné dělení slov pro češtinu" niekto naklepal do slovníkov? Bez toho to pôjde veľmi ťažko, a s tým to pôjde aj v to groff.
    wamba avatar 26.2.2019 22:10 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Příloha:
    Ten paradj.pl používá Tex::Hyphen, který podporuje i češtinu. Neříkám že ideální, ale nějaký slovník to je. Tedy bych zkusil si ten skript upravit:
    <  
    ---
    > binmode(STDIN,  ":utf8");
    > binmode(STDOUT, ":utf8");
    > 
    > 
    18,19c21
    < my $hyp = new TeX::Hyphen;
    <  
    ---
    > my $hyp = new TeX::Hyphen '/usr/share/texmf-dist/tex/csplain/base/czhyphen.tex', 'style' => 'czech',; 
    
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    26.2.2019 21:57 petr_p | skóre: 59 | blog: pb
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov

    Groff umí dělit slova, dokonce má i slovník s českým dělení slov (ukradený z TeXu). Jen se mu musí říci, že jazyk je čeština parametrem -mcs. Příklad manuálové stránky natažené na šířku terminálu včetně dělených slov:

    (echo ".ll ${COLUMNS}\n"; bzcat /usr/share/man/cs/man1/shigofumi.1.bz2) | /usr/bin/preconv | groff -Tutf8 -mandoc -mcs
    26.2.2019 22:08 mhepp
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Trochu nerozumím tomu, jak chceš dodržet podmínku, že na každém řádku bude přesně daný počet znaků. Aby to vyšlo vždy na konec slova nebo alespoň mezi dělitelné slabiky. Jak bys chtěl vyřešit nálsedující problém?
    ...
    řádek textu zadané šířky
    další řádek blbě vycházející
    
    Totiž můžeš zarovnat:
    ...
    řádek textu zadané šířky
    další řádek blbě vychá-
    zející
    
    nebo:
    ...
    řádek textu zadané šířky
    další řádek blbě vycháze-
    jící
    
    což není ani v jednom případě do bloku.
    Josef Kufner avatar 26.2.2019 23:42 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Prostě tam nastrkáš mezery a vybereš to nejhezčí. Viz zdrojáky TeXu.
    Hello world ! Segmentation fault (core dumped)
    Řešení 1× (vencas (tazatel))
    27.2.2019 22:39 vencas | skóre: 32
    Rozbalit Rozbalit vše Re: Zarovnání českého textu do bloku v terminálu, včetně dělení slov
    Konečné řešení vezme sazbu TeXu s monospace fontem, převede ji z pdf to txt a přidává mezery na vhodná místa, dokud nemá řádek požadovanou šířku. Zde je výstup pro český výplňový text z http://wellstyled.com/tools/dummy-cz/:
    Těby dived ptyzruně. Měji šlucry
    tří  chré lážlotist vumrou tiper
    v nic gláti úmýpech. Vlydi trou-
    di prýv k paská sro  prytě  fly-
    křu v kust.  Oří o půcpa a vimoj
    opo  trouchetrá  utě děšležrokla
    a mlehřou.  Puďni šru  vonitědre
    crodra vremhrn niv,  nit těpoma-
    bud zroum nědě hlysk srážlo věti
    v chévu břat z mřidis.  Vrůštniž
    hrec z divluděře důd hrovu  mru-
    fí hlů člymflů miť.  Dě timan vé
    vřep  dředi  hlíboumrů  otoučpa-
    bi vadigu  skecru krel  opiv ha-
    ti. Flůchlavrum o mrepré z glouš
    stomřá,  cláni  ratikřes sámřáč-
    lit  šle a matěňáďsé.  Z  dělkác
    vostáčloř děť  nip chlapréleň  s
    myktý.  Fi  mlíďglůch  v clů ně-
    chreť  nichra kra zytý pepo zlo-
    famne  leř.  Třužláč klyť i vydě
    vo těž ďodlo hružlech drbětrévře
    tlezaz myv.  Mežrůst šlévro nyd.
    
    A kdyby to někdo potřeboval, tady je kód:
    #!/usr/bin/env python3
    def monoblock(text,width=80,lang='czech',emergencystretch='2em'):
        content=r'''
        \documentclass[]{article}
        \usepackage{polyglossia}
        \setdefaultlanguage{%s}
        %%\usepackage{showhyphens}
        \usepackage{fontspec}
        \setmainfont{Latin Modern Mono}
        \pagestyle{empty}
        \usepackage{ragged2e}
        \lefthyphenmin=2
        %% tune emergencystretch by hand until happy
        \emergencystretch=%s
        \parindent=0pt
        \begin{document}
            \begin{minipage}{%dex}
                \RaggedRight
                %s
            \end{minipage}
        \end{document}
        '''%(lang,emergencystretch,width,text)
        import tempfile, subprocess, os.path, webbrowser, time
        with tempfile.TemporaryDirectory() as tmpDir:
            tex,pdf=[tmpDir+'/main.'+ext for ext in ('tex','pdf')]
            print(tex)
            f=open(tex,'w')
            f.write(content)
            f.close()
            subprocess.call(['lualatex',tex],cwd=tmpDir)
            txt=subprocess.check_output(['pdftotext','-raw',pdf,'-']).decode('utf-8')
            webbrowser.open('file://'+os.path.abspath(pdf))
            time.sleep(2)
            return expandToBlock(txt,width)
    
    def expandToBlock(txt,wd):
        import re, random
        ll=txt.split('\n')
        lens=[len(l) for l in ll]
        maxWd=max(lens)
        if maxWd>wd: print('WARN: max unexpanded text width %d is greater than required width %d. Increasing to %d.'%(maxWd,wd,maxWd))
        wd=maxWd
        for i,l in enumerate(ll):
            # skip last paragraph line
            if i+1==len(ll) or (i+1<len(ll) and ll[i+1]==''): continue
            pats=[r'… \b',r'\. \b',r': \b',r', \b',r'\) \b',r'\b \(',r'\b \b']
            patReps=['… ','. ',': ',', ',') ',' (',' ']
            for ex in range(1,5): # expand to multiple spaces
                for pat,prep in zip([p.replace(' ',ex*' ') for p in pats],patReps):
                    matches=list(re.finditer(pat,l))
                    if not matches: continue
                    #random.shuffle(matches)
                    todo=min(len(matches),wd-len(l))
                    m2=random.sample(matches,todo)
                    # print('use %d occurrences of "%s" (out of %d)'%(todo,pat,len(matches)))
                    # replace from right to left to preserve indices
                    for m in sorted(m2,key=lambda x: -x.span()[0]): l=l[:m.span()[0]]+prep.replace(' ',(ex+1)*' ')+l[m.span()[1]:]
                    if len(l)==wd: break
                if len(l)==wd: break
            ll[i]=l
        return '\n'.join(ll)
    
    
    
    if __name__=='__main__':
        print('\n\n'+monoblock('Těby dived ptyzruně. Měji šlucry tří chré lážlotist vumrou tiper v nic gláti úmýpech. Vlydi troudi prýv k paská sro prytě flykřu v kust. Oří o půcpa a vimoj opo trouchetrá utě děšležrokla a mlehřou. Puďni šru vonitědre crodra vremhrn niv, nit těpomabud zroum nědě hlysk srážlo věti v chévu břat z mřidis. Vrůštniž hrec z divluděře důd hrovu mrufí hlů člymflů miť. Dě timan vé vřep dředi hlíboumrů otoučpabi vadigu skecru krel opiv hati. Flůchlavrum o mrepré z glouš stomřá, cláni ratikřes sámřáčlit šle a matěňáďsé. Z dělkác vostáčloř děť nip chlapréleň s myktý. Fi mlíďglůch v clů něchreť nichra kra zytý pepo zlofamne leř. Třužláč klyť i vydě vo těž ďodlo hružlech drbětrévře tlezaz myv. Mežrůst šlévro nyd.',width=40,emergencystretch='2em'))
    

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.