29 lines
794 B
Python
29 lines
794 B
Python
|
# -*- coding: utf-8 -*-
|
||
|
"""
|
||
|
Dateish Plugin for Pelican
|
||
|
==========================
|
||
|
|
||
|
This plugin adds the ability to treat arbitrary metadata fields as datetime
|
||
|
objects.
|
||
|
"""
|
||
|
|
||
|
from pelican import signals
|
||
|
from pelican.utils import get_date
|
||
|
|
||
|
|
||
|
def dateish(generator):
|
||
|
if 'DATEISH_PROPERTIES' not in generator.settings:
|
||
|
return
|
||
|
|
||
|
for article in generator.articles:
|
||
|
for field in generator.settings['DATEISH_PROPERTIES']:
|
||
|
if hasattr(article, field):
|
||
|
value = getattr(article, field)
|
||
|
if type(value) == list:
|
||
|
setattr(article, field, [get_date(d) for d in value])
|
||
|
else:
|
||
|
setattr(article, field, get_date(value))
|
||
|
|
||
|
def register():
|
||
|
signals.article_generator_finalized.connect(dateish)
|