abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 16:11 | Nová verze

    Bylo oznámeno vydání Fedora Linuxu 40. Přehled novinek ve Fedora Workstation 40 a Fedora KDE 40 na stránkách Fedora Magazinu. Současně byl oznámen notebook Slimbook Fedora 2.

    Ladislav Hagara | Komentářů: 0
    dnes 13:44 | Upozornění

    ČTK (Česká tisková kancelář) upozorňuje (X), že na jejím zpravodajském webu České noviny byly dnes dopoledne neznámým útočníkem umístěny dva smyšlené texty, které nepocházejí z její produkce. Jde o text s titulkem „BIS zabránila pokusu o atentát na nově zvoleného slovenského prezidenta Petra Pelligriniho“ a o údajné mimořádné prohlášení ministra Lipavského k témuž. Tyto dezinformace byly útočníky zveřejněny i s příslušnými notifikacemi v mobilní aplikaci Českých novin. ČTK ve svém zpravodajském servisu žádnou informaci v tomto znění nevydala.

    Ladislav Hagara | Komentářů: 6
    dnes 13:33 | Komunita

    Byla založena nadace Open Home Foundation zastřešující více než 240 projektů, standardů, ovladačů a knihoven (Home Assistant, ESPHome, Zigpy, Piper, Improv Wi-Fi, Wyoming, …) pro otevřenou chytrou domácnost s důrazem na soukromí, možnost výběru a udržitelnost.

    Ladislav Hagara | Komentářů: 0
    dnes 13:00 | Nová verze

    Společnost Meta otevírá svůj operační systém Meta Horizon OS pro headsety pro virtuální a rozšířenou realitu. Vedle Meta Quest se bude používat i v připravovaných headsetech od Asusu a Lenova.

    Ladislav Hagara | Komentářů: 0
    dnes 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

    Ladislav Hagara | Komentářů: 0
    včera 23:44 | Nová verze

    Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Zajímavý článek

    50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.

    Ladislav Hagara | Komentářů: 0
    včera 16:22 | Pozvánky

    Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.

    TomasVondra | Komentářů: 0
    včera 03:00 | IT novinky

    Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].

    Ladislav Hagara | Komentářů: 6
    včera 02:00 | IT novinky

    Ještě letos vyjde Kingdom Come: Deliverance II (YouTube), pokračování počítačové hry Kingdom Come: Deliverance (Wikipedie, ProtonDB Gold).

    Ladislav Hagara | Komentářů: 9
    KDE Plasma 6
     (71%)
     (10%)
     (2%)
     (17%)
    Celkem 688 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    TeX

    TODO
    Informace o skupině
    Založena: 24. 8. 2008
    Členů: 47
    Článků: 0
    Wiki stránek: 1
    Dotazů: 108
    Akcí: 0
    Čtenost: 30 %
    Skóre: 29

    Dotaz: pdflatex: dělení slov v uvozovkách

    23.12.2016 14:34 mirek19 | skóre: 4
    pdflatex: dělení slov v uvozovkách
    Přečteno: 1817×
    Všechny srdečně zdravím. Narazil jsem na problém, že první slovo textu po uzavření do uvozovek, např. \uv{nejvyšší ...} se přestane dělit. Už jsem podobný problém řešil, tak vím, čím to asi je a zkusil jsem před dělené slovo vložit mezeru : \uv{ nejvyšší}. Podle předpokladu se slovo rozdělilo správně. Jen mezera mezi levými uvozovkami a slovem ja trapas. Tak jsem mezeru nahradil \uv{\hspace[0pt}nejvyšší} a už to vypadá dobře. Jenže vkládat \hspace všude (nevím, který text se během úprav dostane na konec řádku) se mi nechce a navíc se obávám, že se takto může stát, že řádek se zlomí tak, že uvozovky budou jako poslední znak na řádku a text začne na řádku novém. Vyzkoušel jsem pár jiných maker v této situaci (např. \textbf{}) a tento problém se nikde neobjevil.

    Nevíte někdo, co s tím, popřípadě, je-li to chyba makra jako takového, na koho se obrátit s žádostí o úpravu? Používám Fedoru 23 a texlive přímo z této distribuce.

    Odpovědi

    wamba avatar 23.12.2016 16:11 wamba | skóre: 38 | blog: wamba
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    hm skutečně to tak dělá, není třeba v českém pravopise takové pravidlo? Nicméně můžete redefinovat \uv:

    např. \renewcommand\uv[1]{\quotedblbase #1\textquotedblleft
    This would have been so hard to fix when you don't know that there is in fact an easy fix.
    23.12.2016 19:06 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    není třeba v českém pravopise takové pravidlo?
    Není. (A nebylo by to pravidlo v pravopise, ale v typografických zvyklostech, ale není ani tam.) Spíš bych to viděl na technický problém, jestli se třeba místa možného dělení neurčují před aplikací maker nebo uvozovka není považována za součást slova (neznámý znak) a pak se nedokáže pro dané slovo najít místo pro dělení? Nechovají se takhle i jiná makra? Platí to samé i pro poslední slovo (i když neznámý znak na konci slova by dělení nemusel vadit)? Chová se to stejně, i když místa pro dělení vyznačíte přímo v textu (aby to nezáviselo na algoritmickém dělení nebo na slovníku)?
    24.12.2016 00:12 mirek19 | skóre: 4
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    1. Zkoušel jsem několik jiných maker a žádné se tak nezachovalo.

    2. Poslední slovo se vždy dělí v pořádku, jak má.

    3. V případě přímo vyznačených míst pro dělení \uv{nev\-vyš\-ší} je slovo děleno normálně, jak má.

    4. Jak jsem psal, řešil jsem dřív podobný problém v diskusi: https://groups.google.com/forum/#!topic/cz.comp.cstex/U-v-o44UofI, kdy se nedělilo slovo za příkazem \marginpar{} . Nakonec to vyřešilo odstranění mezery před \marginpar{}. V podstatě šlo o to, že makro \marginpar{} vložilo před následující slovo něco, co způsobilo, že TeX to slovo pak nepovažuje za vhodné k dělení. Pokud je i v případě \uv{} ten samý důvod, tak tu ovšem neplatí to samé řešení, protože v případě \marginpar{} byl problém mezi makrem a následujícím slovem, a tedy šel řešit naúrovni textu, jenže tady je problém uvnitř makra \uv{}, a tedy na úrovni textu neřešitelný (vložení mezery nepovažuji za řešení, redefinice makra není na úrovni textu).
    24.12.2016 09:41 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Předpokládám, že je to tedy tím, že se uvozovky (nebo něco jiného) berou jako součást slova, a tím pádem nefunguje algoritmus pro určení míst dělení slova nebo vyhledávání ve slovníku (podobně jako ten \marginpar{}). Napadá mne jediné, co by to makro mohlo dělat víc, než jen vkládat uvozovky – dělat „zavěšené uvozovky“, tj. uvozovky na začátku nebo na konci řádku vysouvat mírně za okraj textu. Dělá se to tak s interpunkcí na konci řádku, protože interpunkce dělá na řádku hlavně bílé místo, takže když vyjde na okraj a nevysune se ven, vypadá to, že je tam v okraji textu „zub“. V případě počátečních uvozovek pak má smysl dělat to samé na začátku řádku.
    24.12.2016 11:16 mirek19 | skóre: 4
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Ano, rozumím. Nicméně stále zůstává otázka, co s tím... Napadá mě jedině obrátit se na někoho, kdo je schopen makro \uv{} upravit.
    24.12.2016 11:18 ttt
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Předpokládám, že je to tedy tím, že se uvozovky (nebo něco jiného) berou jako součást slova
    Spíš ne. Jako součást slova se berou znaky, které mají nenulový [pre]\lccode[/pre], tedy převoditelné na malé písmeno. Problém bude v podmínkách, kdy je možné slovo dělit. Musí (mimo jiné)

    • před slovem (po přeskočení dalších znaků*) být mezera typu hglue.

    • za slovem (po přeskočení dalších znaků*) nebýt linka, box nebo písmeno.

    * další znak je znak s nulovým \lccode

    Tipuju, že samotné \uv bude v pořádku, ale problém bude až s uvozovkami, které jsou vkládané pomocí \clqq, \crqq. Našel jsem několik definic, ale nebyl jsem moudrý z toho, která se používá., zobrazit se mi to nepodařilo. Mezi nimi i takové, které obsah obalily do boxu, který zabrání dělení. Kromě zavěšených uvozovek třeba zachovávají spacefactor (řídí velikost mezery) tak, aby se řídil podle posledního písmene nebo posunují uvozovky o fous doleva/doprava.

    24.12.2016 13:39 mirek19 | skóre: 4
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Ano, tohle je ai nejpřesnější. Ovšem z mého pohledu ne příliš znalého uživatele je jedno, jestli problém je v makru nebo v uvozovkách. Prostě je mimo úroveň textu a bylo by fajn najít řešení.

    Pro mě je jediná možnost pokaždé projít závěrečnou verzi textu a doplnit ručně místa k dělení na patřičná místa. A pak znovu, protože tím doplněním se změnil zlom, takže se na konec řádku mohla dostat jiná slova. Ale takto přijdu jen na ta místa, kde se nezlomené slovo vysadí částečně za okraj textu (overfull hbox). Na jiných místech se vysází nezlomená slova korektně, ale sazba není tak dobrá, jak by mohla, což je škoda.
    25.12.2016 03:23 ttt
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Makro \uv je definované* jako {\leavevmode \clqq #1\crqq }. \leavevmode řeší problém na začátku odstavce. Pak je potřeba zjistit, co dělá problém, jestli \clqq nebo \crqq nebo obojí - podíval jsem se, jak se to chová, když to odeberu. Ukázalo se, ze \clqq. Patrně tedy končí něčím jiným než mezerou typu glue*. Co s tím?

    Nacpat tam mezeru nulové velikosti, která se nijak neprojeví. Tedy to, co jsi experimentálně zjistil. Tím se vyřeší problém s rozdělením slova, ale jak správně píšeš, vznikne nový - v této mezeře může nastat řádkový zlom a uvozovky zůstanou jako poslední znak na řádku. To už má jednoduché řešení, před tu mezeru se vloží \nobreak, což zamezí zlomu. Pokud jsem nic neopomněl, je korektní řešení předefinovat \uv jako {\leavevmode\clqq\nobreak\hskip0pt #1\crqq}

    --

    * Ve skutečnosti je tam ještě test, jestli to neběží v kompabilním módu. Příkaz, jak zjistit, jestli expanduje na výše uvedené je pár příspěvků níž.

    ** Může se lišit podle použitých balíků, zkoušel jsem to s kombinací
    \documentclass[a4]{article}
    \usepackage[czech]{babel}
    \usepackage[utf8]{inputenc}
    \usepackage[T1]{fontenc}
    
    S takovou kombinací je \clqq definované jako {\kern.1em\quotedblbase\kern-.0158em\relax}, tedy skutečně končí kernem, ne mezerou typu glue.
    25.12.2016 14:11 mirek19 | skóre: 4
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Jo, tak se to zdá být vyřešené. Mám přesně tu zkoušenou kombinaci, jen místo article používám book. Trochu mě překvapuje, že se definice uvozovek mění podle jiných balíků, ale už se ničemu nedivím a věřím, že to má své důvody (ještě jsem se nesetkal s ničím bezdůvodným v těchto případech).

    V této souvislosti ještě řeším vnoření uvozovek. Makro \uviq mi nefunguje a nefunguje. Ale pokud si nadefinuju vnořené uvozovky stejným způsobem jako je uvedená redefinice \uv jen použiju \clq, \crq, \frqq, flqq tak by to mělo fungovat taky korektně. Mám pravdu? Jen si musím ručně ohlídat úroveň, popřípadě dodefinovat nějaký čítač, což by taky mělo být v pohodě.

    Díky
    23.12.2016 23:52 mirek19 | skóre: 4
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Ano, redefinice věc vyřešila. Ale nedělá původní makro ještě něco jiného, je opravdu tak jednoduché? Co si vzpomínám, tak se v něm řeší nějaký problémy na krajích odstavců nebo tak něco..... Ale to fakt nevím.
    24.12.2016 02:58 ttt
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Co makro uv dělá lze zjistit pomocí \expandafter\show\csname uv \endcsname. V mém případě nic navíc:
    > \uv =\long macro:
    #1->{\leavevmode \clqq #1\crqq }.
    pavlix avatar 24.12.2016 00:09 pavlix | skóre: 54 | blog: pavlix
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Není lepší tam ty uvozovky narvat rovnou? Mimochodem já to pořád tvrdím, že je tex bullshit (i když pořád asi nejlepší, co máme) a že by se to nemělo přeceňovat.
    Já už tu vlastně ani nejsem. Abclinuxu umřelo.
    24.12.2016 11:57 ttt
    Rozbalit Rozbalit vše Re: pdflatex: dělení slov v uvozovkách
    Myslím si, že jsem tu okolo 3 hodiny ranní poslal příspěvek se vzorovým kódem, kde mi dělení funguje, ale obsahoval i anglickou citaci z TexBooku. Nemohl skončit ve spamu? Taky jsem ho mohl neodeslat ... Zajímá mě ten zdroják, po ránu se mi nedaří replikovat, ale tehdy to určitě fungovalo.

    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.