Грамотный Haskell: ссылки и индексирование

Поддерживает ли Literate Haskell имена имен индексирования, типы и ссылки на переменные? Есть ли фильтр, который я могу запустить на источнике Literate Haskell, который сделает это и предоставит мне либо хорошее руководство по PDF, либо гиперссылку HTML-документа.

Это действительно приятные черты noweb и CWEB, который, по моему мнению, послужит широким распространением грамотности Haskell.

В качестве примера рассмотрим программу подсчета слов, написанную на CWEB. Блок кода на первой странице в элементе # 4 содержит примечания о том, где используется этот код. LHS не поддерживает куски, но я хотел бы знать, где используется код:

  • Комментарий, описывающий func.

    func = id

    Используется в: (X.Y.Z.f, A.B.C.g, раздел 1.5)

    func2 = indefined

    Используется в: (A.B.C.x, раздел 2.1)

Кроме того, индекс, который объединяет все имена функций и переменные, где они ссылаются в документе, и другими функциями и т.д.

Ответы

Ответ 1

В Latex есть некоторые возможности: далее listings, а также makeindex для создания списка всех функций. Кроме того, \label используется для создания перекрестных ссылок между различными разделами:

\documentclass[a4paper,11pt,reqno,twoside,pdflatex,makeidx]{amsart}

\usepackage[a4paper]{geometry}

\usepackage{listings}
\lstloadlanguages{Haskell}

\lstset{
    flexiblecolumns=false,
    basewidth={0.5em,0.45em},
    basicstyle=\ttfamily,
    language=haskell,
    % numbers=left, % optional numbering of code lines
    firstnumber=last,
    numberstyle=\tiny,
    stepnumber=2,  
    numbersep=5pt,
    index={fac,fac2}
}

\lstnewenvironment{code}{}{}

\usepackage{hyperref}

\title{The factorial function}
\author{Federico Squartini}
\date{}


\makeindex

\begin{document}
\maketitle
\section{Factorial function}
\label{code:fac1}
The factorial function can be defined as:

\begin{code}

fac 0 = 1
fac n = n * fac (n-1)

\end{code}

\section{Factorial function in constant space}
The code for the factorial defined section~\ref{code:fac1} uses $o(n)$ stack
space. The following function uses constant space:

\begin{code}

fac2 n = go 1 1
    where
      go !acc i| i <= n = go (acc*i) (i+1)
               | otherwise = acc

\end{code}

\printindex
\end{document}

Скомпилировать с помощью:

pdflatex example.tex

makeindex example.idx

pdflatex example.tex

pdflatex example.tex

Результат pdf здесь. Это отлично подходит для создания pdf файлов. Для других видов выходов (например, html) вы должны использовать латекс вместе с pandoc.

Другим вариантом является использование синтаксиса разметки pandoc, смешанного с специальными латексными командами (\ label и makeindex). Это должно упростить задачу, а также уменьшить синтаксический шум в исходных файлах.