Fix rest of mypy errors
- This allows us to run mypy on the full gajim folder
This commit is contained in:
		
							parent
							
								
									fafef38f2c
								
							
						
					
					
						commit
						9bbc2eceb3
					
				
					 20 changed files with 123 additions and 50 deletions
				
			
		|  | @ -17,6 +17,9 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
|  | from typing import List  # pylint: disable=unused-import | ||||||
|  | from typing import Any  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
| from gi.repository import Gdk | from gi.repository import Gdk | ||||||
| from gi.repository import GLib | from gi.repository import GLib | ||||||
| 
 | 
 | ||||||
|  | @ -26,7 +29,7 @@ from gajim.common import i18n | ||||||
| 
 | 
 | ||||||
| class AtomWindow: | class AtomWindow: | ||||||
|     window = None |     window = None | ||||||
|     entries = [] |     entries = []  # type: List[Any] | ||||||
| 
 | 
 | ||||||
|     @classmethod |     @classmethod | ||||||
|     def newAtomEntry(cls, entry): |     def newAtomEntry(cls, entry): | ||||||
|  |  | ||||||
|  | @ -23,12 +23,21 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
|  | from typing import ClassVar  # pylint: disable=unused-import | ||||||
|  | from typing import Type  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
| import os | import os | ||||||
| import time | import time | ||||||
|  | 
 | ||||||
| from gi.repository import Gtk | from gi.repository import Gtk | ||||||
| from gi.repository import Gio | from gi.repository import Gio | ||||||
| from gi.repository import Pango | from gi.repository import Pango | ||||||
| from gi.repository import GLib | from gi.repository import GLib | ||||||
|  | from nbxmpp.protocol import NS_XHTML, NS_XHTML_IM, NS_FILE, NS_MUC | ||||||
|  | from nbxmpp.protocol import NS_JINGLE_RTP_AUDIO, NS_JINGLE_RTP_VIDEO | ||||||
|  | from nbxmpp.protocol import NS_JINGLE_ICE_UDP, NS_JINGLE_FILE_TRANSFER_5 | ||||||
|  | from nbxmpp.protocol import NS_CHATSTATES | ||||||
|  | 
 | ||||||
| from gajim import gtkgui_helpers | from gajim import gtkgui_helpers | ||||||
| from gajim import gui_menu_builder | from gajim import gui_menu_builder | ||||||
| from gajim import message_control | from gajim import message_control | ||||||
|  | @ -41,14 +50,11 @@ from gajim.common import helpers | ||||||
| from gajim.common import ged | from gajim.common import ged | ||||||
| from gajim.common import i18n | from gajim.common import i18n | ||||||
| from gajim.common.contacts import GC_Contact | from gajim.common.contacts import GC_Contact | ||||||
| from nbxmpp.protocol import NS_XHTML, NS_XHTML_IM, NS_FILE, NS_MUC |  | ||||||
| from nbxmpp.protocol import NS_JINGLE_RTP_AUDIO, NS_JINGLE_RTP_VIDEO |  | ||||||
| from nbxmpp.protocol import NS_JINGLE_ICE_UDP, NS_JINGLE_FILE_TRANSFER_5 |  | ||||||
| from nbxmpp.protocol import NS_CHATSTATES |  | ||||||
| from gajim.common.connection_handlers_events import MessageOutgoingEvent | from gajim.common.connection_handlers_events import MessageOutgoingEvent | ||||||
| from gajim.common.const import AvatarSize, KindConstant | from gajim.common.const import AvatarSize, KindConstant | ||||||
| 
 | 
 | ||||||
| from gajim.command_system.implementation.hosts import ChatCommands | from gajim.command_system.implementation.hosts import ChatCommands | ||||||
|  | from gajim.command_system.framework import CommandHost  # pylint: disable=unused-import | ||||||
| from gajim.chat_control_base import ChatControlBase | from gajim.chat_control_base import ChatControlBase | ||||||
| 
 | 
 | ||||||
