Docx reader: more efficient trimSps.
Replacing trimLineBreaks. This does the work of normalizeSpaces as well, so we avoid the need for that function here. See #1530.
This commit is contained in:
parent
9862d7c359
commit
a197dc9d3f
1 changed files with 9 additions and 9 deletions
|
@ -83,7 +83,7 @@ import Data.Default (Default)
|
|||
import Data.List (delete, intersect)
|
||||
import qualified Data.Map as M
|
||||
import Data.Sequence (ViewL (..), viewl)
|
||||
import qualified Data.Sequence as Seq (null)
|
||||
import qualified Data.Sequence as Seq
|
||||
import qualified Data.Set as Set
|
||||
import Text.Pandoc.Builder
|
||||
-- import Text.Pandoc.Definition
|
||||
|
@ -476,12 +476,13 @@ rowToBlocksList (Row cells) = do
|
|||
blksList <- mapM cellToBlocks cells
|
||||
return $ map singleParaToPlain blksList
|
||||
|
||||
trimLineBreaks :: [Inline] -> [Inline]
|
||||
trimLineBreaks [] = []
|
||||
trimLineBreaks (LineBreak : ils) = trimLineBreaks ils
|
||||
trimLineBreaks ils
|
||||
| (LineBreak : ils') <- reverse ils = trimLineBreaks (reverse ils')
|
||||
trimLineBreaks ils = ils
|
||||
-- like trimInlines, but also take out linebreaks
|
||||
trimSps :: Inlines -> Inlines
|
||||
trimSps (Many ils) = Many $ Seq.dropWhileL isSp $ Seq.dropWhileR isSp $ ils
|
||||
where isSp Space = True
|
||||
isSp SoftBreak = True
|
||||
isSp LineBreak = True
|
||||
isSp _ = False
|
||||
|
||||
parStyleToTransform :: ParagraphStyle -> (Blocks -> Blocks)
|
||||
parStyleToTransform pPr
|
||||
|
@ -534,8 +535,7 @@ bodyPartToBlocks (Paragraph pPr parparts)
|
|||
makeHeaderAnchor $
|
||||
headerWith ("", delete style (pStyle pPr), []) n ils
|
||||
| otherwise = do
|
||||
ils <- smushInlines <$> mapM parPartToInlines parparts >>=
|
||||
(return . fromList . trimLineBreaks . normalizeSpaces . toList)
|
||||
ils <- (trimSps . smushInlines) <$> mapM parPartToInlines parparts
|
||||
dropIls <- gets docxDropCap
|
||||
let ils' = dropIls <> ils
|
||||
if dropCap pPr
|
||||
|
|
Loading…
Reference in a new issue