Fix rest of mypy errors

- This allows us to run mypy on the full gajim folder
This commit is contained in:
Philipp Hörist 2018-09-21 23:55:57 +02:00
parent fafef38f2c
commit 9bbc2eceb3
20 changed files with 123 additions and 50 deletions

View File

@ -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):

View File

@ -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,

View File

@ -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,

View File

@ -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', ''],

View File

@ -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

View File

@ -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')

View File

@ -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()

View File

@ -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()

View File

@ -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):

View File

@ -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]

View File

@ -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):

View File

@ -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
""" """

View File

@ -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']

View File

@ -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

View File

@ -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

View File

@ -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

View File

@ -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)

View File

@ -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):

View File

@ -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

View File

@ -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