Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add skip status to ignore selected posts #3305

Merged
merged 4 commits into from
Sep 12, 2024
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions RELEASE.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
Release type: minor

Documents with the "skip" status are ignored and not rendered to output.
9 changes: 8 additions & 1 deletion docs/content.rst
Original file line number Diff line number Diff line change
Expand Up @@ -89,7 +89,7 @@ contains a list of reserved metadata keywords:
``summary`` Brief description of content for index pages
``lang`` Content language ID (``en``, ``fr``, etc.)
``translation`` If content is a translation of another (``true`` or ``false``)
``status`` Content status: ``draft``, ``hidden``, or ``published``
``status`` Content status: ``draft``, ``hidden``, ``skip``, or ``published``
``template`` Name of template to use to generate content (without extension)
``save_as`` Save content to this relative file path
``url`` URL to use for this article/page
Expand Down Expand Up @@ -633,6 +633,13 @@ attribute. Hidden posts will be output to ``ARTICLE_SAVE_AS`` as expected, but
are not included by default in tag, category, and author indexes, nor in the
main article feed. This has the effect of creating an "unlisted" post.

Skipped Posts
==============

Posts marked with the ``skip`` status are ignored entirely. They are not
processed, and not output to the ``ARTICLE_SAVE_AS`` path. These posts will
also not be included in indexes or feeds.

.. _W3C ISO 8601: https://www.w3.org/TR/NOTE-datetime
.. _AsciiDoc: https://asciidoc.org
.. _Pelican Plugins: https://github.com/pelican-plugins
Expand Down
24 changes: 22 additions & 2 deletions pelican/contents.py
Original file line number Diff line number Diff line change
Expand Up @@ -547,9 +547,29 @@ def refresh_metadata_intersite_links(self) -> None:
self._summary = self.metadata["summary"]


class SkipStub(Content):
# Stub class representing content that should not be processed in any way
justinmayer marked this conversation as resolved.
Show resolved Hide resolved

def __init__(
self, content, metadata=None, settings=None, source_path=None, context=None
):
self.source_path = source_path

def is_valid(self):
return False

@property
def content(self):
raise NotImplementedError("Stub content should not be read")

@property
def save_as(self):
raise NotImplementedError("Stub content cannot be saved")


class Page(Content):
mandatory_properties = ("title",)
allowed_statuses = ("published", "hidden", "draft")
allowed_statuses = ("published", "hidden", "draft", "skip")
default_status = "published"
default_template = "page"

Expand All @@ -560,7 +580,7 @@ def _expand_settings(self, key: str) -> str:

class Article(Content):
mandatory_properties = ("title", "date", "category")
allowed_statuses = ("published", "hidden", "draft")
allowed_statuses = ("published", "hidden", "draft", "skip")
default_status = "published"
default_template = "article"

Expand Down
15 changes: 14 additions & 1 deletion pelican/generators.py
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@
)

from pelican.cache import FileStampDataCacher
from pelican.contents import Article, Page, Static
from pelican.contents import Article, Page, SkipStub, Static
from pelican.plugins import signals
from pelican.plugins._utils import plugin_enabled
from pelican.readers import Readers
Expand Down Expand Up @@ -690,6 +690,10 @@ def generate_context(self):
self._add_failed_source_path(f)
continue

if isinstance(article, SkipStub):
logger.debug("Safely skipping %s", f)
continue

if not article.is_valid():
self._add_failed_source_path(f)
continue
Expand All @@ -702,6 +706,8 @@ def generate_context(self):
all_drafts.append(article)
elif article.status == "hidden":
hidden_articles.append(article)
elif article.status == "skip":
raise AssertionError("Documents with 'skip' status should be skipped")

self.add_source_path(article)
self.add_static_links(article)
Expand Down Expand Up @@ -899,6 +905,10 @@ def generate_context(self):
self._add_failed_source_path(f)
continue

if isinstance(page, SkipStub):
logger.debug("Safely skipping %s", f)
continue

if not page.is_valid():
self._add_failed_source_path(f)
continue
Expand All @@ -911,6 +921,9 @@ def generate_context(self):
hidden_pages.append(page)
elif page.status == "draft":
draft_pages.append(page)
elif page.status == "skip":
raise AssertionError("Documents with 'skip' status should be skipped")

self.add_source_path(page)
self.add_static_links(page)

Expand Down
5 changes: 4 additions & 1 deletion pelican/readers.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@

from pelican import rstdirectives # NOQA
from pelican.cache import FileStampDataCacher
from pelican.contents import Author, Category, Page, Tag
from pelican.contents import Author, Category, Page, SkipStub, Tag
from pelican.plugins import signals
from pelican.utils import file_suffix, get_date, pelican_open, posixize_path

Expand Down Expand Up @@ -669,6 +669,9 @@ def typogrify_wrapper(text):
)
context_signal.send(context_sender, metadata=metadata)

if metadata.get("status") == "skip":
content_class = SkipStub

return content_class(
content=content,
metadata=metadata,
Expand Down
5 changes: 5 additions & 0 deletions pelican/tests/content/article_skip.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
Title: Skipped article
Date: 2024-06-30
Status: skip

This content will not be rendered.
5 changes: 3 additions & 2 deletions pelican/tests/test_cache.py
Original file line number Diff line number Diff line change
Expand Up @@ -183,15 +183,16 @@ def test_article_object_caching(self):
generator.readers.read_file = MagicMock()
generator.generate_context()
"""
6 files don't get cached because they were not valid
7 files don't get cached because they were not valid
- article_with_attributes_containing_double_quotes.html
- article_with_comments.html
- article_with_null_attributes.html
- 2012-11-30_md_w_filename_meta#foo-bar.md
- empty.md
- empty_with_bom.md
- article_skip.md
"""
self.assertEqual(generator.readers.read_file.call_count, 6)
self.assertEqual(generator.readers.read_file.call_count, 7)

def test_article_reader_content_caching(self):
"""Test raw article content caching at the reader level"""
Expand Down