From 70f0882e275afad064fa2acf5ba5d00344f7bde4 Mon Sep 17 00:00:00 2001 From: Dmitri Bogomolov <4glitch@gmail.com> Date: Wed, 21 Feb 2018 19:13:18 +0200 Subject: [PATCH] This version of tr._translate is probably compatible with all Qt APIs --- src/tr.py | 38 ++++++++++++++++++++------------------ 1 file changed, 20 insertions(+), 18 deletions(-) diff --git a/src/tr.py b/src/tr.py index 8c5cda35..8a9f7f5b 100644 --- a/src/tr.py +++ b/src/tr.py @@ -1,21 +1,23 @@ +import os import shared - -def _translate(context, text, disambiguation=None, n=None): - return translateText(context, text, n) - - -def translateText(context, text, n=None): - try: - is_daemon = shared.thisapp.daemon - except AttributeError: # inside the plugin - is_daemon = False - if not is_daemon: - from qtpy import QtWidgets, QtCore - if n is None: - return QtWidgets.QApplication.translate(context, text) - else: - return QtWidgets.QApplication.translate( - context, text, None, QtCore.QCoreApplication.CodecForTr, n) - else: +try: + _daemon = shared.thisapp.daemon +except AttributeError: # inside the plugin + _daemon = False +if _daemon: + def _translate(context, text, disambiguation=None, n=None): return text +else: + from qtpy import QtWidgets, QtCore + if os.environ['QT_API'] == 'pyqt5': + _translate = QtWidgets.QApplication.translate + else: + def _translate(context, text, disambiguation=None, n=None): + return ( + QtWidgets.QApplication.translate(context, text, disambiguation) + if n is None else + QtWidgets.QApplication.translate( + context, text, disambiguation, + QtCore.QCoreApplication.CodecForTr, n) + )