From 55c9e98d86e717a3da832fc309947d70a68ffdb0 Mon Sep 17 00:00:00 2001 From: Adrian Holovaty Date: Mon, 15 May 2006 04:24:48 +0000 Subject: [PATCH] Fixed #1852 -- Improved TemplateSyntaxError to display the original exception if str() of the exception raises an exception in itself. Thanks, nnorwitz@google.com git-svn-id: http://code.djangoproject.com/svn/django/trunk@2906 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- AUTHORS | 1 + django/template/__init__.py | 15 ++++++++++++++- 2 files changed, 15 insertions(+), 1 deletion(-) diff --git a/AUTHORS b/AUTHORS index 5864c7107f..6c1a9070fe 100644 --- a/AUTHORS +++ b/AUTHORS @@ -88,6 +88,7 @@ answer newbie questions, and generally made Django that much better: Robin Munn Nebojša Dorđević Sam Newman + Neal Norwitz oggie rob pgross@thoughtworks.com phaedo diff --git a/django/template/__init__.py b/django/template/__init__.py index e32200cccb..18dceff45c 100644 --- a/django/template/__init__.py +++ b/django/template/__init__.py @@ -91,7 +91,20 @@ libraries = {} builtins = [] class TemplateSyntaxError(Exception): - pass + def __str__(self): + try: + import cStringIO as StringIO + except ImportError: + import StringIO + output = StringIO.StringIO() + output.write(Exception.__str__(self)) + # Check if we wrapped an exception and print that too. + if hasattr(self, 'exc_info'): + import traceback + output.write('\n\nOriginal ') + e = self.exc_info + traceback.print_exception(e[0], e[1], e[2], 500, output) + return output.getvalue() class TemplateDoesNotExist(Exception): pass