diff options
| author | Ned Batchelder <ned@nedbatchelder.com> | 2009-11-21 08:31:47 -0500 |
|---|---|---|
| committer | Ned Batchelder <ned@nedbatchelder.com> | 2009-11-21 08:31:47 -0500 |
| commit | 6497a1f7a5d19ee31a6d7fb8552d308544980e2a (patch) | |
| tree | 892fdcd0f6fd73c3d877126ac79be4c1c86ee9ff /coverage | |
| parent | 4e7ebf2419893348dee1c38b2c33cafe5a92d23a (diff) | |
| download | python-coveragepy-6497a1f7a5d19ee31a6d7fb8552d308544980e2a.tar.gz | |
Add nicer exception reporting inside Templite so when a template goes wrong we have some hope of figuring out why.
Diffstat (limited to 'coverage')
| -rw-r--r-- | coverage/templite.py | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/coverage/templite.py b/coverage/templite.py index f61fbdc..22c93a9 100644 --- a/coverage/templite.py +++ b/coverage/templite.py @@ -2,7 +2,7 @@ # Coincidentally named the same as http://code.activestate.com/recipes/496702/ -import re +import re, sys class Templite(object): """A simple template renderer, for a nano-subset of Django syntax. @@ -120,7 +120,13 @@ class _TempliteEngine(object): if op == 'lit': self.result += args elif op == 'exp': - self.result += str(self.evaluate(args)) + try: + self.result += str(self.evaluate(args)) + except: + exc_class, exc, tb = sys.exc_info() + new_exc = exc_class("Couldn't evaluate {{ %s }}: %s" + % (args, exc)) + raise exc_class, new_exc, tb elif op == 'if': expr, body = args if self.evaluate(expr): |
