Conforme discutidoaqui, existem muitos comandos que podem ser usados para "depurar" o processo de composição do (La)TeX.
Também sei que às vezes o \show
comando pode ser usado para mostrar as definições das macros.
No entanto, eu sei que existem alguns comandos de depuração/rastreamento que começam com show, por exemplo, \showboxbreadth=xx
como se pode veraqui.
Existe alguma lista de tais comandos e suas ações?
Responder1
O livroTeX By Topic
de Victor Eijkhout descreve algumas \show...
macros.
Na visão geral a seguir X
significa algum valor inteiro e Y e número de 8 bits, \Z
é a abreviação de alguma 'quantidade interna', como count
, dimen
, \skip
ou token
registro, W
é uma lista de palavras separadas por palavra ou espaço.
\show
é um comando primitivo e mostra o significado de um token, ou seja, o que\meaning\foo
faz dentro do documento.\showboxdepth=X
tem o valor do nível mais profundo de aninhamento de caixa, padronizado comoX=3
simplesTeX
\showboxbreadth=X
tem o número máximo de itens mostrados por nível Isto tem umTeX
padrão simples deX=5
\showlists
é um primitivo e escreve o conteúdo de listas de caixas parciais em todos os 4 modos não matemáticos do TeX (ou seja, horizontal/vertical e as versões restritas)\showthe\Y
imprime o conteúdo de uma\Y
quantidade como no documento com\the
,\the\footoks
\showhyphens{W}
exibe a hifenização de W no terminal/log de acordo com as regras de hifenização.
Agora, o eTeX
padrão (que já é um padrão no momento em que este artigo foi escrito em abril de 2017) adiciona mais algumas \show...
ferramentas
\showifs
(ativado com\tracingifs=1
)\showgroups
(\tracinggroups=1
)\showtokens
para listas de tokens e conteúdo, que não é possível mostrar com\show
ou\showthe
.
Essas três eTeX
adições são independentes do modo.
LaTeX adiciona algumas macros wrapper, como
\showoutput
\showoverfull
\showhyphens
(sendo redefinido)
e define inicialmente \showboxbreadth=-1
e \showboxdepth=-1
também.
Aqui está um exemplo de documento LaTeX para \show...
entidades TeX simples.
\documentclass{article}
\newbox\foobox
\setbox\foobox=\hbox{A nice text}
\newcount\foocnt
\foocnt=17
\newtoks\footok
\footok={Gandalf The Grey}
\tracingoutput=1
\tracingonline=1
\begin{document}
\showboxbreadth=10
\showboxdepth=2
\scrollmode
\showbox\foobox
\showthe\footok
\showthe\foocnt
% Show lists
a\hfil\break b\par
c\hfill\break d
\hbox{e\vbox{f\showlists}}
\end{document}
A saída está tanto no console quanto no .log
arquivo (aqui cortei o cabeçalho e as estatísticas inferiores para fornecer \show...
apenas a saída relacionada):
> \box26=
\hbox(6.83331+0.0)x48.88896
.\OT1/cmr/m/n/10 A
.\glue 3.33333 plus 1.66498 minus 1.11221
.\OT1/cmr/m/n/10 n
.\OT1/cmr/m/n/10 i
.\OT1/cmr/m/n/10 c
.\OT1/cmr/m/n/10 e
.\glue 3.33333 plus 1.66666 minus 1.11111
.\OT1/cmr/m/n/10 t
.\OT1/cmr/m/n/10 e
.\OT1/cmr/m/n/10 x
.etc.
! OK.
l.23 \showbox\foobox
> Gandalf The Grey.
l.25 \showthe\footok
> 17.
l.27 \showthe\foocnt
### horizontal mode entered at line 32
\hbox(0.0+0.0)x15.0
\OT1/cmr/m/n/10 f
spacefactor 1000
### internal vertical mode entered at line 32
prevdepth ignored
### restricted horizontal mode entered at line 32
\OT1/cmr/m/n/10 e
spacefactor 1000
### horizontal mode entered at line 31
\hbox(0.0+0.0)x15.0
\OT1/cmr/m/n/10 c
\glue 0.0 plus 1.0fill
\penalty -10000
\OT1/cmr/m/n/10 d
\glue 3.33333 plus 1.66666 minus 1.11111
spacefactor 1000
### vertical mode entered at line 0
### current page:
\write-{}
\glue(\topskip) 5.69446
\hbox(4.30554+0.0)x345.0, glue set 324.99998fil
.\hbox(0.0+0.0)x15.0
.\OT1/cmr/m/n/10 a
.\glue 0.0 plus 1.0fil
.\penalty -10000
.\glue(\rightskip) 0.0
\penalty 300
\glue(\baselineskip) 5.05556
\hbox(6.94444+0.0)x345.0, glue set 339.44443fil
.\OT1/cmr/m/n/10 b
.\penalty 10000
.\glue(\parfillskip) 0.0 plus 1.0fil
.\glue(\rightskip) 0.0
\glue(\parskip) 0.0 plus 1.0
total height 22.0 plus 1.0
goal height 550.0
prevdepth 0.0
! OK.
l.32 \hbox{e\vbox{f\showlists
}}
Overfull \hbox (12.22223pt too wide) in paragraph at lines 31--33
\OT1/cmr/m/n/10 d []
\hbox(6.94444+0.0)x345.0, glue set - 1.0
.\OT1/cmr/m/n/10 d
.\glue 3.33333 plus 1.66666 minus 1.11111
.\hbox(6.94444+0.0)x349.44444
..\OT1/cmr/m/n/10 e
..\vbox(6.94444+0.0)x345.0 []
.\penalty 10000
.\glue(\parfillskip) 0.0 plus 1.0fil
.\glue(\rightskip) 0.0
Completed box being shipped out [1]
\vbox(633.0+0.0)x407.0
.\glue 16.0
.\vbox(617.0+0.0)x345.0, shifted 62.0
..\vbox(12.0+0.0)x345.0, glue set 12.0fil []
..\glue 25.0
..\glue(\lineskip) 0.0
..\vbox(550.0+0.0)x345.0, glue set 503.94617fil []
..\glue(\baselineskip) 23.55556
..\hbox(6.44444+0.0)x345.0, glue set 170.0fil []