X-Git-Url: https://git.openstreetmap.org./osqa.git/blobdiff_plain/bdc1f3f4e02e0d558bb80e70679d5e56172d32b9..6739afe99e21df2a3c4cf7768f967fcf72b4e514:/forum_modules/pgfulltext/handlers.py diff --git a/forum_modules/pgfulltext/handlers.py b/forum_modules/pgfulltext/handlers.py index c8b4e09..196790b 100644 --- a/forum_modules/pgfulltext/handlers.py +++ b/forum_modules/pgfulltext/handlers.py @@ -5,8 +5,9 @@ from forum.modules.decorators import decorate @decorate(QuestionManager.search, needs_origin=False) def question_search(self, keywords): - repl_re = re.compile(r'[^\'-_\s\w]') + repl_re = re.compile(r"[^\'\-_\s\w]", re.UNICODE) tsquery = " | ".join([k for k in repl_re.sub('', keywords).split(' ') if k]) + ilike = keywords + u"%%" return self.extra( tables = ['forum_rootnode_doc'], @@ -17,9 +18,9 @@ def question_search(self, keywords): }, where=[""" "forum_rootnode_doc"."node_id" = "forum_node"."id" AND ("forum_rootnode_doc"."document" @@ to_tsquery('english', %s) OR - "forum_node"."title" ILIKE '""" + keywords.replace("'",r"\'") + """%%') + "forum_node"."title" ILIKE %s) """], - params=[tsquery], + params=[tsquery, ilike], select_params=[tsquery], order_by=['-ranking'] )