Mais alguns problemas com geração de índice e tex4ebook

Mais alguns problemas com geração de índice e tex4ebook

Esta é uma continuação da minha pergunta anterioraqui.

Ele usa os arquivos fornecidos por @Michal.h21. Modifiquei o arquivo de entrada conforme abaixo:

\documentclass[ebook,12pt,oneside,openany]{memoir}

\begin{filecontents}{test.bib}
@book{Hiemenz,
author={Hiemenz},
title={Polymer Chemistry}
}
\end{filecontents}

\usepackage{lipsum}

\usepackage[backend=biber,hyperref=auto,backref=true]{biblatex}
\bibliography{test}

\usepackage{imakeidx}
\makeindex[intoc=true,columns=1,noautomatic]

\usepackage[hyperindex=true]{hyperref}

\title{Book}
\author{Author}
\date{}

\begin{document}

\maketitle

\frontmatter

\tableofcontents \newpage

\mainmatter

\chapter{C1}

aword\index{aword}

\lipsum \newpage

Here comes a quotation \cite{Hiemenz}.

\chapter{C2}

bword\index{bword}
\lipsum \newpage

\backmatter

\phantomsection
%\addcontentsline{toc}{chapter}{Bibliography}
\printbibliography \newpage

\phantomsection
\addcontentsline{toc}{chapter}{Index}
\indexprologue{Concepts}
\printindex

\end{document}

Os arquivos de configuração e construção são iguais aos da pergunta anterior e novamente fornecidos por @Michal.h21.

As principais questões são:

  1. O comando \indexprologue é tratado corretamente no pdf:

saída em pdf

No entanto, ele é ignorado na execução do tex4ebook.

saída tex4ebook

  1. Acho que há um comportamento inconsistente na opção intoc e na opção \addcontentsline{toc}{chapter}{Index}. A opção intoc é ignorada na execução do tex4ebook.

  2. O link do índice no sumário aponta para uma página em branco, e não para onde está o cabeçalho do índice.

saída tex4ebook

Está correto no arquivo pdf.

saída em pdf

  1. O uso de uma opção automática no comando makeindex não produz hiperlinks:

saída tex4ebook

Usar a opção noautomatic funciona. Este não é um grande problema, mas é diferente de como uma corrida normal de látex se comporta e parece estranho.

Outras pessoas já enfrentaram esses problemas e há alguma sugestão de correção ou maneira de obter resultados consistentes?

Suspeito que isso cairá sobre @Michal.h21 e por isso vou agradecê-lo antecipadamente.

Responder1

A versão anterior da configuração do imakeidxpacote não levava em consideração alguns recursos deste pacote, utilizava a tex4htconfiguração padrão para manipular o \printindexcomando. Podemos usar a versão modificada da imakeidxdefinição para obter suporte para alguns desses recursos.

Esta é a nova versão do imakeidx.4htarquivo:

\RequirePackage[]{etoolbox}
\RequirePackage{gettitlestring}
\newcounter{indexcnt}
\let\@Index\@index
\patchcmd{\@Index}{\@wrindex}{\@Wrindex}{}{}
\let\@Wrindex\@wrindex
\patchcmd{\@Wrindex}{\thepage}{\theindexcnt}{}{}
\let\xIndex\index
\patchcmd{\xIndex}{\@index}{\@Index}{}{}
\patchcmd{\xIndex}{\@index}{\@Index}{}{}

