Code cleanup in Texinfo writer.

git-svn-id: https://pandoc.googlecode.com/svn/trunk@1316 788f1e2b-df1e-0410-8736-df70ead52e1b
This commit is contained in:
fiddlosopher 2008-07-13 23:49:32 +00:00
parent 9f14bf7d0c
commit 048aeabebe

View file

@ -31,8 +31,8 @@ module Text.Pandoc.Writers.Texinfo ( writeTexinfo ) where
import Text.Pandoc.Definition import Text.Pandoc.Definition
import Text.Pandoc.Shared import Text.Pandoc.Shared
import Text.Printf ( printf ) import Text.Printf ( printf )
import Data.List ( (\\), isSuffixOf ) import Data.List ( isSuffixOf )
import Data.Char ( toLower, chr, ord ) import Data.Char ( chr, ord )
import qualified Data.Set as S import qualified Data.Set as S
import Control.Monad.State import Control.Monad.State
import Text.PrettyPrint.HughesPJ hiding ( Str ) import Text.PrettyPrint.HughesPJ hiding ( Str )
@ -60,13 +60,14 @@ writeTexinfo options document =
WriterState { stIncludes = S.empty } WriterState { stIncludes = S.empty }
-- | Add a "Top" node around the document, needed by Texinfo. -- | Add a "Top" node around the document, needed by Texinfo.
wrapTop :: Pandoc -> Pandoc
wrapTop (Pandoc (Meta title authors date) blocks) = wrapTop (Pandoc (Meta title authors date) blocks) =
Pandoc (Meta title authors date) (Header 0 title : blocks) Pandoc (Meta title authors date) (Header 0 title : blocks)
pandocToTexinfo :: WriterOptions -> Pandoc -> State WriterState Doc pandocToTexinfo :: WriterOptions -> Pandoc -> State WriterState Doc
pandocToTexinfo options (Pandoc meta blocks) = do pandocToTexinfo options (Pandoc meta blocks) = do
main <- blockListToTexinfo blocks main <- blockListToTexinfo blocks
head <- if writerStandalone options head' <- if writerStandalone options
then texinfoHeader options meta then texinfoHeader options meta
else return empty else return empty
let before = if null (writerIncludeBefore options) let before = if null (writerIncludeBefore options)
@ -83,7 +84,7 @@ pandocToTexinfo options (Pandoc meta blocks) = do
let foot = if writerStandalone options let foot = if writerStandalone options
then text "@bye" then text "@bye"
else empty else empty
return $ head $$ toc $$ body $$ foot return $ head' $$ toc $$ body $$ foot
-- | Insert bibliographic information into Texinfo header. -- | Insert bibliographic information into Texinfo header.
texinfoHeader :: WriterOptions -- ^ Options, including Texinfo header texinfoHeader :: WriterOptions -- ^ Options, including Texinfo header
@ -114,6 +115,7 @@ texinfoHeader options (Meta title authors date) = do
datetext $$ datetext $$
text "@end titlepage" text "@end titlepage"
makeAuthor :: String -> Doc
makeAuthor author = text $ "@author " ++ (stringToTexinfo author) makeAuthor author = text $ "@author " ++ (stringToTexinfo author)
-- | Escape things as needed for Texinfo. -- | Escape things as needed for Texinfo.
@ -153,7 +155,7 @@ blockToTexinfo (CodeBlock _ str) = do
vcat (map text (lines str)) $$ vcat (map text (lines str)) $$
text "@end verbatim\n" text "@end verbatim\n"
blockToTexinfo (RawHtml str) = return empty blockToTexinfo (RawHtml _) = return empty
blockToTexinfo (BulletList lst) = do blockToTexinfo (BulletList lst) = do
items <- mapM listItemToTexinfo lst items <- mapM listItemToTexinfo lst
@ -161,7 +163,7 @@ blockToTexinfo (BulletList lst) = do
vcat items $$ vcat items $$
text "@end itemize\n" text "@end itemize\n"
blockToTexinfo (OrderedList (start, numstyle, numdelim) lst) = do blockToTexinfo (OrderedList (start, numstyle, _) lst) = do
items <- mapM listItemToTexinfo lst items <- mapM listItemToTexinfo lst
return $ text "@enumerate " <> exemplar $$ return $ text "@enumerate " <> exemplar $$
vcat items $$ vcat items $$
@ -214,6 +216,7 @@ blockToTexinfo (Header level lst) = do
seccmd 2 = "@section " seccmd 2 = "@section "
seccmd 3 = "@subsection " seccmd 3 = "@subsection "
seccmd 4 = "@subsubsection " seccmd 4 = "@subsubsection "
seccmd _ = error "illegal seccmd level"
blockToTexinfo (Table caption aligns widths heads rows) = do blockToTexinfo (Table caption aligns widths heads rows) = do
headers <- tableHeadToTexinfo aligns heads headers <- tableHeadToTexinfo aligns heads
@ -232,8 +235,14 @@ blockToTexinfo (Table caption aligns widths heads rows) = do
inCmd "caption" captionText $$ inCmd "caption" captionText $$
text "@end float" text "@end float"
tableHeadToTexinfo :: [Alignment]
-> [[Block]]
-> State WriterState Doc
tableHeadToTexinfo = tableAnyRowToTexinfo "@headitem " tableHeadToTexinfo = tableAnyRowToTexinfo "@headitem "
tableRowToTexinfo :: [Alignment]
-> [[Block]]
-> State WriterState Doc
tableRowToTexinfo = tableAnyRowToTexinfo "@item " tableRowToTexinfo = tableAnyRowToTexinfo "@item "
tableAnyRowToTexinfo :: String tableAnyRowToTexinfo :: String
@ -275,15 +284,15 @@ blockListToTexinfo (x:xs) = do
let menu = if level < 4 let menu = if level < 4
then collectNodes (level + 1) after then collectNodes (level + 1) after
else [] else []
lines <- mapM makeMenuLine menu lines' <- mapM makeMenuLine menu
let menu' = if null lines let menu' = if null lines'
then empty then empty
else text "@menu" $$ else text "@menu" $$
vcat lines $$ vcat lines' $$
text "@end menu" text "@end menu"
after' <- blockListToTexinfo after after' <- blockListToTexinfo after
return $ x' $$ before' $$ menu' $$ after' return $ x' $$ before' $$ menu' $$ after'
Para x -> do Para _ -> do
xs' <- blockListToTexinfo xs xs' <- blockListToTexinfo xs
case xs of case xs of
((CodeBlock _ _):_) -> return $ x' $$ xs' ((CodeBlock _ _):_) -> return $ x' $$ xs'
@ -292,10 +301,12 @@ blockListToTexinfo (x:xs) = do
xs' <- blockListToTexinfo xs xs' <- blockListToTexinfo xs
return $ x' $$ xs' return $ x' $$ xs'
isHeader :: Block -> Bool
isHeader (Header _ _) = True isHeader (Header _ _) = True
isHeader _ = False isHeader _ = False
collectNodes level [] = [] collectNodes :: Int -> [Block] -> [Block]
collectNodes _ [] = []
collectNodes level (x:xs) = collectNodes level (x:xs) =
case x of case x of
(Header hl _) -> (Header hl _) ->
@ -312,6 +323,7 @@ makeMenuLine :: Block
makeMenuLine (Header _ lst) = do makeMenuLine (Header _ lst) = do
txt <- inlineListForNode lst txt <- inlineListForNode lst
return $ text "* " <> txt <> text "::" return $ text "* " <> txt <> text "::"
makeMenuLine _ = error "makeMenuLine called with non-Header block"
listItemToTexinfo :: [Block] listItemToTexinfo :: [Block]
-> State WriterState Doc -> State WriterState Doc
@ -335,6 +347,7 @@ inlineListForNode :: [Inline] -- ^ Inlines to convert
-> State WriterState Doc -> State WriterState Doc
inlineListForNode lst = mapM inlineForNode lst >>= return . hcat inlineListForNode lst = mapM inlineForNode lst >>= return . hcat
inlineForNode :: Inline -> State WriterState Doc
inlineForNode (Str str) = return $ text $ filter (not.disallowedInNode) str inlineForNode (Str str) = return $ text $ filter (not.disallowedInNode) str
inlineForNode (Emph lst) = inlineListForNode lst inlineForNode (Emph lst) = inlineListForNode lst
inlineForNode (Strong lst) = inlineListForNode lst inlineForNode (Strong lst) = inlineListForNode lst
@ -357,6 +370,7 @@ inlineForNode (Image lst _) = inlineListForNode lst
inlineForNode (Note _) = return empty inlineForNode (Note _) = return empty
-- periods, commas, colons, and parentheses are disallowed in node names -- periods, commas, colons, and parentheses are disallowed in node names
disallowedInNode :: Char -> Bool
disallowedInNode c = c `elem` ".,:()" disallowedInNode c = c `elem` ".,:()"
-- | Convert inline element to Texinfo -- | Convert inline element to Texinfo
@ -418,7 +432,7 @@ inlineToTexinfo Ellipses = return $ text "@dots{}"
inlineToTexinfo (Str str) = return $ text (stringToTexinfo str) inlineToTexinfo (Str str) = return $ text (stringToTexinfo str)
inlineToTexinfo (Math str) = return $ inCmd "math" $ text str inlineToTexinfo (Math str) = return $ inCmd "math" $ text str
inlineToTexinfo (TeX str) = return $ text "@tex" $$ text str $$ text "@end tex" inlineToTexinfo (TeX str) = return $ text "@tex" $$ text str $$ text "@end tex"
inlineToTexinfo (HtmlInline str) = return empty inlineToTexinfo (HtmlInline _) = return empty
inlineToTexinfo (LineBreak) = return $ text "@*" inlineToTexinfo (LineBreak) = return $ text "@*"
inlineToTexinfo Space = return $ char ' ' inlineToTexinfo Space = return $ char ' '
@ -431,7 +445,7 @@ inlineToTexinfo (Link txt (src, _)) = do
return $ text ("@uref{" ++ src1 ++ ",") <> contents <> return $ text ("@uref{" ++ src1 ++ ",") <> contents <>
char '}' char '}'
inlineToTexinfo (Image alternate (source, tit)) = do inlineToTexinfo (Image alternate (source, _)) = do
content <- inlineListToTexinfo alternate content <- inlineListToTexinfo alternate
return $ text ("@image{" ++ base ++ ",,,") <> content <> text "," <> return $ text ("@image{" ++ base ++ ",,,") <> content <> text "," <>
text (ext ++ "}") text (ext ++ "}")