diff --git a/src/Text/Pandoc/Readers/LaTeX.hs b/src/Text/Pandoc/Readers/LaTeX.hs index a69c17ebc..b65ae15ad 100644 --- a/src/Text/Pandoc/Readers/LaTeX.hs +++ b/src/Text/Pandoc/Readers/LaTeX.hs @@ -1451,14 +1451,24 @@ parseAligns = try $ do <|> xAlign <|> mAlign <|> bAlign let alignPrefix = char '>' >> braced let alignSuffix = char '<' >> braced + let colWidth = try $ do + char '{' + ds <- many1 (oneOf "0123456789.") + spaces + string "\\linewidth" + char '}' + case safeRead ds of + Just w -> return w + Nothing -> return 0.0 let alignSpec = do spaces pref <- option "" alignPrefix spaces al <- alignChar - let parseWidth :: String -> Double - parseWidth _ = 0.00 -- TODO actually parse the width - width <- parseWidth <$> option "" braced + width <- colWidth <|> option 0.0 (do s <- braced + pos <- getPosition + report $ SkippedContent s pos + return 0.0) spaces suff <- option "" alignSuffix return (al, width, (pref, suff)) diff --git a/test/command/tabularx.md b/test/command/tabularx.md index 9e6069542..bf7670e9c 100644 --- a/test/command/tabularx.md +++ b/test/command/tabularx.md @@ -57,7 +57,7 @@ \hline \end{tabularx} ^D -[Table [] [AlignLeft,AlignCenter,AlignLeft] [0.0,0.0,0.0] +[Table [] [AlignLeft,AlignCenter,AlignLeft] [0.0,0.0,0.25] [[Plain [Str "Column",Space,Str "Heading",Space,Str "1"]] ,[Plain [Str "Column",Space,Str "Heading",Space,Str "2"]] ,[Plain [Str "Column",Space,Str "Heading",Space,Str "3"]]] @@ -94,7 +94,7 @@ \hline \end{tabularx} ^D -[Table [] [AlignLeft,AlignCenter,AlignLeft] [0.0,0.0,0.0] +[Table [] [AlignLeft,AlignCenter,AlignLeft] [0.25,0.0,0.25] [[Plain [Str "Column",Space,Str "Heading",Space,Str "1"]] ,[Plain [Str "Column",Space,Str "Heading",Space,Str "2"]] ,[Plain [Str "Column",Space,Str "Heading",Space,Str "3"]]]