私はpandocを使用して(誰かがより良い変換プログラムを持っているなら、私はすべての耳です、Rubyに依存しないでください)マークダウンファイルをマンページに変換しようとしています。テーブルを使ってドキュメントを作成するまでは問題なく動作します。これが私のテストドキュメントです:
% Author Man
% TEST(1) This is a test | Version .01
% 18-April-2016
# Header1
# Format
foo
+-----------+-----------+-----------+
| linenum-1 | two | three |
|===========+===========+===========+
| three | four | fove |
| 6 | 7 | 8 |
+-----------+-----------+-----------+
| linenum-1 | two | three |
|-----------|-----------|-----------|
| three | four | fove |
| 6 | 7 | 8 |
| linenum-1 | two | three
|-----------|-----------|--------:
| three | four | fove
| 6 | 7 | 8
I WAS HERE
| linenum-1 | two | three
|--- |--- |---
| three | four | fove
| 6 | 7 | 8
here is some text
_italics_
**bold**
使っていた
pandoc.exe -s -f markdown -t man ~/test.md | man -p t -l -
(私は-p t
の有無にかかわらずtbl
プリプロセッサを強制しようとしました)同じ結果で:
Author Man() Author Man()
Header1
Format
foo
tab(@); lw(11.7n) lw(11.7n) lw(11.7n). T{
linenum-1 ===========+ three 6 T}@T{
two ===========+ four 7 T}@T{
three ===========+ fove 8 T}
tab(@); l l l. T{ linenum-1 T}@T{ two T}@T{ three T} _ T{ three T}@T{ four T}@T{ fove T}
T{ 6 T}@T{ 7 T}@T{ 8 T}
tab(@); l l r. T{ linenum-1 T}@T{ two T}@T{ three T} _ T{ three T}@T{ four T}@T{ fove T}
T{ 6 T}@T{ 7 T}@T{ 8 T}
I WAS HERE
tab(@); l l l. T{ linenum-1 T}@T{ two T}@T{ three T} _ T{ three T}@T{ four T}@T{ fove T}
T{ 6 T}@T{ 7 T}@T{ 8 T}
here is some text
italics
bold
AUTHORS
TEST(1) This is a test | Version .01.
18-April-2016 Author Man()
man
にパイプしない場合の生の出力は次のとおりです。
.\"t
.\" Automatically generated by Pandoc 1.17.0.2
.\"
.TH "Author Man" "" "18\-April\-2016" "" ""
.hy
.SH Header1
.SH Format
.PP
foo
.PP
.TS
tab(@);
lw(11.7n) lw(11.7n) lw(11.7n).
T{
.PP
linenum\-1 ===========+ three 6
T}@T{
.PP
two ===========+ four 7
T}@T{
.PP
three ===========+ fove 8
T}
.TE
.PP
.TS
tab(@);
l l l.
T{
linenum\-1
T}@T{
two
T}@T{
three
T}
_
T{
three
T}@T{
four
T}@T{
fove
T}
T{
6
T}@T{
7
T}@T{
8
T}
.TE
.PP
.TS
tab(@);
l l r.
T{
linenum\-1
T}@T{
two
T}@T{
three
T}
_
T{
three
T}@T{
four
T}@T{
fove
T}
T{
6
T}@T{
7
T}@T{
8
T}
.TE
.PP
I WAS HERE
.PP
.TS
tab(@);
l l l.
T{
linenum\-1
T}@T{
two
T}@T{
three
T}
_
T{
three
T}@T{
four
T}@T{
fove
T}
T{
6
T}@T{
7
T}@T{
8
T}
.TE
.PP
here is some text
.PP
\f[I]italics\f[]
.PP
\f[B]bold\f[]
.SH AUTHORS
TEST(1) This is a test | Version .01.
-d
フラグを使用すると、多くのことが得られますが、最後のビットだけが適用できるようです。
final search path = /mingw64/share/man:/usr/share/man
restore_cwd: 3 (null)
pre-processors `t' from command line
page_encoding = UTF-8
source_encoding = ISO-8859-1
roff_encoding = ISO-8859-1
Terminal width 102
Terminal width 102 not within cat page range [80, 80]
formatted_encoding = UTF-8
opening -
opened -
そして楽しい部分...
私のdebian8.3ボックスのPandocは同じ出力を生成しましたが、マンページはdebian/linuxでそれをうまく表示します。
比較のために
私はman man
man groff_man
man tbl
などを何時間も読んでいますが、これを解決するのに近づいていません。ここでのアイデアは大歓迎です!!
ありがとう-エリック
問題は間違いなく、windows/msys上のman
および関連するgroff
システムです。 pandocの出力はLinuxで正常に機能します。
別のレンダリングプログラムを見つけて試しました。
http://embedeo.org/ws/doc/man_windows/
問題のない形式でpandocからの出力を表示します
mandoc.exe foo.man.1 | less
より直接的な再試行
cat foo.man.1 | nroff -mandoc -Tlatin1 | less
man -l -
を呼び出すのとまったく同じ効果があります
次に、gnuwin32バイナリを直接ダウンロードしてみましたが、同じ結果になりました。
cat foo.man.1 | Downloads/groff-1.20.1-bin/bin/nroff -mandoc -Tlatin1 | less
どうやら今週は少し遅いようです...
想像できる最も簡単な修正で、私は3日しか無駄にしませんでした。
pandoc.exe -s -f markdown -t man ~/test.md | dos2unix.exe | man -l -
(重要なのはdos2unix.exe
ミックスに)
美しい収量:
Author Man() Author Man()
Header1
Format
foo
linenum-1 two three
===========+ ===========+ ===========+
three four fove
6 7 8
linenum-1 two three
─────────────────────────
three four fove
6 7 8
linenum-1 two three
─────────────────────────
three four fove
6 7 8
I WAS HERE
linenum-1 two three
─────────────────────────
three four fove
6 7 8
here is some text
italics
bold
AUTHORS
TEST(1) This is a test | Version .01.
18-April-2016 Author Man()