Merge branch 'org-figure-fix'

This commit is contained in:
Albert Krewinkel 2016-08-18 14:34:07 +02:00
commit 29ac4ae813
No known key found for this signature in database
GPG key ID: 388DC0B21F631124
2 changed files with 27 additions and 10 deletions

View file

@ -39,8 +39,8 @@ import Text.Pandoc.Shared
import Text.Pandoc.Writers.Shared import Text.Pandoc.Writers.Shared
import Text.Pandoc.Pretty import Text.Pandoc.Pretty
import Text.Pandoc.Templates (renderTemplate') import Text.Pandoc.Templates (renderTemplate')
import Data.Char ( toLower ) import Data.Char ( isAlphaNum, toLower )
import Data.List ( intersect, intersperse, partition, transpose ) import Data.List ( isPrefixOf, intersect, intersperse, partition, transpose )
import Control.Monad.State import Control.Monad.State
data WriterState = data WriterState =
@ -158,10 +158,9 @@ blockToOrg (Plain inlines) = inlineListToOrg inlines
blockToOrg (Para [Image attr txt (src,'f':'i':'g':':':tit)]) = do blockToOrg (Para [Image attr txt (src,'f':'i':'g':':':tit)]) = do
capt <- if null txt capt <- if null txt
then return empty then return empty
else (\c -> "#+CAPTION: " <> c <> blankline) `fmap` else ("#+CAPTION: " <>) `fmap` inlineListToOrg txt
inlineListToOrg txt
img <- inlineToOrg (Image attr txt (src,tit)) img <- inlineToOrg (Image attr txt (src,tit))
return $ capt <> img return $ capt $$ img $$ blankline
blockToOrg (Para inlines) = do blockToOrg (Para inlines) = do
contents <- inlineListToOrg inlines contents <- inlineListToOrg inlines
return $ contents <> blankline return $ contents <> blankline
@ -355,16 +354,34 @@ inlineToOrg (Link _ txt (src, _)) = do
case txt of case txt of
[Str x] | escapeURI x == src -> -- autolink [Str x] | escapeURI x == src -> -- autolink
do modify $ \s -> s{ stLinks = True } do modify $ \s -> s{ stLinks = True }
return $ "[[" <> text x <> "]]" return $ "[[" <> text (orgPath x) <> "]]"
_ -> do contents <- inlineListToOrg txt _ -> do contents <- inlineListToOrg txt
modify $ \s -> s{ stLinks = True } modify $ \s -> s{ stLinks = True }
return $ "[[" <> text src <> "][" <> contents <> "]]" return $ "[[" <> text (orgPath src) <> "][" <> contents <> "]]"
inlineToOrg (Image _ _ (source, _)) = do inlineToOrg (Image _ _ (source, _)) = do
modify $ \s -> s{ stImages = True } modify $ \s -> s{ stImages = True }
return $ "[[" <> text source <> "]]" return $ "[[" <> text (orgPath source) <> "]]"
inlineToOrg (Note contents) = do inlineToOrg (Note contents) = do
-- add to notes in state -- add to notes in state
notes <- get >>= (return . stNotes) notes <- get >>= (return . stNotes)
modify $ \st -> st { stNotes = contents:notes } modify $ \st -> st { stNotes = contents:notes }
let ref = show $ (length notes) + 1 let ref = show $ (length notes) + 1
return $ " [" <> text ref <> "]" return $ " [" <> text ref <> "]"
orgPath :: String -> String
orgPath src =
case src of
[] -> mempty -- wiki link
('#':xs) -> xs -- internal link
_ | isUrl src -> src
_ | isFilePath src -> src
_ -> "file:" <> src
where
isFilePath :: String -> Bool
isFilePath cs = any (`isPrefixOf` cs) ["/", "./", "../", "file:"]
isUrl :: String -> Bool
isUrl cs =
let (scheme, path) = break (== ':') cs
in all (\c -> isAlphaNum c || c `elem` (".-"::String)) scheme
&& not (null path)

View file

@ -808,9 +808,9 @@ Auto-links should not occur here: =<http://example.com/>=
From "Voyage dans la Lune" by Georges Melies (1902): From "Voyage dans la Lune" by Georges Melies (1902):
#+CAPTION: lalune #+CAPTION: lalune
[[file:lalune.jpg]]
[[lalune.jpg]] Here is a movie [[file:movie.jpg]] icon.
Here is a movie [[movie.jpg]] icon.
-------------- --------------