# HG changeset patch # User Ludovic Chabant # Date 1417323644 28800 # Node ID ab6e7e0e9d443979e0c9e0286a50ed20b5c8d4ba # Parent 0609739169bde90933b77830a7e51033e3667c56 Pass date information to routing when building URLs. This is so that URLs with dates in them can be built even when the date information is not coming from the source metadata, but from the page's config. diff -r 0609739169bd -r ab6e7e0e9d44 piecrust/baking/baker.py --- a/piecrust/baking/baker.py Sat Nov 29 20:58:28 2014 -0800 +++ b/piecrust/baking/baker.py Sat Nov 29 21:00:44 2014 -0800 @@ -84,8 +84,9 @@ def bake(self, factory, route, record_entry, taxonomy_name=None, taxonomy_term=None): + custom_data = None pagination_filter = None - custom_data = None + route_metadata = dict(factory.metadata) if taxonomy_name and taxonomy_term: # Must bake a taxonomy listing page... we'll have to add a # pagination filter for only get matching posts, and the output @@ -108,10 +109,11 @@ taxonomy_term)) slugified_term = taxonomy_term custom_data = {tax.term_name: taxonomy_term} - uri = route.getUri({tax.term_name: slugified_term}) - else: - # Normal page bake. - uri = route.getUri(factory.metadata) + route_metadata.update({tax.term_name: slugified_term}) + + # Generate the URL using the route. + page = factory.buildPage() + uri = route.getUri(route_metadata, page) override = self.record.getOverrideEntry(factory, uri) if override is not None: @@ -131,7 +133,6 @@ has_more_subs = True force_this = self.force invalidate_formatting = False - page = factory.buildPage() record_entry.config = page.config.get().copy() prev_record_entry = self.record.getPreviousEntry( factory.source.name, factory.rel_path, diff -r 0609739169bd -r ab6e7e0e9d44 piecrust/data/base.py --- a/piecrust/data/base.py Sat Nov 29 20:58:28 2014 -0800 +++ b/piecrust/data/base.py Sat Nov 29 21:00:44 2014 -0800 @@ -123,7 +123,7 @@ route = page.app.getRoute(page.source.name, page.source_metadata) if route is None: raise Exception("Can't get route for page: %s" % page.path) - return route.getUri(page.source_metadata) + return route.getUri(page.source_metadata, page) def _loadCustom(self): page_url = self._get_uri() diff -r 0609739169bd -r ab6e7e0e9d44 piecrust/page.py --- a/piecrust/page.py Sat Nov 29 20:58:28 2014 -0800 +++ b/piecrust/page.py Sat Nov 29 21:00:44 2014 -0800 @@ -11,6 +11,7 @@ from werkzeug.utils import cached_property from piecrust.configuration import (Configuration, ConfigurationError, parse_config_header) +from piecrust.routing import IRouteMetadataProvider logger = logging.getLogger(__name__) @@ -36,7 +37,7 @@ FLAG_RAW_CACHE_VALID = 2**0 -class Page(object): +class Page(IRouteMetadataProvider): def __init__(self, source, source_metadata, rel_path): self.source = source self.source_metadata = source_metadata @@ -137,6 +138,13 @@ if was_cache_valid: self._flags |= FLAG_RAW_CACHE_VALID + def getRouteMetadata(self): + page_dt = self.datetime + return { + 'year': page_dt.year, + 'month': page_dt.month, + 'day': page_dt.day} + def _parse_config_date(page_date): if page_date is None: diff -r 0609739169bd -r ab6e7e0e9d44 piecrust/processing/sitemap.py --- a/piecrust/processing/sitemap.py Sat Nov 29 20:58:28 2014 -0800 +++ b/piecrust/processing/sitemap.py Sat Nov 29 21:00:44 2014 -0800 @@ -67,7 +67,7 @@ for page in source.getPages(): route = self.app.getRoute(source.name, page.source_metadata) - uri = route.getUri(page.source_metadata) + uri = route.getUri(page.source_metadata, page) t = page.datetime.timestamp() sm_cfg = page.config.get('sitemap') diff -r 0609739169bd -r ab6e7e0e9d44 piecrust/routing.py --- a/piecrust/routing.py Sat Nov 29 20:58:28 2014 -0800 +++ b/piecrust/routing.py Sat Nov 29 21:00:44 2014 -0800 @@ -10,6 +10,11 @@ template_func_arg_re = re.compile(r',\s*(?P\w+)') +class IRouteMetadataProvider(object): + def getRouteMetadata(self): + raise NotImplementedError() + + class Route(object): """ Information about a route for a PieCrust application. Each route defines the "shape" of an URL and how it maps to @@ -48,7 +53,10 @@ def isMatch(self, source_metadata): return True - def getUri(self, source_metadata): + def getUri(self, source_metadata, provider=None): + if provider: + source_metadata = dict(source_metadata) + source_metadata.update(provider.getRouteMetadata()) #TODO: fix this hard-coded shit for key in ['year', 'month', 'day']: if key in source_metadata and isinstance(source_metadata[key], str):