| ################################################################################ | ################################################################################ | ||||||
|  | @ -69,7 +75,7 @@ class ChatControl(ChatControlBase): | ||||||
| 
 | 
 | ||||||
|     # Set a command host to bound to. Every command given through a chat will be |     # Set a command host to bound to. Every command given through a chat will be | ||||||
|     # processed with this command host. |     # processed with this command host. | ||||||
|     COMMAND_HOST = ChatCommands |     COMMAND_HOST = ChatCommands  # type: ClassVar[Type[CommandHost]] | ||||||
| 
 | 
 | ||||||
|     def __init__(self, parent_win, contact, acct, session, resource=None): |     def __init__(self, parent_win, contact, acct, session, resource=None): | ||||||
|         ChatControlBase.__init__(self, self.TYPE_ID, parent_win, |         ChatControlBase.__init__(self, self.TYPE_ID, parent_win, | ||||||
|  |  | ||||||
|  | @ -24,8 +24,11 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
|  | from typing import Any  # pylint: disable=unused-import | ||||||
| from typing import Dict  # pylint: disable=unused-import | from typing import Dict  # pylint: disable=unused-import | ||||||
| from typing import List  # pylint: disable=unused-import | from typing import List  # pylint: disable=unused-import | ||||||
|  | from typing import Optional  # pylint: disable=unused-import | ||||||
|  | from typing import cast | ||||||
| 
 | 
 | ||||||
| import os | import os | ||||||
| import sys | import sys | ||||||
|  | @ -44,21 +47,25 @@ from gajim.common import ged as ged_module | ||||||
| from gajim.common.contacts import LegacyContactsAPI | from gajim.common.contacts import LegacyContactsAPI | ||||||
| from gajim.common.events import Events | from gajim.common.events import Events | ||||||
| from gajim.common.css_config import CSSConfig | from gajim.common.css_config import CSSConfig | ||||||
|  | from gajim.common.types import NetworkEventsControllerT  # pylint: disable=unused-import | ||||||
|  | from gajim.common.types import InterfaceT  # pylint: disable=unused-import | ||||||
|  | from gajim.common.types import LoggerT  # pylint: disable=unused-import | ||||||
|  | from gajim.common.types import ConnectionT  # pylint: disable=unused-import | ||||||
| 
 | 
 | ||||||
| interface = None  # type: gajim.interface.Interface | interface = cast(InterfaceT, None) | ||||||
| thread_interface = lambda *args: None # Interface to run a thread and then a callback | thread_interface = lambda *args: None # Interface to run a thread and then a callback | ||||||
| config = c_config.Config() | config = c_config.Config() | ||||||
| version = gajim.__version__ | version = gajim.__version__ | ||||||
| connections = {} # 'account name': 'account (connection.Connection) instance' | connections = {}  # type: Dict[str, ConnectionT] | ||||||
| avatar_cache = {} | avatar_cache = {}  # type: Dict[str, Dict[str, Any]] | ||||||
| ipython_window = None | ipython_window = None | ||||||
| app = None  # Gtk.Application | app = None  # Gtk.Application | ||||||
| 
 | 
 | ||||||
| ged = ged_module.GlobalEventsDispatcher() # Global Events Dispatcher | ged = ged_module.GlobalEventsDispatcher() # Global Events Dispatcher | ||||||
| nec = None  # type: gajim.common.nec.NetworkEventsController | nec = cast(NetworkEventsControllerT, None) | ||||||
| plugin_manager = None # Plugins Manager | plugin_manager = None # Plugins Manager | ||||||
| 
 | 
 | ||||||
| logger = None  # type: gajim.common.logger.Logger | logger = cast(LoggerT, None) | ||||||
| 
 | 
 | ||||||
| # For backwards compatibility needed | # For backwards compatibility needed | ||||||
| # some plugins use that | # some plugins use that | ||||||
|  | @ -113,7 +120,7 @@ nicks = {}  # type: Dict[str, str] | ||||||
| # to something else than offline | # to something else than offline | ||||||
| # can also contain account/transport_jid to block notifications for contacts | # can also contain account/transport_jid to block notifications for contacts | ||||||
| # from this transport | # from this transport | ||||||
| block_signed_in_notifications = {} | block_signed_in_notifications = {}  # type: Dict[str, bool] | ||||||
| 
 | 
 | ||||||
|  # type of each connection (ssl, tls, tcp, ...) |  # type of each connection (ssl, tls, tcp, ...) | ||||||
| con_types = {}  # type: Dict[str, Optional[str]] | con_types = {}  # type: Dict[str, Optional[str]] | ||||||
|  | @ -153,10 +160,10 @@ gajim_common_features = [nbxmpp.NS_BYTESTREAM, nbxmpp.NS_SI, nbxmpp.NS_FILE, | ||||||
|     nbxmpp.NS_EME, 'urn:xmpp:avatar:metadata+notify'] |     nbxmpp.NS_EME, 'urn:xmpp:avatar:metadata+notify'] | ||||||
| 
 | 
 | ||||||
| # Optional features gajim supports per account | # Optional features gajim supports per account | ||||||
| gajim_optional_features = {} | gajim_optional_features = {}  # type: Dict[str, List[str]] | ||||||
| 
 | 
 | ||||||
| # Capabilities hash per account | # Capabilities hash per account | ||||||
| caps_hash = {} | caps_hash = {}  # type: Dict[str, List[str]] | ||||||
| 
 | 
 | ||||||
| _dependencies = { | _dependencies = { | ||||||
|     'PYTHON-DBUS': False, |     'PYTHON-DBUS': False, | ||||||
|  |  | ||||||
|  | @ -27,6 +27,11 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
|  | from typing import Any  # pylint: disable=unused-import | ||||||
|  | from typing import Dict  # pylint: disable=unused-import | ||||||
|  | from typing import List  # pylint: disable=unused-import | ||||||
|  | from typing import Tuple  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
| import re | import re | ||||||
| from enum import IntEnum, unique | from enum import IntEnum, unique | ||||||
| 
 | 
 | ||||||
|  | @ -287,7 +292,7 @@ class Config: | ||||||
|         'use_keyring': [opt_bool, True, _('If true, Gajim will use the Systems Keyring to store account passwords.')], |         'use_keyring': [opt_bool, True, _('If true, Gajim will use the Systems Keyring to store account passwords.')], | ||||||
|         'pgp_encoding': [opt_str, '', _('Sets the encoding used by python-gnupg'), True], |         'pgp_encoding': [opt_str, '', _('Sets the encoding used by python-gnupg'), True], | ||||||
|         'remote_commands': [opt_bool, False, _('If true, Gajim will execute XEP-0146 Commands.')], |         'remote_commands': [opt_bool, False, _('If true, Gajim will execute XEP-0146 Commands.')], | ||||||
|     }, {}) |     }, {})  # type: Tuple[Dict[str, List[Any]], Dict[Any, Any]] | ||||||
| 
 | 
 | ||||||
