Skip to content

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Browse files

Fixed #22412 -- More nuanced advice re template filters and exceptions.

Thanks Tim for review.
  • Loading branch information...
commit 7e3834adc993317bc691cc6edc0be13538dc39ad 1 parent 59b1d30
Carl Meyer carljm authored
Showing with 5 additions and 3 deletions.
  1. +5 −3 docs/howto/custom-template-tags.txt
8 docs/howto/custom-template-tags.txt
View
@@ -88,9 +88,11 @@ Custom filters are just Python functions that take one or two arguments:
For example, in the filter ``{{ var|foo:"bar" }}``, the filter ``foo`` would be
passed the variable ``var`` and the argument ``"bar"``.
-Filter functions should always return something. They shouldn't raise
-exceptions. They should fail silently. In case of error, they should return
-either the original input or an empty string -- whichever makes more sense.
+Usually any exception raised from a template filter will be exposed as a server
+error. Thus, filter functions should avoid raising exceptions if there is a
+reasonable fallback value to return. In case of input that represents a clear
+bug in a template, raising an exception may still be better than silent failure
+which hides the bug.
Here's an example filter definition:
Please sign in to comment.
Something went wrong with that request. Please try again.