diff --git a/blueman/gui/DeviceSelectorDialog.py b/blueman/gui/DeviceSelectorDialog.py index c32140147..0b907cbb4 100644 --- a/blueman/gui/DeviceSelectorDialog.py +++ b/blueman/gui/DeviceSelectorDialog.py @@ -4,6 +4,7 @@ from blueman.bluez.Device import Device from blueman.gui.DeviceList import DeviceList from blueman.gui.DeviceSelectorWidget import DeviceSelectorWidget +from blueman.bluemantyping import ObjectPath import gi gi.require_version("Gtk", "3.0") @@ -11,7 +12,7 @@ class DeviceSelectorDialog(Gtk.Dialog): - selection: Optional[Tuple[str, Optional[Device]]] + selection: Optional[Tuple[ObjectPath, Optional[Device]]] def __init__(self, title: str = _("Select Device"), parent: Optional[Gtk.Container] = None, discover: bool = True, adapter_name: Optional[str] = None) -> None: diff --git a/blueman/main/Sendto.py b/blueman/main/Sendto.py index 37ad3047c..1bff1f6cb 100644 --- a/blueman/main/Sendto.py +++ b/blueman/main/Sendto.py @@ -3,8 +3,9 @@ import os import time import logging +from argparse import Namespace from gettext import ngettext -from typing import List, Iterable, Optional +from typing import List, Iterable, Optional, Sequence from blueman.bluez.Device import Device from blueman.bluez.errors import BluezDBusException, DBusNoSuchAdapterError @@ -28,7 +29,7 @@ class SendTo: - def __init__(self, parsed_args): + def __init__(self, parsed_args: Namespace) -> None: setup_icon_path() check_bluetooth_status(_("Bluetooth needs to be turned on for file sending to work"), bmexit) @@ -64,7 +65,7 @@ def __init__(self, parsed_args): self.adapter_path = adapter.get_object_path() if parsed_args.delete: - def delete_files(): + def delete_files() -> None: for file in self.files: os.unlink(file) atexit.register(delete_files) @@ -83,21 +84,23 @@ def delete_files(): self.device = d self.do_send() - def do_send(self): + def do_send(self) -> None: if not self.files: logging.warning("No files to send") bmexit() + assert(self.device is not None) sender = Sender(self.device, self.adapter_path, self.files) - def on_result(sender, res): + def on_result(_sender: Sender, _res: bool) -> None: Gtk.main_quit() sender.connect("result", on_result) @staticmethod - def select_files(): - d = Gtk.FileChooserDialog(title=_("Select files to send"), icon_name='blueman-send-symbolic', select_multiple=True) + def select_files() -> Sequence[str]: + d = Gtk.FileChooserDialog(title=_("Select files to send"), icon_name='blueman-send-symbolic') + d.set_select_multiple(True) # this avoids type error when using keyword arg above d.add_buttons(_("_Cancel"), Gtk.ResponseType.REJECT, _("_OK"), Gtk.ResponseType.ACCEPT) resp = d.run() @@ -109,7 +112,7 @@ def select_files(): d.destroy() quit() - def select_device(self): + def select_device(self) -> bool: adapter_name = os.path.split(self.adapter_path)[-1] d = DeviceSelectorDialog(discover=True, adapter_name=adapter_name) resp = d.run()