|     __options_per_key = { |     __options_per_key = { | ||||||
|         'accounts': ({ |         'accounts': ({ | ||||||
|  | @ -436,7 +441,7 @@ class Config: | ||||||
|         'plugins': ({ |         'plugins': ({ | ||||||
|             'active': [opt_bool, False, _('State whether plugins should be activated on startup (this is saved on Gajim exit). This option SHOULD NOT be used to (de)activate plug-ins. Use GUI instead.')], |             'active': [opt_bool, False, _('State whether plugins should be activated on startup (this is saved on Gajim exit). This option SHOULD NOT be used to (de)activate plug-ins. Use GUI instead.')], | ||||||
|         }, {}), |         }, {}), | ||||||
|     } |     }  # type: Dict[str, Tuple[Dict[str, List[Any]], Dict[Any, Any]]] | ||||||
| 
 | 
 | ||||||
|     statusmsg_default = { |     statusmsg_default = { | ||||||
|         _('Sleeping'): ['ZZZZzzzzzZZZZZ', 'inactive', 'sleeping', '', 'sleepy', ''], |         _('Sleeping'): ['ZZZZzzzzzZZZZZ', 'inactive', 'sleeping', '', 'sleepy', ''], | ||||||
|  |  | ||||||
|  | @ -4,10 +4,10 @@ from collections import namedtuple | ||||||
| from gajim.common.i18n import _ | from gajim.common.i18n import _ | ||||||
| 
 | 
 | ||||||
| Option = namedtuple('Option', 'kind label type value name callback data desc enabledif props') | Option = namedtuple('Option', 'kind label type value name callback data desc enabledif props') | ||||||
| Option.__new__.__defaults__ = (None,) * len(Option._fields) | Option.__new__.__defaults__ = (None,) * len(Option._fields)  # type: ignore | ||||||
| 
 | 
 | ||||||
| DialogButton = namedtuple('DialogButton', 'text callback action') | DialogButton = namedtuple('DialogButton', 'text callback action') | ||||||
| DialogButton.__new__.__defaults__ = (None, None) | DialogButton.__new__.__defaults__ = (None, None)  # type: ignore | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| @unique | @unique | ||||||
|  |  | ||||||
|  | @ -17,8 +17,14 @@ Exception: this class should not be instatiated | ||||||
| True | True | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
|  | from typing import Any  # pylint: disable=unused-import | ||||||
|  | from typing import ClassVar  # pylint: disable=unused-import | ||||||
|  | from typing import Dict  # pylint: disable=unused-import | ||||||
|  | from typing import Tuple  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| class FilesProp: | class FilesProp: | ||||||
|     _files_props = {} |     _files_props = {}  # type: ClassVar[Dict[Tuple[str, str], Any]] | ||||||
| 
 | 
 | ||||||
|     def __init__(self): |     def __init__(self): | ||||||
|         raise Exception('this class should not be instantiated') |         raise Exception('this class should not be instantiated') | ||||||
|  |  | ||||||
|  | @ -16,14 +16,19 @@ | ||||||
| Handles Jingle contents (XEP 0166) | Handles Jingle contents (XEP 0166) | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
|  | from typing import Any  # pylint: disable=unused-import | ||||||
|  | from typing import Dict  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
| import os | import os | ||||||
|  | 
 | ||||||
|  | import nbxmpp | ||||||
|  | 
 | ||||||
| from gajim.common import app | from gajim.common import app | ||||||
| from gajim.common import configpaths | from gajim.common import configpaths | ||||||
| import nbxmpp |  | ||||||
| from gajim.common.jingle_xtls import SELF_SIGNED_CERTIFICATE | from gajim.common.jingle_xtls import SELF_SIGNED_CERTIFICATE | ||||||
| from gajim.common.jingle_xtls import load_cert_file | from gajim.common.jingle_xtls import load_cert_file | ||||||
| 
 | 
 | ||||||
| contents = {} | contents = {}  # type: Dict[str, Any] | ||||||
| 
 | 
 | ||||||
| def get_jingle_content(node): | def get_jingle_content(node): | ||||||
|     namespace = node.getNamespace() |     namespace = node.getNamespace() | ||||||
|  |  | ||||||
|  | @ -16,16 +16,21 @@ | ||||||
| Handles Jingle Transports (currently only ICE-UDP) | Handles Jingle Transports (currently only ICE-UDP) | ||||||
| """ | """ | ||||||
| 
 | 
 | ||||||
|  | from typing import Any  # pylint: disable=unused-import | ||||||
|  | from typing import Dict  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
| import logging | import logging | ||||||
| import socket | import socket | ||||||
| from enum import IntEnum, unique | from enum import IntEnum, unique | ||||||
|  | 
 | ||||||
| import nbxmpp | import nbxmpp | ||||||
|  | 
 | ||||||
| from gajim.common import app | from gajim.common import app | ||||||
| 
 | 
 | ||||||
| log = logging.getLogger('gajim.c.jingle_transport') | log = logging.getLogger('gajim.c.jingle_transport') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| transports = {} | transports = {}  # type: Dict[str, Any] | ||||||
| 
 | 
 | ||||||
| def get_jingle_transport(node): | def get_jingle_transport(node): | ||||||
|     namespace = node.getNamespace() |     namespace = node.getNamespace() | ||||||
|  |  | ||||||
|  | @ -28,10 +28,12 @@ __all__ = ['get_password', 'save_password'] | ||||||
| 
 | 
 | ||||||
| log = logging.getLogger('gajim.password') | log = logging.getLogger('gajim.password') | ||||||
| 
 | 
 | ||||||
| keyring = None | 
 | ||||||
| try: | try: | ||||||
|     import keyring |     import keyring | ||||||
|  |     KEYRING_AVAILABLE = True | ||||||
| except ImportError: | except ImportError: | ||||||
|  |     KEYRING_AVAILABLE = False | ||||||
|     log.debug('python-keyring missing, falling back to plaintext storage') |     log.debug('python-keyring missing, falling back to plaintext storage') | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -83,7 +85,7 @@ class PasswordStorageManager(PasswordStorage): | ||||||
|         """ |         """ | ||||||
|         # TODO: handle disappearing backends |         # TODO: handle disappearing backends | ||||||
| 
 | 
 | ||||||
|         if app.config.get('use_keyring') and keyring: |         if app.config.get('use_keyring') and KEYRING_AVAILABLE: | ||||||
|             self.secret = SecretPasswordStorage() |             self.secret = SecretPasswordStorage() | ||||||
| 
 | 
 | ||||||
|     def get_password(self, account_name): |     def get_password(self, account_name): | ||||||
|  |  | ||||||
|  | @ -19,11 +19,14 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
|  | from typing import Any  # pylint: disable=unused-import | ||||||
|  | from typing import List  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
| import logging | import logging | ||||||
| log = logging.getLogger('gajim.c.pep') |  | ||||||
| 
 | 
 | ||||||
| from gajim.common import app | from gajim.common import app | ||||||
| 
 | 
 | ||||||
|  | log = logging.getLogger('gajim.c.pep') | ||||||
| 
 | 
 | ||||||
| class AbstractPEP: | class AbstractPEP: | ||||||
| 
 | 
 | ||||||
|  | @ -75,4 +78,4 @@ class AbstractPEP: | ||||||
|         pass |         pass | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| SUPPORTED_PERSONAL_USER_EVENTS = [] | SUPPORTED_PERSONAL_USER_EVENTS = []  # type: List[Any] | ||||||
|  |  | ||||||
|  | @ -18,11 +18,11 @@ | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
| try: | try: | ||||||
|     from docutils import io |     from docutils import io  # type: ignore | ||||||
|     from docutils.core import Publisher |     from docutils.core import Publisher | ||||||
|     from docutils.parsers.rst import roles |     from docutils.parsers.rst import roles | ||||||
|     from docutils import nodes, utils |     from docutils import nodes, utils  # type: ignore | ||||||
|     from docutils.parsers.rst.roles import set_classes |     from docutils.parsers.rst.roles import set_classes  # type: ignore | ||||||
| except ImportError: | except ImportError: | ||||||
|     print("Requires docutils 0.4 for set_classes to be available") |     print("Requires docutils 0.4 for set_classes to be available") | ||||||
|     def create_xhtml(text): |     def create_xhtml(text): | ||||||
|  |  | ||||||
|  | @ -799,7 +799,7 @@ class Socks5: | ||||||
|                 return self.file_props.received_len |                 return self.file_props.received_len | ||||||
|         return None |         return None | ||||||
| 
 | 
 | ||||||
|     def disconnect(self): |     def disconnect(self, *args, **kwargs): | ||||||
|         """ |         """ | ||||||
|         Close open descriptors and remover socket descr. from idleque |         Close open descriptors and remover socket descr. from idleque | ||||||
|         """ |         """ | ||||||
|  |  | ||||||
|  | @ -33,6 +33,15 @@ if TYPE_CHECKING: | ||||||
|     from gajim.common.contacts import Contact |     from gajim.common.contacts import Contact | ||||||
|     from gajim.common.contacts import GC_Contact |     from gajim.common.contacts import GC_Contact | ||||||
|     from gajim.common.nec import NetworkEvent |     from gajim.common.nec import NetworkEvent | ||||||
|  |     from gajim.common.nec import NetworkEventsController | ||||||
|  |     from gajim.common.logger import Logger | ||||||
|  | 
 | ||||||
|  |     from gajim.gui_interface import Interface | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | NetworkEventsControllerT = Union['NetworkEventsController'] | ||||||
|  | InterfaceT = Union['Interface'] | ||||||
|  | LoggerT = Union['Logger'] | ||||||
| 
 | 
 | ||||||
| ConnectionT = Union['Connection', 'ConnectionZeroconf'] | ConnectionT = Union['Connection', 'ConnectionZeroconf'] | ||||||
| ContactT = Union['Contact', 'GC_Contact'] | ContactT = Union['Contact', 'GC_Contact'] | ||||||
|  |  | ||||||
|  | @ -19,6 +19,7 @@ from gajim.common import app | ||||||
| import nbxmpp | import nbxmpp | ||||||
| from nbxmpp.idlequeue import IdleObject | from nbxmpp.idlequeue import IdleObject | ||||||
| from nbxmpp import dispatcher_nb, simplexml | from nbxmpp import dispatcher_nb, simplexml | ||||||
|  | from nbxmpp.plugin import PlugIn | ||||||
| from nbxmpp.plugin import * | from nbxmpp.plugin import * | ||||||
| from nbxmpp.transports_nb import DATA_RECEIVED, DATA_SENT, DATA_ERROR | from nbxmpp.transports_nb import DATA_RECEIVED, DATA_SENT, DATA_ERROR | ||||||
| from gajim.common.zeroconf import zeroconf | from gajim.common.zeroconf import zeroconf | ||||||
|  |  | ||||||
|  | @ -14,8 +14,11 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim.  If not, see <http://www.gnu.org/licenses/>. | # along with Gajim.  If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
|  | from typing import Any  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
| from enum import IntEnum, unique | from enum import IntEnum, unique | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| @unique | @unique | ||||||
| class Constant(IntEnum): | class Constant(IntEnum): | ||||||
|     NAME = 0 |     NAME = 0 | ||||||
|  | @ -54,7 +57,7 @@ def test_zeroconf(): | ||||||
| 
 | 
 | ||||||
| if test_avahi(): | if test_avahi(): | ||||||
|     from gajim.common.zeroconf import zeroconf_avahi |     from gajim.common.zeroconf import zeroconf_avahi | ||||||
|     Zeroconf = zeroconf_avahi.Zeroconf |     Zeroconf = zeroconf_avahi.Zeroconf  # type: Any | ||||||
| elif test_bonjour(): | elif test_bonjour(): | ||||||
|     from gajim.common.zeroconf import zeroconf_bonjour |     from gajim.common.zeroconf import zeroconf_bonjour | ||||||
|     Zeroconf = zeroconf_bonjour.Zeroconf |     Zeroconf = zeroconf_bonjour.Zeroconf | ||||||
|  |  | ||||||
|  | @ -25,18 +25,22 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
| from gi.repository import Gtk | from typing import Dict  # pylint: disable=unused-import | ||||||
| from gi.repository import Gdk | from typing import List  # pylint: disable=unused-import | ||||||
| from gi.repository import GLib | from typing import Tuple  # pylint: disable=unused-import | ||||||
| 
 | 
 | ||||||
| import os | import os | ||||||
| import logging | import logging | ||||||
|  | from random import randrange | ||||||
|  | 
 | ||||||
|  | from gi.repository import Gtk | ||||||
|  | from gi.repository import Gdk | ||||||
|  | from gi.repository import GLib | ||||||
| 
 | 
 | ||||||
| from gajim import gtkgui_helpers | from gajim import gtkgui_helpers | ||||||
| from gajim import vcard | from gajim import vcard | ||||||
| from gajim import dataforms_widget | from gajim import dataforms_widget | ||||||
| 
 | 
 | ||||||
| from random import randrange |  | ||||||
| from gajim.common import ged | from gajim.common import ged | ||||||
| from gajim.common.i18n import _ | from gajim.common.i18n import _ | ||||||
| from gajim.common.const import ACTIVITIES | from gajim.common.const import ACTIVITIES | ||||||
|  | @ -1363,7 +1367,7 @@ class ProgressDialog: | ||||||
| 
 | 
 | ||||||
| class TransformChatToMUC: | class TransformChatToMUC: | ||||||
|     # Keep a reference on windows so garbage collector don't restroy them |     # Keep a reference on windows so garbage collector don't restroy them | ||||||
|     instances = [] |     instances = []  # type: List[TransformChatToMUC] | ||||||
|     def __init__(self, account, jids, preselected=None): |     def __init__(self, account, jids, preselected=None): | ||||||
|         """ |         """ | ||||||
|         This window is used to trasform a one-to-one chat to a MUC. We do 2 |         This window is used to trasform a one-to-one chat to a MUC. We do 2 | ||||||
|  | @ -1584,7 +1588,7 @@ class ResourceConflictDialog(TimeoutDialog, InputDialog): | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class VoIPCallReceivedDialog: | class VoIPCallReceivedDialog: | ||||||
|     instances = {} |     instances = {}   # type: Dict[Tuple[str, str], VoIPCallReceivedDialog] | ||||||
|     def __init__(self, account, contact_jid, sid, content_types): |     def __init__(self, account, contact_jid, sid, content_types): | ||||||
|         self.instances[(contact_jid, sid)] = self |         self.instances[(contact_jid, sid)] = self | ||||||
|         self.account = account |         self.account = account | ||||||
|  |  | ||||||
|  | @ -12,6 +12,8 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
|  | from typing import List  # pylint: disable=unused-import | ||||||
|  | 
 | ||||||
| from gi.repository import Gdk | from gi.repository import Gdk | ||||||
| from gi.repository import GLib | from gi.repository import GLib | ||||||
| 
 | 
 | ||||||
|  | @ -40,7 +42,7 @@ class SingleMessageWindow: | ||||||
|     action argument which can be 'send' or 'receive' |     action argument which can be 'send' or 'receive' | ||||||
|     """ |     """ | ||||||
|     # Keep a reference on windows so garbage collector don't restroy them |     # Keep a reference on windows so garbage collector don't restroy them | ||||||
|     instances = [] |     instances = []  # type: List[SingleMessageWindow] | ||||||
|     def __init__(self, account, to='', action='', from_whom='', subject='', |     def __init__(self, account, to='', action='', from_whom='', subject='', | ||||||
|             message='', resource='', session=None, form_node=None): |             message='', resource='', session=None, form_node=None): | ||||||
|         self.instances.append(self) |         self.instances.append(self) | ||||||
|  |  | ||||||
|  | @ -23,32 +23,34 @@ | ||||||
| # You should have received a copy of the GNU General Public License | # You should have received a copy of the GNU General Public License | ||||||
| # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | # along with Gajim. If not, see <http://www.gnu.org/licenses/>. | ||||||
| 
 | 
 | ||||||
|  | import cairo | ||||||
|  | import os | ||||||
|  | import sys | ||||||
|  | import math | ||||||
|  | import logging | ||||||
|  | from io import BytesIO | ||||||
|  | import xml.etree.ElementTree as ET | ||||||
| import xml.sax.saxutils | import xml.sax.saxutils | ||||||
|  | from xml.sax import ContentHandler  # type: ignore | ||||||
|  | 
 | ||||||
| from gi.repository import Gtk | from gi.repository import Gtk | ||||||
| from gi.repository import Gdk | from gi.repository import Gdk | ||||||
| from gi.repository import GdkPixbuf | from gi.repository import GdkPixbuf | ||||||
| from gi.repository import GLib | from gi.repository import GLib | ||||||
| from gi.repository import Pango | from gi.repository import Pango | ||||||
| import cairo |  | ||||||
| import os |  | ||||||
| import sys |  | ||||||
| import math |  | ||||||
| import xml.etree.ElementTree as ET |  | ||||||
| 
 | 
 | ||||||
| try: | try: | ||||||
|     from PIL import Image |     from PIL import Image | ||||||
| except Exception: | except Exception: | ||||||
|     pass |     pass | ||||||
| from io import BytesIO |  | ||||||
| 
 |  | ||||||
| import logging |  | ||||||
| log = logging.getLogger('gajim.gtkgui_helpers') |  | ||||||
| 
 | 
 | ||||||
| from gajim.common import i18n | from gajim.common import i18n | ||||||
| from gajim.common import app | from gajim.common import app | ||||||
| from gajim.common import configpaths | from gajim.common import configpaths | ||||||
| from gajim.common.const import PEPEventType, ACTIVITIES, MOODS | from gajim.common.const import PEPEventType, ACTIVITIES, MOODS | ||||||
| 
 | 
 | ||||||
|  | log = logging.getLogger('gajim.gtkgui_helpers') | ||||||
|  | 
 | ||||||
| gtk_icon_theme = Gtk.IconTheme.get_default() | gtk_icon_theme = Gtk.IconTheme.get_default() | ||||||
| gtk_icon_theme.append_search_path(configpaths.get('ICONS')) | gtk_icon_theme.append_search_path(configpaths.get('ICONS')) | ||||||
| 
 | 
 | ||||||
|  | @ -234,9 +236,9 @@ def scroll_to_end(widget): | ||||||
|     return False |     return False | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| class ServersXMLHandler(xml.sax.ContentHandler): | class ServersXMLHandler(ContentHandler): | ||||||
|     def __init__(self): |     def __init__(self): | ||||||
|         xml.sax.ContentHandler.__init__(self) |         ContentHandler.__init__(self) | ||||||
|         self.servers = [] |         self.servers = [] | ||||||
| 
 | 
 | ||||||
|     def startElement(self, name, attributes): |     def startElement(self, name, attributes): | ||||||
|  |  | ||||||
|  | @ -5643,7 +5643,7 @@ class RosterWindow: | ||||||
| ### | ### | ||||||
| ################################################################################ | ################################################################################ | ||||||
| 
 | 
 | ||||||
|     def __init__(self, application: Gtk.Application): |     def __init__(self, application): | ||||||
|         self.application = application |         self.application = application | ||||||
|         self.filtering = False |         self.filtering = False | ||||||
|         self.starting = False |         self.starting = False | ||||||
|  |  | ||||||
							
								
								
									
										10
									
								
								mypy.ini
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								mypy.ini
									
										
									
									
									
								
							|  | @ -1,5 +1,6 @@ | ||||||
| [mypy] | [mypy] | ||||||
| python_version = 3.5 | python_version = 3.5 | ||||||
|  | warn_unused_configs = True | ||||||
| disallow_incomplete_defs = True | disallow_incomplete_defs = True | ||||||
| 
 | 
 | ||||||
| [mypy-nbxmpp.*] | [mypy-nbxmpp.*] | ||||||
|  | @ -61,3 +62,12 @@ ignore_missing_imports = True | ||||||
| 
 | 
 | ||||||
| [mypy-docutils.*] | [mypy-docutils.*] | ||||||
| ignore_missing_imports = True | ignore_missing_imports = True | ||||||
|  | 
 | ||||||
|  | [mypy-IPython.*] | ||||||
|  | ignore_missing_imports = True | ||||||
|  | 
 | ||||||
|  | [mypy-traitlets.*] | ||||||
|  | ignore_missing_imports = True | ||||||
|  | 
 | ||||||
|  | [mypy-pygments.*] | ||||||
|  | ignore_missing_imports = True | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue