In the past, some files were tested with the standard profile, others with a profile in which most of the messages were switched off ... some files were not checked at all. - ``PYLINT_SEARXNG_DISABLE_OPTION`` has been abolished - the distinction ``# lint: pylint`` is no longer necessary - the pylint tasks have been reduced from three to two 1. ./searx/engines -> lint engines with additional builtins 2. ./searx ./searxng_extra ./tests -> lint all other python files Signed-off-by: Markus Heiser <markus.heiser@darmarit.de>
		
			
				
	
	
		
			61 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			61 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
# SPDX-License-Identifier: AGPL-3.0-or-later
 | 
						|
"""Processors for engine-type: ``online_dictionary``
 | 
						|
 | 
						|
"""
 | 
						|
 | 
						|
import re
 | 
						|
 | 
						|
from searx.utils import is_valid_lang
 | 
						|
from .online import OnlineProcessor
 | 
						|
 | 
						|
parser_re = re.compile('.*?([a-z]+)-([a-z]+) (.+)$', re.I)
 | 
						|
 | 
						|
 | 
						|
class OnlineDictionaryProcessor(OnlineProcessor):
 | 
						|
    """Processor class used by ``online_dictionary`` engines."""
 | 
						|
 | 
						|
    engine_type = 'online_dictionary'
 | 
						|
 | 
						|
    def get_params(self, search_query, engine_category):
 | 
						|
        """Returns a set of :ref:`request params <engine request online_dictionary>` or
 | 
						|
        ``None`` if search query does not match to :py:obj:`parser_re`.
 | 
						|
        """
 | 
						|
        params = super().get_params(search_query, engine_category)
 | 
						|
        if params is None:
 | 
						|
            return None
 | 
						|
 | 
						|
        m = parser_re.match(search_query.query)
 | 
						|
        if not m:
 | 
						|
            return None
 | 
						|
 | 
						|
        from_lang, to_lang, query = m.groups()
 | 
						|
 | 
						|
        from_lang = is_valid_lang(from_lang)
 | 
						|
        to_lang = is_valid_lang(to_lang)
 | 
						|
 | 
						|
        if not from_lang or not to_lang:
 | 
						|
            return None
 | 
						|
 | 
						|
        params['from_lang'] = from_lang
 | 
						|
        params['to_lang'] = to_lang
 | 
						|
        params['query'] = query
 | 
						|
 | 
						|
        return params
 | 
						|
 | 
						|
    def get_default_tests(self):
 | 
						|
        tests = {}
 | 
						|
 | 
						|
        if getattr(self.engine, 'paging', False):
 | 
						|
            tests['translation_paging'] = {
 | 
						|
                'matrix': {'query': 'en-es house', 'pageno': (1, 2, 3)},
 | 
						|
                'result_container': ['not_empty', ('one_title_contains', 'house')],
 | 
						|
                'test': ['unique_results'],
 | 
						|
            }
 | 
						|
        else:
 | 
						|
            tests['translation'] = {
 | 
						|
                'matrix': {'query': 'en-es house'},
 | 
						|
                'result_container': ['not_empty', ('one_title_contains', 'house')],
 | 
						|
            }
 | 
						|
 | 
						|
        return tests
 |