summaryrefslogtreecommitdiff
path: root/src/pyssg
diff options
context:
space:
mode:
Diffstat (limited to 'src/pyssg')
-rw-r--r--src/pyssg/page.py27
-rw-r--r--src/pyssg/plt/index.html8
-rw-r--r--src/pyssg/plt/page.html4
-rw-r--r--src/pyssg/plt/tag.html8
4 files changed, 31 insertions, 16 deletions
diff --git a/src/pyssg/page.py b/src/pyssg/page.py
index 0161f25..85a6a47 100644
--- a/src/pyssg/page.py
+++ b/src/pyssg/page.py
@@ -59,6 +59,23 @@ class Page:
log.debug('getting metadata "%s" failed, using optional value "%s"', var, or_else)
return or_else
+ def cdate(self, format: str) -> str:
+ if format in self.config['fmt']:
+ return self.cdatetime.strftime(self.config['fmt'][format])
+ else:
+ log.warning('format "%s" not found in config["fmt"], returning empty string', format)
+ return ''
+
+ def mdate(self, format: str) -> str:
+ if self.mdatetime is None:
+ log.warning('no mdatetime found, can\'t return a formatted string')
+ return ''
+ if format in self.config['fmt']:
+ return self.mdatetime.strftime(self.config['fmt'][format]) # type: ignore
+ else:
+ log.warning('format "%s" not found in config["fmt"], returning empty string', format)
+ return ''
+
# parses meta from self.meta, for og, it prioritizes,
# the actual og meta
def parse_metadata(self):
@@ -70,16 +87,14 @@ class Page:
log.debug('parsing timestamp')
self.cdatetime = datetime.fromtimestamp(self.ctimestamp, tz=timezone.utc)
- cdate = lambda x : self.cdatetime.strftime(self.config['fmt'][x])
- self.cdate_rss = cdate('rss_date')
- self.cdate_sitemap = cdate('sitemap_date')
+ self.cdate_rss = self.cdate('rss_date')
+ self.cdate_sitemap = self.cdate('sitemap_date')
if self.mtimestamp != 0.0:
log.debug('parsing modified timestamp')
self.mdatetime = datetime.fromtimestamp(self.mtimestamp, tz=timezone.utc)
- mdate = lambda x : self.mdatetime.strftime(self.config['fmt'][x]) # type: ignore
- self.mdate_rss = mdate('rss_date')
- self.mdate_sitemap = mdate('sitemap_date')
+ self.mdate_rss = self.mdate('rss_date')
+ self.mdate_sitemap = self.mdate('sitemap_date')
else:
log.debug('not parsing modified timestamp, hasn\'t been modified')
diff --git a/src/pyssg/plt/index.html b/src/pyssg/plt/index.html
index c33fd37..7c034bb 100644
--- a/src/pyssg/plt/index.html
+++ b/src/pyssg/plt/index.html
@@ -19,13 +19,13 @@
<ul>
{%for p in all_pages%}
{%if loop.previtem%}
- {%if loop.previtem.cdatetime.strftime(config['fmt']['list_sep_date']) != p.cdatetime.strftime(config['fmt']['list_sep_date'])%}
- <h3>{{p.cdatetime.strftime(config['fmt']['list_sep_date'])}}</h3>
+ {%if loop.previtem.cdate('list_sep_date') != p.cdate('list_sep_date')%}
+ <h3>{{p.cdate('list_sep_date')}}</h3>
{%endif%}
{%else%}
- <h3>{{p.cdatetime.strftime(config['fmt']['list_sep_date'])}}</h3>
+ <h3>{{p.cdate('list_sep_date')}}</h3>
{%endif%}
- <li>{{p.cdatetime.strftime(config['fmt']['list_date'])}} - <a href="{{p.url}}">{{p.title}}</a></li>
+ <li>{{p.cdate('list_date')}} - <a href="{{p.url}}">{{p.title}}</a></li>
{%endfor%}
</ul>
</body>
diff --git a/src/pyssg/plt/page.html b/src/pyssg/plt/page.html
index 08e92f1..93d4da9 100644
--- a/src/pyssg/plt/page.html
+++ b/src/pyssg/plt/page.html
@@ -8,9 +8,9 @@
<body>
<h1>{{page.title}}</h1>
<p>By {{page.author}}</p>
- <p>Created: {{page.cdatetime.strftime(config['fmt']['date'])}}</p>
+ <p>Created: {{page.cdate('date')}}</p>
{%if page.mdatetime is not none%}
- <p>Modified: {{page.mdatetime.strftime(config['fmt']['date'])}}</p>
+ <p>Modified: {{page.mdate('date')}}</p>
{%endif%}
{{page.content}}
diff --git a/src/pyssg/plt/tag.html b/src/pyssg/plt/tag.html
index 2dd7177..aff7982 100644
--- a/src/pyssg/plt/tag.html
+++ b/src/pyssg/plt/tag.html
@@ -13,13 +13,13 @@
<ul>
{%for p in tag_pages%}
{%if loop.previtem%}
- {%if loop.previtem.cdatetime.strftime(config['fmt']['list_sep_date']) != p.cdatetime.strftime(config['fmt']['list_sep_date'])%}
- <h3>{{p.cdatetime.strftime(config['fmt']['list_sep_date'])}}</h3>
+ {%if loop.previtem.cdate('list_sep_date') != p.cdate('list_sep_date')%}
+ <h3>{{p.cdate('list_sep_date')}}</h3>
{%endif%}
{%else%}
- <h3>{{p.cdatetime.strftime(config['fmt']['list_sep_date'])}}</h3>
+ <h3>{{p.cdate('list_sep_date')}}</h3>
{%endif%}
- <li>{{p.cdatetime.strftime(config['fmt']['list_date'])}} - <a href="{{p.url}}">{{p.title}}</a></li>
+ <li>{{p.cdate('list_date')}} - <a href="{{p.url}}">{{p.title}}</a></li>
{%endfor%}
</ul>
</body>