ConTeXt writer: Use itemize options, not sym{}, to produce ordered
lists with custom numbering styles. git-svn-id: https://pandoc.googlecode.com/svn/trunk@1079 788f1e2b-df1e-0410-8736-df70ead52e1b
This commit is contained in:
parent
13d8a75060
commit
780b77c147
1 changed files with 28 additions and 14 deletions
|
@ -129,20 +129,34 @@ blockToConTeXt opts (RawHtml str) = return empty
|
||||||
blockToConTeXt opts (BulletList lst) = do
|
blockToConTeXt opts (BulletList lst) = do
|
||||||
contents <- mapM (listItemToConTeXt opts) lst
|
contents <- mapM (listItemToConTeXt opts) lst
|
||||||
return $ text "\\startltxitem" $$ vcat contents $$ text "\\stopltxitem"
|
return $ text "\\startltxitem" $$ vcat contents $$ text "\\stopltxitem"
|
||||||
blockToConTeXt opts (OrderedList attribs lst) = case attribs of
|
blockToConTeXt opts (OrderedList (start, style, delim) lst) = do
|
||||||
(1, DefaultStyle, DefaultDelim) -> do
|
contents <- mapM (listItemToConTeXt opts) lst
|
||||||
contents <- mapM (listItemToConTeXt opts) lst
|
let start' = if start == 1 then "" else "start=" ++ show start
|
||||||
return $ text "\\startltxenum"$$ vcat contents $$ text "\\stopltxenum"
|
let delim' = case delim of
|
||||||
_ -> do
|
DefaultDelim -> ""
|
||||||
let markers = take (length lst) $ orderedListMarkers attribs
|
Period -> "stopper=."
|
||||||
contents <- zipWithM (orderedListItemToConTeXt opts) markers lst
|
OneParen -> "stopper=)"
|
||||||
let markerWidth = maximum $ map length markers
|
TwoParens -> "left=(,stopper=)"
|
||||||
let markerWidth' = if markerWidth < 3
|
let width = maximum $ map length $ take (length contents)
|
||||||
then ""
|
(orderedListMarkers (start, style, delim))
|
||||||
else "[width=" ++
|
let width' = (toEnum width + 1) / 2
|
||||||
show ((markerWidth + 2) `div` 2) ++ "em]"
|
let width'' = if width' > 1.5
|
||||||
return $ text ("\\startitemize" ++ markerWidth') $$ vcat contents $$
|
then "width=" ++ show width' ++ "em"
|
||||||
text "\\stopitemize"
|
else ""
|
||||||
|
let specs2Items = filter (not . null) [start', delim', width'']
|
||||||
|
let specs2 = if null specs2Items
|
||||||
|
then ""
|
||||||
|
else "[" ++ joinWithSep "," specs2Items ++ "]"
|
||||||
|
let style' = case style of
|
||||||
|
DefaultStyle -> if null specs2 then "" else "[]"
|
||||||
|
Decimal -> "[n]"
|
||||||
|
LowerRoman -> "[r]"
|
||||||
|
UpperRoman -> "[R]"
|
||||||
|
LowerAlpha -> "[a]"
|
||||||
|
UpperAlpha -> "[A]"
|
||||||
|
let specs = style' ++ specs2
|
||||||
|
return $ text ("\\startitemize" ++ specs) $$ vcat contents $$
|
||||||
|
text "\\stopitemize\n"
|
||||||
blockToConTeXt opts (DefinitionList lst) =
|
blockToConTeXt opts (DefinitionList lst) =
|
||||||
mapM (defListItemToConTeXt opts) lst >>= return . (<> char '\n') . vcat
|
mapM (defListItemToConTeXt opts) lst >>= return . (<> char '\n') . vcat
|
||||||
blockToConTeXt opts HorizontalRule = return $ text "\\thinrule\n"
|
blockToConTeXt opts HorizontalRule = return $ text "\\thinrule\n"
|
||||||
|
|
Loading…
Reference in a new issue