\pretocmd{\xIndex}{\@stepindexcnt\@indexanchor}
% \patchcmd{\index}{\@index}{\@Index}{}{}
% \patchcmd{\xIndex}{\@index}{\@Index}{}{}
% \let\protected@iwrite\protected@write
% \let\@index\@Index
% \patchcmd{\protected@iwrite}{\write}{\immediate\write}{}{}
\patchcmd{\@Wrindex}{\protected@write}{\protected@iwrite}{}{}
\let\Index\xIndex
\let\index\xIndex
%\show\Index
\newcommand\@indexanchor{%
  \edef\idx@anch{idx-anch\theindexcnt}%
  \Link[]{}{\idx@anch}\EndLink%
  %\Ref{(idx-link-\idx@anch)}{\FileName/\idx@anch}
}
\newcommand\@stepindexcnt{\stepcounter{indexcnt}}
\newcommand\hello[1]{\@hello#1}
\def\@hello#1/{%
  \Link{idx-anch#1}{}#1\EndLink%
}


\GetTitleStringSetup{expand}
\GetTitleStringDisableCommands{%
  \renewcommand\LaTeX{LaTeX}
}

\newcount\idxkwdcnt
\LinkCommand\IdxKWLink{span,href,id}
\newcommand\idxkeyword[1]{%
  \global\advance\idxkwdcnt by 1\relax%
  % use tags only one time
  \GetTitleString{#1}
  \ifcsdef{idxkw\GetTitleStringResult}{}%
  %{\Tag{idxkw#1}{idxkw\the\idxkwdcnt}}%
  {\expandafter\Tag\expandafter{idxkw\GetTitleStringResult}{idxkw\the\idxkwdcnt}}%
  \csgdef{idxkw\GetTitleStringResult}{x}
  \a:IdxKW{}{idxkw\the\idxkwdcnt}#1\b:IdxKW
}


\NewConfigure{IdxKW}{2}
\Configure{IdxKW}{\IdxKWLink}{\EndIdxKWLink}


\newcommand\idxlocator[1]{\Link{idx-anch#1}{}#1\EndLink}%

\renewenvironment{theindex}%
{\imki@maybeaddtotoc
  % \imki@indexlevel{\indexname}\imki@indexheaders
      \imki@idxprologue
      \global\let\imki@idxprologue\relax
      \parindent\z@
      \parskip\z@ \@plus .3\p@\relax
      \raggedright
      \let\item\@idxitem
    \imki@othercode}
{%
}


\let\indexspace\relax

\ConfigureEnv{theindex}{\ifvmode\IgnorePar\fi\EndP\HCode{<div class="theindex">}}{\ifvmode\IgnorePar\fi\EndP\HCode{</div>}}{}{}


\begin{filecontents*}{\jobname.xdy}
(define-attributes (("default" "definition" "textbf")))
( define-location-class "sec-num" :var
                        ("arabic-numbers"
             :sep "." "arabic-numbers"
             :sep "." "arabic-numbers"
             :sep "." "arabic-numbers"
             :sep "." "arabic-numbers"
))
(require "texindy.xdy")
(markup-keyword :open "\idxkeyword{" :close "}" )
(markup-locref :open "\idxlocator{" :close "}")
(markup-locref :open "\textbf{\idxlocator{" :close "}}"  :attr "textbf")
(markup-locref :open "\textbf{\idxlocator{" :close "}}"  :attr "definition")
\end{filecontents*}

A mudança importante é esta:

\renewenvironment{theindex}%
{\imki@maybeaddtotoc
  % \imki@indexlevel{\indexname}\imki@indexheaders
      \imki@idxprologue
      \global\let\imki@idxprologue\relax
      \parindent\z@
      \parskip\z@ \@plus .3\p@\relax
      \raggedright
      \let\item\@idxitem
    \imki@othercode}
{%
}


\let\indexspace\relax

\ConfigureEnv{theindex}{\ifvmode\IgnorePar\fi\EndP\HCode{<div class="theindex">}}{\ifvmode\IgnorePar\fi\EndP\HCode{</div>}}{}{}

O \reneenwironment{theindex}levará em consideração o \indexprologuesuporte ao TOC e \ConfigureEnv{theindex}adicionará <div class="theindex">elementos ao redor do conteúdo do índice.

Com essa mudança, você não precisa mais usar \addcontentsline{toc}{chapter}{Index}no seu documento, o link do TOC vincula corretamente ao índice.

Em relação à sua última pergunta, a automaticopção imakeidxnão funciona porque você precisa usar opções diferentes ao compilar with pdflatexe with tex4ht. É por isso que xindyé chamado a partir do arquivo de construção. A outra razão é que o LaTeX é chamado múltiplas vezes em cada execução do tex4ebook e não faz sentido compilar o índice em cada uma dessas chamadas.

insira a descrição da imagem aqui

informação relacionada