LaTeX reader: implement \newtoggle, \iftoggle, \toggletrue|false
from etoolbox. Closes #3853.
This commit is contained in:
parent
d1444b4ecd
commit
bfbdfa646a
3 changed files with 82 additions and 5 deletions
|
@ -75,6 +75,7 @@ data LogMessage =
|
|||
| DuplicateIdentifier String SourcePos
|
||||
| ReferenceNotFound String SourcePos
|
||||
| CircularReference String SourcePos
|
||||
| UndefinedToggle String SourcePos
|
||||
| ParsingUnescaped String SourcePos
|
||||
| CouldNotLoadIncludeFile String SourcePos
|
||||
| MacroAlreadyDefined String SourcePos
|
||||
|
@ -144,6 +145,11 @@ instance ToJSON LogMessage where
|
|||
"source" .= Text.pack (sourceName pos),
|
||||
"line" .= toJSON (sourceLine pos),
|
||||
"column" .= toJSON (sourceColumn pos)]
|
||||
UndefinedToggle s pos ->
|
||||
["contents" .= Text.pack s,
|
||||
"source" .= Text.pack (sourceName pos),
|
||||
"line" .= toJSON (sourceLine pos),
|
||||
"column" .= toJSON (sourceColumn pos)]
|
||||
ParsingUnescaped s pos ->
|
||||
["contents" .= Text.pack s,
|
||||
"source" .= Text.pack (sourceName pos),
|
||||
|
@ -238,6 +244,8 @@ showLogMessage msg =
|
|||
"Reference not found for '" ++ s ++ "' at " ++ showPos pos
|
||||
CircularReference s pos ->
|
||||
"Circular reference '" ++ s ++ "' at " ++ showPos pos
|
||||
UndefinedToggle s pos ->
|
||||
"Undefined toggle '" ++ s ++ "' at " ++ showPos pos
|
||||
ParsingUnescaped s pos ->
|
||||
"Parsing unescaped '" ++ s ++ "' at " ++ showPos pos
|
||||
CouldNotLoadIncludeFile fp pos ->
|
||||
|
@ -306,6 +314,7 @@ messageVerbosity msg =
|
|||
DuplicateIdentifier{} -> WARNING
|
||||
ReferenceNotFound{} -> WARNING
|
||||
CircularReference{} -> WARNING
|
||||
UndefinedToggle{} -> WARNING
|
||||
CouldNotLoadIncludeFile{} -> WARNING
|
||||
MacroAlreadyDefined{} -> WARNING
|
||||
ParsingUnescaped{} -> INFO
|
||||
|
|
|
@ -159,6 +159,7 @@ data LaTeXState = LaTeXState{ sOptions :: ReaderOptions
|
|||
, sInTableCell :: Bool
|
||||
, sLastHeaderNum :: HeaderNum
|
||||
, sLabels :: M.Map String [Inline]
|
||||
, sToggles :: M.Map String Bool
|
||||
}
|
||||
deriving Show
|
||||
|
||||
|
@ -177,6 +178,7 @@ defaultLaTeXState = LaTeXState{ sOptions = def
|
|||
, sInTableCell = False
|
||||
, sLastHeaderNum = HeaderNum []
|
||||
, sLabels = M.empty
|
||||
, sToggles = M.empty
|
||||
}
|
||||
|
||||
instance PandocMonad m => HasQuoteContext LaTeXState m where
|
||||
|
@ -1440,12 +1442,46 @@ inlineCommands = M.fromList $
|
|||
, ("xspace", doxspace)
|
||||
-- etoolbox
|
||||
, ("ifstrequal", ifstrequal)
|
||||
, ("newtoggle", braced >>= newToggle)
|
||||
, ("toggletrue", braced >>= setToggle True)
|
||||
, ("togglefalse", braced >>= setToggle False)
|
||||
, ("iftoggle", try $ ifToggle >> inline)
|
||||
]
|
||||
|
||||
newToggle :: (Monoid a, PandocMonad m) => [Tok] -> LP m a
|
||||
newToggle name = do
|
||||
updateState $ \st ->
|
||||
st{ sToggles = M.insert (toksToString name) False (sToggles st) }
|
||||
return mempty
|
||||
|
||||
setToggle :: (Monoid a, PandocMonad m) => Bool -> [Tok] -> LP m a
|
||||
setToggle on name = do
|
||||
updateState $ \st ->
|
||||
st{ sToggles = M.adjust (const on) (toksToString name) (sToggles st) }
|
||||
return mempty
|
||||
|
||||
ifToggle :: PandocMonad m => LP m ()
|
||||
ifToggle = do
|
||||
name <- braced
|
||||
spaces
|
||||
yes <- braced
|
||||
spaces
|
||||
no <- braced
|
||||
toggles <- sToggles <$> getState
|
||||
inp <- getInput
|
||||
let name' = toksToString name
|
||||
case M.lookup name' toggles of
|
||||
Just True -> setInput (yes ++ inp)
|
||||
Just False -> setInput (no ++ inp)
|
||||
Nothing -> do
|
||||
pos <- getPosition
|
||||
report $ UndefinedToggle name' pos
|
||||
return ()
|
||||
|
||||
doTerm :: PandocMonad m => Translations.Term -> LP m Inlines
|
||||
doTerm term = str <$> translateTerm term
|
||||
|
||||
ifstrequal :: PandocMonad m => LP m Inlines
|
||||
ifstrequal :: (PandocMonad m, Monoid a) => LP m a
|
||||
ifstrequal = do
|
||||
str1 <- tok
|
||||
str2 <- tok
|
||||
|
@ -1964,6 +2000,12 @@ environments = M.fromList
|
|||
, ("alignat", mathEnvWith para (Just "aligned") "alignat")
|
||||
, ("alignat*", mathEnvWith para (Just "aligned") "alignat*")
|
||||
, ("tikzpicture", rawVerbEnv "tikzpicture")
|
||||
-- etoolbox
|
||||
, ("ifstrequal", ifstrequal)
|
||||
, ("newtoggle", braced >>= newToggle)
|
||||
, ("toggletrue", braced >>= setToggle True)
|
||||
, ("togglefalse", braced >>= setToggle False)
|
||||
, ("iftoggle", try $ ifToggle >> block)
|
||||
]
|
||||
|
||||
environment :: PandocMonad m => LP m Blocks
|
||||
|
|
26
test/command/3853.md
Normal file
26
test/command/3853.md
Normal file
|
@ -0,0 +1,26 @@
|
|||
```
|
||||
% pandoc -f latex -t native
|
||||
\newtoggle{ebook}
|
||||
\toggletrue{ebook}
|
||||
\iftoggle{ebook}{
|
||||
ebook
|
||||
}%
|
||||
{
|
||||
not ebook
|
||||
}%
|
||||
more
|
||||
|
||||
\togglefalse{ebook}
|
||||
\iftoggle{ebook}{%
|
||||
ebook
|
||||
}{
|
||||
not ebook
|
||||
}%
|
||||
more
|
||||
|
||||
hello \iftoggle{ebook}{ebook}{noebook}
|
||||
^D
|
||||
[Para [Str "ebook",SoftBreak,Str "more"]
|
||||
,Para [Str "not",Space,Str "ebook",SoftBreak,Str "more"]
|
||||
,Para [Str "hello",Space,Str "noebook"]]
|
||||
```
|
Loading…
Reference in a new issue