T.P.Readers.LaTeX.Parsing: don't export totoks.

Make the first param of `tokenize` a SourcePos instead of
SourceName, and use it instead of `totoks`.
This commit is contained in:
John MacFarlane 2022-01-14 21:27:33 -08:00
parent 55cc9040cb
commit 4214218256
3 changed files with 12 additions and 13 deletions

View file

@ -126,7 +126,8 @@ resolveRefs _ x = x
-- res <- runIOorExplode (runParserT p defaultLaTeXState{
-- sOptions = def{ readerExtensions =
-- enableExtension Ext_raw_tex $
-- getDefaultExtensions "latex" }} "source" (tokenize "source" t))
-- getDefaultExtensions "latex" }} "source"
-- (tokenize (initialPos "source") t))
-- case res of
-- Left e -> error (show e)
-- Right r -> return r
@ -721,7 +722,7 @@ insertIncluded defaultExtension f' = do
Nothing -> do
report $ CouldNotLoadIncludeFile (T.pack f) pos
return ""
getInput >>= setInput . (tokenize f contents ++)
getInput >>= setInput . (tokenize (initialPos f) contents ++)
updateState dropLatestIncludeFile
authors :: PandocMonad m => LP m ()

View file

@ -96,7 +96,7 @@ verbTok stopchar = do
let (t1, t2) = T.splitAt i txt
inp <- getInput
setInput $ Tok (incSourceColumn pos i) Symbol (T.singleton stopchar)
: totoks (incSourceColumn pos (i + 1)) (T.drop 1 t2) ++ inp
: tokenize (incSourceColumn pos (i + 1)) (T.drop 1 t2) ++ inp
return $ Tok pos toktype t1
listingsLanguage :: [(Text, Text)] -> Maybe Text

View file

@ -32,7 +32,6 @@ module Text.Pandoc.Readers.LaTeX.Parsing
, getInputTokens
, untokenize
, untoken
, totoks
, toksToString
, satisfyTok
, parseFromToks
@ -307,7 +306,7 @@ applyMacros s = (guardDisabled Ext_latex_macros >> return s) <|>
pstate <- getState
let lstate = def{ sOptions = extractReaderOptions pstate
, sMacros = extractMacros pstate :| [] }
res <- runParserT retokenize lstate "math" (tokenize "math" s)
res <- runParserT retokenize lstate "math" (tokenize (initialPos "math") s)
case res of
Left e -> Prelude.fail (show e)
Right s' -> return s'
@ -324,7 +323,7 @@ QuickCheck property:
tokenizeSources :: Sources -> [Tok]
tokenizeSources = concatMap tokenizeSource . unSources
where
tokenizeSource (pos, t) = totoks pos t
tokenizeSource (pos, t) = tokenize pos t
-- Return tokens from input sources. Ensure that starting position is
-- correct.
@ -337,12 +336,11 @@ getInputTokens = do
Sources [] -> []
Sources ((_,t):rest) -> tokenizeSources $ Sources ((pos,t):rest)
tokenize :: SourceName -> Text -> [Tok]
tokenize sourcename = totoks (initialPos sourcename)
totoks :: SourcePos -> Text -> [Tok]
totoks pos t =
case T.uncons t of
tokenize :: SourcePos -> Text -> [Tok]
tokenize = totoks
where
totoks pos t =
case T.uncons t of
Nothing -> []
Just (c, rest)
| c == '\n' ->
@ -806,7 +804,7 @@ retokenizeComment = (do
let updPos (Tok pos' toktype' txt') =
Tok (incSourceColumn (incSourceLine pos' (sourceLine pos - 1))
(sourceColumn pos)) toktype' txt'
let newtoks = map updPos $ tokenize (sourceName pos) $ T.tail txt
let newtoks = map updPos $ tokenize pos $ T.tail txt
getInput >>= setInput . ((Tok pos Symbol "%" : newtoks) ++))
<|> return ()