diff --git a/CHANGES b/CHANGES index 029b9efcb..a9702cae5 100644 --- a/CHANGES +++ b/CHANGES @@ -29,6 +29,7 @@ Bugs fixed * #4574: vertical space before equation in latex * #4720: message when an image is mismatched for builder is not clear * #4655, #4684: Incomplete localization strings in Polish and Chinese +* #2286: Sphinx crashes when error is happens in rendering HTML pages Testing -------- diff --git a/sphinx/builders/html.py b/sphinx/builders/html.py index 183ffc017..fad49486b 100644 --- a/sphinx/builders/html.py +++ b/sphinx/builders/html.py @@ -35,8 +35,9 @@ from sphinx.deprecation import RemovedInSphinx20Warning from sphinx.environment.adapters.asset import ImageAdapter from sphinx.environment.adapters.indexentries import IndexEntries from sphinx.environment.adapters.toctree import TocTree +from sphinx.errors import ThemeError from sphinx.highlighting import PygmentsBridge -from sphinx.locale import _, l_ +from sphinx.locale import _, __, l_ from sphinx.search import js_index from sphinx.theming import HTMLThemeFactory from sphinx.util import jsonimpl, logging, status_iterator @@ -1016,6 +1017,9 @@ class StandaloneHTMLBuilder(Builder): "Please make sure all config values that contain " "non-ASCII content are Unicode strings.", pagename) return + except Exception as exc: + raise ThemeError(__("An error happened in rendering the page %s.\nReason: %r") % + (pagename, exc)) if not outfilename: outfilename = self.get_outfilename(pagename)