5 This plugin allows easy, variable length summaries directly embedded into the
9 from __future__ import unicode_literals
10 from bs4 import BeautifulSoup
11 from pelican import signals
12 from pelican.generators import ArticlesGenerator, StaticGenerator, PagesGenerator
15 def initialized(pelican):
16 from pelican.settings import DEFAULT_CONFIG
17 DEFAULT_CONFIG.setdefault('SUMMARY_BEGIN_MARKER',
18 '<!-- PELICAN_BEGIN_SUMMARY -->')
19 DEFAULT_CONFIG.setdefault('SUMMARY_END_MARKER',
20 '<!-- PELICAN_END_SUMMARY -->')
21 DEFAULT_CONFIG.setdefault('SUMMARY_USE_FIRST_PARAGRAPH', False)
23 pelican.settings.setdefault('SUMMARY_BEGIN_MARKER',
24 '<!-- PELICAN_BEGIN_SUMMARY -->')
25 pelican.settings.setdefault('SUMMARY_END_MARKER',
26 '<!-- PELICAN_END_SUMMARY -->')
27 pelican.settings.setdefault('SUMMARY_USE_FIRST_PARAGRAPH', False)
29 def extract_summary(instance):
30 # if summary is already specified, use it
31 # if there is no content, there's nothing to do
32 if hasattr(instance, '_summary') or 'summary' in instance.metadata:
33 instance.has_summary = True
36 if not instance._content:
37 instance.has_summary = False
40 begin_marker = instance.settings['SUMMARY_BEGIN_MARKER']
41 end_marker = instance.settings['SUMMARY_END_MARKER']
42 use_first_paragraph = instance.settings['SUMMARY_USE_FIRST_PARAGRAPH']
45 content = instance._update_content(instance._content, instance.settings['SITEURL'])
49 begin_summary = content.find(begin_marker)
51 end_summary = content.find(end_marker)
53 if begin_summary == -1 and end_summary == -1 and use_first_paragraph:
54 begin_marker, end_marker = '<p>', '</p>'
55 remove_markers = False
56 begin_summary = content.find(begin_marker)
57 end_summary = content.find(end_marker)
59 if begin_summary == -1 and end_summary == -1:
60 instance.has_summary = False
63 # skip over the begin marker, if present
64 if begin_summary == -1:
67 begin_summary = begin_summary + len(begin_marker)
72 summary = content[begin_summary:end_summary]
75 # remove the markers from the content
77 content = content.replace(begin_marker, '', 1)
79 content = content.replace(end_marker, '', 1)
81 summary = str(BeautifulSoup(summary, 'html.parser'))
83 instance._content = content
84 # default_status was added to Pelican Content objects after 3.7.1.
85 # Its use here is strictly to decide on how to set the summary.
86 # There's probably a better way to do this but I couldn't find it.
87 if hasattr(instance, 'default_status'):
88 instance.metadata['summary'] = summary
90 instance._summary = summary
91 instance.has_summary = True
94 def run_plugin(generators):
95 for generator in generators:
96 if isinstance(generator, ArticlesGenerator):
97 for article in generator.articles:
98 extract_summary(article)
99 elif isinstance(generator, PagesGenerator):
100 for page in generator.pages:
101 extract_summary(page)
105 signals.initialized.connect(initialized)
107 signals.all_generators_finalized.connect(run_plugin)
108 except AttributeError:
109 # NOTE: This results in #314 so shouldn't really be relied on
110 # https://github.com/getpelican/pelican-plugins/issues/314
111 signals.content_object_init.connect(extract_summary)