avoid overwriting timestamps if they are forced by markdown already

This commit is contained in:
Mirek Kratochvil 2023-06-22 11:34:00 +02:00
parent 91900a323c
commit fa7d1fab55
5 changed files with 17 additions and 10 deletions

View file

@ -132,7 +132,8 @@ siteOptions' = do
_timestampSuffix <- _timestampSuffix <-
strOption $ strOption $
long "timestamp-prefix" <> long "timestamp-prefix" <>
help "Timestamp file suffix for markdowns" <> value ".timestamp" <> showDefault help "Timestamp file suffix for markdowns" <>
value ".timestamp" <> showDefault
_dumpFinalState <- _dumpFinalState <-
switch $ switch $
long "dump-state" <> long "dump-state" <>

View file

@ -2,6 +2,8 @@
mount: /404 mount: /404
title: Page not found title: Page not found
search: off search: off
toc: off
timestamp: null
--- ---
# Page not found! # Page not found!

View file

@ -3,6 +3,7 @@ mount: /
title: Home title: Home
template: index.html template: index.html
toc: off toc: off
timestamp: null
--- ---
#### What are How-To Cards? #### What are How-To Cards?

View file

@ -4,6 +4,7 @@ title: Search
template: search.html template: search.html
search: off search: off
toc: off toc: off
timestamp: null
--- ---
# Search # Search

View file

@ -182,7 +182,9 @@ timestampFile fp = do
-- | If a timestamp file for the page exists, add the timestamp metadata. -- | If a timestamp file for the page exists, add the timestamp metadata.
addTimeMeta :: PageInfo -> Y.Value -> Site Y.Value addTimeMeta :: PageInfo -> Y.Value -> Site Y.Value
addTimeMeta pi m'@(Y.Object m) = do addTimeMeta pi m'@(Y.Object m)
| "timestamp" `KM.member` m = pure m' -- do not overwrite the timestamp if present
| otherwise = do
tspath <- timestampFile $ pi ^. pagePath tspath <- timestampFile $ pi ^. pagePath
io $ io $
ifM ifM