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í
×
    včera 23:11 | Nová verze

    Byla vydána nová verze 0.4.15 (𝕏) svobodného operačního systému ReactOS (Wikipedie), jehož cílem je kompletní binární kompatibilita s aplikacemi a ovladači pro Windows. Přehled novinek i s náhledy v oznámení o vydání.

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

    Byl představen rpi-image-gen, tj. oficiální nástroj pro vytváření vlastních softwarových obrazů pro zařízení Raspberry Pi.

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

    Byla vydána nová major verze 8.0, aktuálně 8.0.1, softwaru pro správu elektronických knih Calibre (Wikipedie). Přehled novinek v poznámkách k vydání. Vypíchnuta je lepší podpora Kobo KEPUB formátu nebo integrovaný lokálně běžící engine Piper pro převod textu na řeč používaný pro čtení nahlas (již od verze 7.18).

    Ladislav Hagara | Komentářů: 0
    včera 05:22 | IT novinky

    Společnost OpenAI rozšířila své API o nové audio modely. Nový model pro převod textu na řeč (text-to-speech model) lze bez přihlašování vyzkoušet na stránce OpenAI.fm.

    Ladislav Hagara | Komentářů: 2
    20.3. 21:33 | Zajímavý článek

    Příspěvek Bezpečnost paměti pro webové fonty na blogu Chrome pro vývojáře rozebírá, proč se pro zpracování webových fontů v Chrome místo FreeType nově používá v Rustu napsaná Skrifa z Fontations.

    Ladislav Hagara | Komentářů: 0
    20.3. 15:22 | Komunita

    V pátek 21. a v sobotu 22. března proběhnou Arduino Days 2025, tj. každoroční „narozeninová oslava“ platformy Arduino. Na programu je řada zajímavých přednášek. Sledovat je bude možné na YouTube. Zúčastnit se lze i lokálních akcí. V sobotu v Praze na Matfyzu.

    Ladislav Hagara | Komentářů: 0
    20.3. 11:00 | Pozvánky

    Komunitná konferencia Bratislava OpenCamp, ktorá sa uskutoční už o tri týždne 5. 4. 2025 na FIIT STU pozná svoj program – návštevníkom ponúkne 3 paralelné behy prednášok a workshopov na rôzne témy týkajúce sa otvoreného softvéru či otvorených technológií.

    Ladislav Hagara | Komentářů: 0
    20.3. 05:11 | Zajímavý článek

    Časopis MagPi od nakladatelství Raspberry Pi se s číslem 151 přejmenoval na Raspberry Pi Official Magazine. I pod novým názvem zůstává nadále ve formátu pdf zdarma ke čtení.

    Ladislav Hagara | Komentářů: 0
    20.3. 01:55 | IT novinky

    Japonská SoftBank Group kupuje firmu Ampere Computing za 6,5 miliardy dolarů. Ampere Computing vyrábí 32-128jádrové procesory Ampere Altra a 192jádrové procesory AmpereOne.

    Ladislav Hagara | Komentářů: 12
    20.3. 01:11 | Nová verze

    Byla vydána (𝕏) nová verze 2025.1a linuxové distribuce navržené pro digitální forenzní analýzu a penetrační testování Kali Linux (Wikipedie). Přehled novinek v oficiálním oznámení na blogu.

    Ladislav Hagara | Komentářů: 0
    Jaké je vaše preferované prostředí?
     (27%)
     (1%)
     (1%)
     (2%)
     (2%)
     (2%)
     (65%)
     (2%)
    Celkem 192 hlasů
     Komentářů: 6, poslední včera 11:15
    Rozcestník

    Dotaz: man: write error: Přerušena roura (SIGPIPE)

    26.4.2007 11:29 Kit
    man: write error: Přerušena roura (SIGPIPE)
    Přečteno: 395×
    Při vyvolání jakékoli manuálové stránky se mi zobrazí pouze

    Unimplemented option chosen.

    Formátuji split(1), prosím počkejte chvíli... /usr/bin/nroff: line 217: echo: write error: Peruena roura (SIGPIPE)

    Zvláštní je, že se tato chyba neobjeví, pokud jsem přihlášen jako root - manuálová stránka se normálně zobrazí. Tedy někde budou asi špatně práva nebo cesty. Dělalo mi to u openSUSE 10.1 a očekával jsem, že to v další verzi opraví. Verze 10.2 však tuto chybu obsahuje také. Snažil jsem se tuto chybu najít a opravit, ale ztratil jsem se v binárkách. Má někdo řešení?

    Odpovědi

    26.4.2007 11:39 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    V openSuSE 10.1 ani 10.2 nejspíš žádná chyba není, mám (měl jsem) je nainstalované na několika počítačích a nikdy jsem podobný problém nezaznamenal. Zkuste si zavést nového uživatele a spustit to pod ním; pokud bude man fungovat, je problém ve vaší uživatelské konfiguraci (možná chybně nastavená proměnná PAGER); jinak by to asi chtělo použít strace, abyste zjistil, co se to vlastně pokouší spustit za potomka a proč umřel.
    26.4.2007 14:50 Kit
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    Mám ho nainstalované na více počítačích a dělá mi to na třech.

    Nový uživatel má stejný problém. $PAGER má hodnotu "less", což by mělo být OK. Zkusil jsem i "/usr/bin/less", ale beze změny. Při spuštění nroff jsem si nechal vypsat seznam procesů:
     PID TTY      STAT   TIME COMMAND
     6108 pts/2    Ss     0:00 /bin/bash
     7731 pts/2    S+     0:00 man mkdir
     7732 pts/2    S+     0:00 sh -c (echo '.ll 79n'; /usr/bin/zsoelim /usr/share/man/man1/mkdir.1) | /usr/bin/tbl | /usr/bin/nroff -mandocdb -rLL=79n -rLT=79n -Tutf8 | less
     7736 pts/2    S+     0:00 /bin/sh /usr/bin/nroff -mandocdb -rLL=79n -rLT=79n -Tutf8
    
    Zatím v tom chybu nevidím. Přesto mi man stále nefunguje.
    26.4.2007 15:47 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)

    Ještě jeden nápad: zkuste sem hodit výpis

      for v in ${!LESS*}; do echo "$v='${!v}'"; done
    

    (nejlépe jednou pod rootem, jednou pod normálním uživatelem).

    26.4.2007 16:24 Kit
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    > for v in ${!LESS*}; do echo "$v='${!v}'"; done
    LESS='-M -I'
    LESSCLOSE='lessclose.sh %s %s'
    LESSKEY='/etc/lesskey.bin'
    LESSOPEN='lessopen.sh %s'
    LESS_ADVANCED_PREPROCESSOR='no'
    > su
    Heslo:
    # for v in ${!LESS*}; do echo "$v='${!v}'"; done
    LESS='-M -I'
    LESSCLOSE='lessclose.sh %s %s'
    LESSKEY='/etc/lesskey.bin'
    LESSOPEN='lessopen.sh %s'
    LESS_ADVANCED_PREPROCESSOR='no'
    
    26.4.2007 16:27 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    Tak asi opravdu nezbyde než na to vypustit strace a podívat se, který program přesně tam havaruje a proč.
    26.4.2007 16:35 Kit
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    Ten strace vyprodukuje asi 5000 řádků, zkusím sem poslat pár posledních:
    rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
    clone(child_stack=0, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0xb7d6fb48) = 6279
    close(3)                                = 0
    close(5)                                = 0
    rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
    pipe([3, 5])                            = 0
    rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
    clone(child_stack=0, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0xb7d6fb48) = 6280
    close(4)                                = 0
    close(5)                                = 0
    rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
    rt_sigprocmask(SIG_BLOCK, [CHLD], [], 8) = 0
    clone(child_stack=0, flags=CLONE_CHILD_CLEARTID|CLONE_CHILD_SETTID|SIGCHLD, child_tidptr=0xb7d6fb48) = 6281
    close(3)                                = 0
    rt_sigprocmask(SIG_SETMASK, [], NULL, 8) = 0
    waitpid(-1, /usr/bin/nroff: line 203: Scenario: command not found
    /usr/bin/nroff: line 204: Scenario: command not found
    /usr/bin/nroff: line 205: Unimplemented: command not found
    /usr/bin/nroff: line 206: Unimplemented: command not found
    /usr/bin/nroff: line 207: Scenario: command not found
    /usr/bin/nroff: line 208: Scenario: command not found
    /usr/bin/nroff: line 209: Scenario: command not found
    /usr/bin/nroff: line 210: 2: command not found
    [{WIFEXITED(s) && WEXITSTATUS(s) == 0}], 0) = 6281
    --- SIGCHLD (Child exited) @ 0 (0) ---
    sigreturn()                             = ? (mask now [])
    waitpid(-1, 0xbfbb2e98, WNOHANG)        = 0
    waitpid(-1, /usr/bin/nroff: line 217: echo: write error: P�eru�ena roura (SIGPIPE)
    [{WIFEXITED(s) && WEXITSTATUS(s) == 0}], 0) = 6280
    --- SIGCHLD (Child exited) @ 0 (0) ---
    sigreturn()                             = ? (mask now [])
    waitpid(-1, [{WIFSIGNALED(s) && WTERMSIG(s) == SIGPIPE}], WNOHANG) = 6278
    waitpid(-1, [{WIFSIGNALED(s) && WTERMSIG(s) == SIGPIPE}], 0) = 6279
    rt_sigaction(SIGINT, {SIG_DFL}, NULL, 8) = 0
    rt_sigaction(SIGQUIT, {SIG_DFL}, NULL, 8) = 0
    chdir("/home/pospichal")                = 0
    ioctl(0, SNDCTL_TMR_START or TCSETS, {B38400 opost isig icanon echo ...}) = 0
    ioctl(0, SNDCTL_TMR_TIMEBASE or TCGETS, {B38400 opost isig icanon echo ...}) = 0
    exit_group(0)                           = ?
    Process 6277 detached
    
    26.4.2007 16:43 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)

    Tohle mi připadá, jako byste měl /usr/bin/nroff (což je skript, který emuluje tradiční nroff pomocí groff) přepsaný nějakými nesmysly. V openSuSE 10.2 by měl mít MD5 kontrolní součet

      15c08b049d17656b083cbe4dee2e0589  /usr/bin/nroff
    
    26.4.2007 16:53 Kit
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    MD5 nroff souhlasí. Sedím teď u jiného PC, kde mi (jak jsem před chvílí zjistil) man nefunguje ani pod rootem. Ještě se podívám na PC, kde mi man chodí alespoň pod rootem a na PC, kde mi man funguje i pod běžným userem (instaloval jsem ho včera).
    26.4.2007 16:56 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    Tak se aspoň podívejte, jak vypadají řádky 203-210 v /usr/bin/nroff na tom systému, ze kterého pochází ten výpis strace.
    26.4.2007 17:14 Kit
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    while true ; do
        case "$1" in
            --)
                if [ -n "$2" ] ; then
                    INPUTFILE="$2"
                    shift 2
                else
                    INPUTFILE=""
                    shift 1
                fi
                break
                ;;
            *)
                OLDARGS="$OLDARGS $1"
                echo $1
                shift 1
                ;;
        esac
    done
    
    Ovšem MD5 jsme si před chvílí odsouhlasili a obsah $1 už tady taky proběhl. Vše vypadá normálně - až na to, že to nefunguje.
    1.5.2007 19:51 Kit
    Rozbalit Rozbalit vše Re: man: write error: Přerušena roura (SIGPIPE)
    Tak jsem si to nakonec vyřešil sám. Místo pochybného while true ; do jsem prozatím vložil while false ; do. O 2 řádky výš je totiž chybný příkaz
    TEMP=$(getopt --options  "abcCd:eEf:F:gGhiI:lL:m:M:n:No:pP:r:RsStT:UvVw:W:XzZ" --longoptions help,version -- ${1+"$@"})
    
    jehož výsledkem v TEMP je řetězec "Unimplemented option chosen.". Nevím, co je na tom příkazu špatně, protože parametry odpovídají popisu v manuálu. Od této chvíle mi už man chodí alespoň v nějakém degradovaném režimu.

    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.