Mercurial > public > sg101
view smiley/utils.py @ 943:cf9918328c64
Haystack tweaks for Django 1.7.7.
I had to upgrade to Haystack 2.3.1 to get it to work with Django
1.7.7. I also had to update the Xapian backend. But I ran into
problems.
On my laptop anyway (Ubuntu 14.0.4), xapian gets mad when search terms
are greater than 245 chars (or something) when indexing. So I created
a custom field that would simply omit terms greater than 64 chars and
used this field everywhere I previously used a CharField.
Secondly, the custom search form was broken now. Something changed in
the Xapian backend and exact searches stopped working. Fortunately the
auto_query (which I was using originally and broke during an upgrade)
started working again. So I cut the search form back over to doing an
auto_query. I kept the form the same (3 fields) because I didn't want
to change the form and I think it's better that way.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Wed, 13 May 2015 20:25:07 -0500 |
parents | 98d2388b6bb2 |
children |
line wrap: on
line source
""" Smiley classes and functions. """ from django.utils.safestring import SafeData from django.utils.html import conditional_escape from models import Smiley class SmilifyHtml(object): """ A class to "smilify" text by replacing text with HTML img tags for smiley images. """ def __init__(self): self.map = Smiley.objects.get_smiley_map() def convert(self, value, autoescape=False): """ Converts and returns the supplied text with the HTML version of the smileys. """ if not value: return u'' if not autoescape or isinstance(value, SafeData): esc = lambda x: x else: esc = conditional_escape words = value.split() for i, word in enumerate(words): if word in self.map: words[i] = self.map[word] else: words[i] = esc(words[i]) return u' '.join(words) class SmilifyMarkdown(object): """ A class to "smilify" text by replacing text with Markdown image syntax for smiley images. """ def __init__(self, relative_urls=True): self.regexes = Smiley.objects.get_smiley_regexes( relative_urls=relative_urls) def convert(self, s): """ Returns a string copy of the input s that has the smiley codes replaced with Markdown for smiley images. """ if not s: return u'' for regex, repl in self.regexes: s = regex.sub(repl, s) return s def smilify_html(value, autoescape=False): """ A convenience function to "smilify" text by replacing text with HTML img tags of smilies. """ s = SmilifyHtml() return s.convert(value, autoescape=autoescape)