From 9079d0cac0156139952446f0fdc8b37b94c10756 Mon Sep 17 00:00:00 2001 From: Bnyro Date: Tue, 15 Oct 2024 15:39:14 +0200 Subject: [refactor] translation engines: common interface --- searx/engines/mozhi.py | 24 ++++++++++-------------- 1 file changed, 10 insertions(+), 14 deletions(-) (limited to 'searx/engines/mozhi.py') diff --git a/searx/engines/mozhi.py b/searx/engines/mozhi.py index 63c90084e..a36bfbec8 100644 --- a/searx/engines/mozhi.py +++ b/searx/engines/mozhi.py @@ -4,7 +4,6 @@ import random import re from urllib.parse import urlencode -from flask_babel import gettext about = { "website": 'https://codeberg.org/aryak/mozhi', @@ -35,30 +34,27 @@ def request(_query, params): def response(resp): translation = resp.json() - infobox = "" + data = {'text': translation['translated-text'], 'definitions': [], 'examples': []} if translation['target_transliteration'] and not re.match( re_transliteration_unsupported, translation['target_transliteration'] ): - infobox = f"{translation['target_transliteration']}" + data['transliteration'] = translation['target_transliteration'] if translation['word_choices']: for word in translation['word_choices']: - infobox += f"
{word['word']}: {word['definition']}
" + if word.get('definition'): + data['definitions'].append(word['definition']) - if word['examples_target']: - for example in word['examples_target']: - infobox += f"
{re.sub(r'<|>', '', example)}
" - infobox += f"
{re.sub(r'<|>', '', example)}
" + for example in word.get('examples_target', []): + data['examples'].append(re.sub(r"<|>", "", example).lstrip('- ')) - infobox += "
" - - if translation['source_synonyms']: - infobox += f"
{gettext('Synonyms')}: {', '.join(translation['source_synonyms'])}
" + data['synonyms'] = translation.get('source_synonyms', []) result = { - 'infobox': translation['translated-text'], - 'content': infobox, + 'answer': translation['translated-text'], + 'answer_type': 'translations', + 'translations': [data], } return [result] -- cgit v1.2.3