Mercurial > piecrust2
view piecrust/sources/interfaces.py @ 852:4850f8c21b6e
core: Start of the big refactor for PieCrust 3.0.
* Everything is a `ContentSource`, including assets directories.
* Most content sources are subclasses of the base file-system source.
* A source is processed by a "pipeline", and there are 2 built-in pipelines,
one for assets and one for pages. The asset pipeline is vaguely functional,
but the page pipeline is completely broken right now.
* Rewrite the baking process as just running appropriate pipelines on each
content item. This should allow for better parallelization.
author | Ludovic Chabant <ludovic@chabant.com> |
---|---|
date | Wed, 17 May 2017 00:11:48 -0700 |
parents | 0c74a6c4533d |
children | f070a4fc033c |
line wrap: on
line source
class IPaginationSource(object): """ Defines the interface for a source that can be used as the data for an iterator or a pagination. """ def getItemsPerPage(self): raise NotImplementedError() def getSourceIterator(self): raise NotImplementedError() def getSorterIterator(self, it): raise NotImplementedError() def getTailIterator(self, it): raise NotImplementedError() def getSettingAccessor(self): raise NotImplementedError() class IPreparingSource(object): """ Defines the interface for a source whose pages can be created by the `chef prepare` command. """ def setupPrepareParser(self, parser, app): raise NotImplementedError() def createContent(self, args): raise NotImplementedError() class InteractiveField(object): """ A field to display in the administration web UI. """ TYPE_STRING = 0 TYPE_INT = 1 def __init__(self, name, field_type, default_value): self.name = name self.field_type = field_type self.default_value = default_value class IInteractiveSource(object): """ A content source that a user can interact with in the administration web UI. """ def getInteractiveFields(self): raise NotImplementedError()