diff piecrust/sources/prose.py @ 853:f070a4fc033c

core: Continue PieCrust3 refactor, simplify pages. The asset pipeline is still the only function pipeline at this point. * No more `QualifiedPage`, and several other pieces of code deleted. * Data providers are simpler and more focused. For instance, the page iterator doesn't try to support other types of items. * Route parameters are proper known source metadata to remove the confusion between the two. * Make the baker and pipeline more correctly manage records and record histories. * Add support for record collapsing and deleting stale outputs in the asset pipeline.
author Ludovic Chabant <ludovic@chabant.com>
date Sun, 21 May 2017 00:06:59 -0700
parents 4850f8c21b6e
children d9059257743c
line wrap: on
line diff
--- a/piecrust/sources/prose.py	Wed May 17 00:11:48 2017 -0700
+++ b/piecrust/sources/prose.py	Sun May 21 00:06:59 2017 -0700
@@ -1,5 +1,3 @@
-import os
-import os.path
 import copy
 import logging
 from piecrust.sources.default import DefaultContentSource
@@ -12,21 +10,19 @@
     SOURCE_NAME = 'prose'
 
     def __init__(self, app, name, config):
-        super(ProseSource, self).__init__(app, name, config)
+        super().__init__(app, name, config)
         self.config_recipe = config.get('config', {})
 
-    def _populateMetadata(self, rel_path, metadata, mode=None):
-        metadata['config'] = self._makeConfig(rel_path, mode)
+    def _doCreateItemMetadata(self, path):
+        metadata = super()._doCreateItemMetadata(path)
+        config = metadata.setdefault('config', {})
+        config.update(self._makeConfig(path))
+        return config
 
-    def _makeConfig(self, rel_path, mode):
+    def _makeConfig(self, path):
         c = copy.deepcopy(self.config_recipe)
-        if c.get('title') == '%first_line%' and mode != MODE_CREATING:
-            path = os.path.join(self.fs_endpoint_path, rel_path)
-            try:
-                c['title'] = get_first_line(path)
-            except IOError:
-                if mode == MODE_PARSING:
-                    raise
+        if c.get('title') == '%first_line%':
+            c['title'] = get_first_line(path)
         return c