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 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
dnes 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
včera 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
včera 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 4
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 9
20.1. 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
20.1. 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
20.1. 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

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

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 360 hlasů
 Komentářů: 25, poslední včera 13:34
Rozcestník
Reklama

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: 294×
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: 71 | 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: 71 | 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: 71 | 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: 71 | 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: 71 | 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.