summaryrefslogtreecommitdiff
path: root/searx
diff options
context:
space:
mode:
authorCqoicebordel <Cqoicebordel@users.noreply.github.com>2015-01-03 02:31:23 +0100
committerCqoicebordel <Cqoicebordel@users.noreply.github.com>2015-01-03 02:31:23 +0100
commit96c4d52eef7de13f6fa1d6e0ae651c50c3bba515 (patch)
treee85fea57da855c1a558559e1124f163837fb5da8 /searx
parent7b531c6fcefe1c0c5cc19967454cdddb6e1c8fbd (diff)
downloadsearxng-96c4d52eef7de13f6fa1d6e0ae651c50c3bba515.tar.gz
searxng-96c4d52eef7de13f6fa1d6e0ae651c50c3bba515.zip
Add non exclusif bang
Allow to perform a search while adding an engine (or a category) without adding it "officially" to the request. '?' is used to add an engine without modifying anything else to the request. For example, you can perform a search in the 'general' category, and if you add '?tw' the result from Twitter will be added to the originals results.
Diffstat (limited to 'searx')
-rw-r--r--searx/query.py6
-rw-r--r--searx/search.py2
2 files changed, 6 insertions, 2 deletions
diff --git a/searx/query.py b/searx/query.py
index 9f711e982..a10a886ff 100644
--- a/searx/query.py
+++ b/searx/query.py
@@ -38,6 +38,7 @@ class Query(object):
self.query_parts = []
self.engines = []
self.languages = []
+ self.specific = False
# parse query, if tags are set, which
# change the serch engine or search-language
@@ -83,7 +84,7 @@ class Query(object):
break
# this force a engine or category
- if query_part[0] == '!':
+ if query_part[0] == '!' or query_part[0] == '?':
prefix = query_part[1:].replace('_', ' ')
# check if prefix is equal with engine shortcut
@@ -110,6 +111,9 @@ class Query(object):
for engine in categories[prefix]
if engine not in self.blocked_engines)
+ if query_part[0] == '!':
+ self.specific = True
+
# append query part to query_part list
self.query_parts.append(query_part)
diff --git a/searx/search.py b/searx/search.py
index fbbf3fe41..1c8b22f93 100644
--- a/searx/search.py
+++ b/searx/search.py
@@ -371,7 +371,7 @@ class Search(object):
# if engines are calculated from query,
# set categories by using that informations
- if self.engines:
+ if self.engines and query_obj.specific:
self.categories = list(set(engine['category']
for engine in self.engines))