diff options
| author | Björn Peemöller <bjp@informatik.uni-kiel.de> | 2015-02-03 14:31:46 +0100 | 
|---|---|---|
| committer | John MacFarlane <jgm@berkeley.edu> | 2016-11-19 23:14:35 +0100 | 
| commit | 2761fecd57203c7dcdb30d72e194386942e62251 (patch) | |
| tree | 525c9cf24f4e1350efdfce4b2b08c4b88ab2c603 /src/Text | |
| parent | 18f5d25abe174683f73ddc177a9a7506d94a8236 (diff) | |
| download | pandoc-2761fecd57203c7dcdb30d72e194386942e62251.tar.gz | |
Fix for calculation of column widths for aligned multiline tables
This also fixes excessive CPU and memory usage for tables
when --columns is set in such a way that cells must be very
tiny.
Now cells are guaranteed to be big enough so that single
words don't need to line break, even if this pushes the
line length above the column width.
Closes #1911.
Diffstat (limited to 'src/Text')
| -rw-r--r-- | src/Text/Pandoc/Writers/Markdown.hs | 28 | 
1 files changed, 20 insertions, 8 deletions
| diff --git a/src/Text/Pandoc/Writers/Markdown.hs b/src/Text/Pandoc/Writers/Markdown.hs index 318c3204b..0e4ddc5b6 100644 --- a/src/Text/Pandoc/Writers/Markdown.hs +++ b/src/Text/Pandoc/Writers/Markdown.hs @@ -592,20 +592,32 @@ pipeTable headless aligns rawHeaders rawRows = do  pandocTable :: WriterOptions -> Bool -> [Alignment] -> [Double]              -> [Doc] -> [[Doc]] -> MD Doc -pandocTable opts headless aligns widths rawHeaders rawRows =  do +pandocTable opts headless aligns widths rawHeaders rawRows = do    let isSimple = all (==0) widths    let alignHeader alignment = case alignment of                                  AlignLeft    -> lblock                                  AlignCenter  -> cblock                                  AlignRight   -> rblock                                  AlignDefault -> lblock -  let numChars = maximum . map offset -  let widthsInChars = if isSimple -                         then map ((+2) . numChars) -                              $ transpose (rawHeaders : rawRows) -                         else map -                              (floor . (fromIntegral (writerColumns opts) *)) -                              widths +  -- Number of characters per column necessary to output every cell +  -- without requiring a line break. +  -- The @+2@ is needed for specifying the alignment. +  let numChars    = (+ 2) . maximum . map offset +  -- Number of characters per column necessary to output every cell +  -- without requiring a line break *inside a word*. +  -- The @+2@ is needed for specifying the alignment. +  let minNumChars = (+ 2) . maximum . map minOffset +  let columns = transpose (rawHeaders : rawRows) +  -- minimal column width without wrapping a single word +  let noWordWrapWidth +        | writerWrapText opts == WrapAuto +                              = fromIntegral $ maximum (map minNumChars columns) +        | otherwise           = fromIntegral $ maximum (map    numChars columns) +  let relWidth w = floor $ max (fromIntegral (writerColumns opts) * w) +                               (noWordWrapWidth * w / minimum widths) +  let widthsInChars +        | isSimple  = map numChars columns +        | otherwise = map relWidth widths    let makeRow = hcat . intersperse (lblock 1 (text " ")) .                     (zipWith3 alignHeader aligns widthsInChars)    let rows' = map makeRow rawRows | 
