You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Now if in my template I do {{ item.blah|typogrify }}, it'll work perfectly. If I do the same with {{ item|typogrify }}, there's a template error.
This is the weird thing:
without the typogrify filter, the model's __unicode__() gets called
with the typogrify filter, the model's it doesn't
And when it doesn't get called, what happens is that the typogrify tags, instead of receiving the unicode that they expect, receive a model object that they naturally choke on.
So it seems to me that typogrify is somehow intercepting the contents of the template before Django is able to turn the {{ item }} into unicode, if that makes sense.
(Just to add to the complexity of this, the template belongs to a django CMS plugin, which has a habit of swallowing up errors and making them harder to debug.)
The text was updated successfully, but these errors were encountered:
Problem identified: {% autoescape off %} was the cause.
On the other hand, I do find that I need to turn off autoescaping all over the place in order to get typogrify to trigger. It's not really clear to me what is preventing it from doing so though.
I've used
{{ item|typogrify }}
without issue a billion times if not more, but today I discovered a problem that has me completely baffled.Here are two absolutely identical model methods:
Now if in my template I do
{{ item.blah|typogrify }}
, it'll work perfectly. If I do the same with{{ item|typogrify }}
, there's a template error.This is the weird thing:
typogrify
filter, the model's__unicode__()
gets calledtypogrify
filter, the model's it doesn'tAnd when it doesn't get called, what happens is that the typogrify tags, instead of receiving the unicode that they expect, receive a model object that they naturally choke on.
So it seems to me that typogrify is somehow intercepting the contents of the template before Django is able to turn the
{{ item }}
into unicode, if that makes sense.(Just to add to the complexity of this, the template belongs to a django CMS plugin, which has a habit of swallowing up errors and making them harder to debug.)
The text was updated successfully, but these errors were encountered: