summaryrefslogtreecommitdiff
path: root/searx/query.py
diff options
context:
space:
mode:
authorJohannes 'josch' Schauer <josch@debian.org>2020-07-14 16:26:13 +0200
committerJohannes 'josch' Schauer <josch@debian.org>2020-07-14 16:26:13 +0200
commit075e7e02683d9db1b303de8e8c17ff7da4c62510 (patch)
tree72d3ed7514879810445f4309e641e29d9c57d02d /searx/query.py
parent61b98ca52e8d48a6ad3b4baed5feb4b38ee53804 (diff)
New upstream version 0.17.0+dfsg1
Diffstat (limited to 'searx/query.py')
-rw-r--r--searx/query.py13
1 files changed, 11 insertions, 2 deletions
diff --git a/searx/query.py b/searx/query.py
index c4002bd..e8b57d4 100644
--- a/searx/query.py
+++ b/searx/query.py
@@ -44,10 +44,11 @@ class RawTextQuery(object):
self.engines = []
self.languages = []
self.timeout_limit = None
+ self.external_bang = None
self.specific = False
# parse query, if tags are set, which
- # change the serch engine or search-language
+ # change the search engine or search-language
def parse_query(self):
self.query_parts = []
@@ -120,6 +121,11 @@ class RawTextQuery(object):
self.languages.append(lang)
parse_next = True
+ # external bang
+ if query_part[0:2] == "!!":
+ self.external_bang = query_part[2:]
+ parse_next = True
+ continue
# this force a engine or category
if query_part[0] == '!' or query_part[0] == '?':
prefix = query_part[1:].replace('-', ' ').replace('_', ' ')
@@ -177,7 +183,8 @@ class RawTextQuery(object):
class SearchQuery(object):
"""container for all the search parameters (query, language, etc...)"""
- def __init__(self, query, engines, categories, lang, safesearch, pageno, time_range, timeout_limit=None):
+ def __init__(self, query, engines, categories, lang, safesearch, pageno, time_range,
+ timeout_limit=None, preferences=None, external_bang=None):
self.query = query.encode('utf-8')
self.engines = engines
self.categories = categories
@@ -186,6 +193,8 @@ class SearchQuery(object):
self.pageno = pageno
self.time_range = None if time_range in ('', 'None', None) else time_range
self.timeout_limit = timeout_limit
+ self.preferences = preferences
+ self.external_bang = external_bang
def __str__(self):
return str(self.query) + ";" + str(self.engines)