diff options
| author | Jesse Rosenthal <jrosenthal@jhu.edu> | 2014-08-12 10:26:49 -0400 | 
|---|---|---|
| committer | Jesse Rosenthal <jrosenthal@jhu.edu> | 2014-08-12 10:26:49 -0400 | 
| commit | 9d0b390d48823e2fcbcbabf84fd105b595bcb60b (patch) | |
| tree | 8132d433e79778ef92b81fb73b6ea0c0dc1ef37f | |
| parent | e4a8e4a636fb4b9bc860591f31bdb8e4dde62049 (diff) | |
| download | pandoc-9d0b390d48823e2fcbcbabf84fd105b595bcb60b.tar.gz | |
Docx reader: move combining logic to Reducible
Introduces a new function in Reducibles, concatR.  The idea is that if we
have two list of Reducibles (blocks or inlines), we can combine them and
just perform the reduction on the joining parts (the last element of the
first list, the first element of the second list). This is useful in cases
where the two lists are already reduced, and we're only worried about the
joining elements.
This actually improves the efficiency a bit further, because concatR can be
smart about empty lists.
| -rw-r--r-- | src/Text/Pandoc/Readers/Docx.hs | 4 | ||||
| -rw-r--r-- | src/Text/Pandoc/Readers/Docx/Reducible.hs | 10 | 
2 files changed, 11 insertions, 3 deletions
| diff --git a/src/Text/Pandoc/Readers/Docx.hs b/src/Text/Pandoc/Readers/Docx.hs index 10dc45581..9943ebeb8 100644 --- a/src/Text/Pandoc/Readers/Docx.hs +++ b/src/Text/Pandoc/Readers/Docx.hs @@ -462,9 +462,7 @@ bodyPartToBlocks (Paragraph pPr parparts)  bodyPartToBlocks (Paragraph pPr parparts) = do    ils <- parPartsToInlines parparts >>= (return . normalizeSpaces)    dropIls <- gets docxDropCap -  let ils' = case ils of -        (x:xs) -> reduceList (dropIls ++ [x]) ++ xs -        []     -> dropIls +  let ils' = concatR dropIls ils    if dropCap pPr      then do modify $ \s -> s { docxDropCap = ils' }              return [] diff --git a/src/Text/Pandoc/Readers/Docx/Reducible.hs b/src/Text/Pandoc/Readers/Docx/Reducible.hs index a852e25bf..39a93d988 100644 --- a/src/Text/Pandoc/Readers/Docx/Reducible.hs +++ b/src/Text/Pandoc/Readers/Docx/Reducible.hs @@ -39,6 +39,7 @@ module Text.Pandoc.Readers.Docx.Reducible ((<++>),                                             innards,                                             reduceList,                                             reduceListB, +                                           concatR,                                             rebuild)         where @@ -78,6 +79,15 @@ reduceList' as (x:xs) = reduceList' (init as ++ (last as <++> x) ) xs  reduceList :: (Reducible a) => [a] -> [a]  reduceList = reduceList' [] +concatR :: (Reducible a) => [a] -> [a] -> [a] +concatR [] [] = [] +concatR [] ss = ss +concatR rs [] = rs +concatR rs ss = let (x:xs) = reverse rs +                    (y:ys) = ss +                in +                 reverse xs ++ ( x <++> y ) ++ ys +  combineReducibles :: (Reducible a, Eq a) => a -> a -> [a]  combineReducibles r s =    let (conts, rs) = topLevelContainers r | 
