More typing

This commit is contained in:
mathieui 2018-07-23 21:44:27 +02:00
parent 878a67e501
commit f1e4cdc2a8
No known key found for this signature in database
GPG key ID: C59F84CEEFD616E3

View file

@ -14,12 +14,13 @@ revolving around chats.
""" """
import logging import logging
log = logging.getLogger(__name__)
import string import string
import time import time
from datetime import datetime from datetime import datetime
from xml.etree import cElementTree as ET from xml.etree import cElementTree as ET
from typing import Any, Callable, Dict, List, Optional
from slixmpp import JID, Message
from poezio.core.structs import Command, Completion, Status from poezio.core.structs import Command, Completion, Status
from poezio import timed_events from poezio import timed_events
@ -33,6 +34,9 @@ from poezio.text_buffer import TextBuffer
from poezio.theming import get_theme, dump_tuple from poezio.theming import get_theme, dump_tuple
from poezio.decorators import command_args_parser from poezio.decorators import command_args_parser
log = logging.getLogger(__name__)
# getters for tab colors (lambdas, so that they are dynamic) # getters for tab colors (lambdas, so that they are dynamic)
STATE_COLORS = { STATE_COLORS = {
'disconnected': lambda: get_theme().COLOR_TAB_DISCONNECTED, 'disconnected': lambda: get_theme().COLOR_TAB_DISCONNECTED,
@ -88,7 +92,7 @@ SHOW_NAME = {
class Tab: class Tab:
plugin_commands = {} plugin_commands = {}
plugin_keys = {} plugin_keys = {} # type: Dict[str, Callable]
def __init__(self, core): def __init__(self, core):
self.core = core self.core = core
@ -106,11 +110,11 @@ class Tab:
self.commands = {} # and their own commands self.commands = {} # and their own commands
@property @property
def size(self): def size(self) -> int:
return self.core.size return self.core.size
@staticmethod @staticmethod
def tab_win_height(): def tab_win_height() -> int:
""" """
Returns 1 or 0, depending on if we are using the vertical tab list Returns 1 or 0, depending on if we are using the vertical tab list
or not. or not.
@ -132,11 +136,11 @@ class Tab:
return VERTICAL_STATE_COLORS[self._state]() return VERTICAL_STATE_COLORS[self._state]()
@property @property
def state(self): def state(self) -> str:
return self._state return self._state
@state.setter @state.setter
def state(self, value): def state(self, value: str):
if value not in STATE_COLORS: if value not in STATE_COLORS:
log.debug("Invalid value for tab state: %s", value) log.debug("Invalid value for tab state: %s", value)
elif STATE_PRIORITY[value] < STATE_PRIORITY[self._state] and \ elif STATE_PRIORITY[value] < STATE_PRIORITY[self._state] and \
@ -154,7 +158,7 @@ class Tab:
if self._state == 'current': if self._state == 'current':
self._prev_state = None self._prev_state = None
def set_state(self, value): def set_state(self, value: str):
self._state = value self._state = value
def save_state(self): def save_state(self):
@ -181,7 +185,7 @@ class Tab:
""" """
return False return False
def register_commands_batch(self, commands): def register_commands_batch(self, commands: List[Dict[str, Any]]):
""" """
Add several commands in a row, using a list of dictionaries Add several commands in a row, using a list of dictionaries
""" """
@ -201,12 +205,12 @@ class Tab:
usage=usage) usage=usage)
def register_command(self, def register_command(self,
name, name: str,
func, func: Callable,
*, *,
desc='', desc='',
shortdesc='', shortdesc='',
completion=None, completion: Optional[Callable] = None,
usage=''): usage=''):
""" """
Add a command Add a command
@ -217,7 +221,7 @@ class Tab:
desc = shortdesc desc = shortdesc
self.commands[name] = Command(func, desc, completion, shortdesc, usage) self.commands[name] = Command(func, desc, completion, shortdesc, usage)
def complete_commands(self, the_input): def complete_commands(self, the_input: windows.Input) -> bool:
""" """
Does command completion on the specified input for both global and tab-specific Does command completion on the specified input for both global and tab-specific
commands. commands.
@ -255,14 +259,13 @@ class Tab:
return False return False
if command.comp is None: if command.comp is None:
return False # There's no completion function return False # There's no completion function
else:
comp = command.comp(the_input) comp = command.comp(the_input)
if comp: if comp:
return comp.run() return comp.run()
return comp return comp
return False return False
def execute_command(self, provided_text): def execute_command(self, provided_text: str) -> bool:
""" """
Execute the command in the input and return False if Execute the command in the input and return False if
the input didn't contain a command the input didn't contain a command
@ -327,19 +330,19 @@ class Tab:
""" """
return self.name return self.name
def get_nick(self): def get_nick(self) -> str:
""" """
Get the nick of the tab (defaults to its name) Get the nick of the tab (defaults to its name)
""" """
return self.name return self.name
def get_text_window(self): def get_text_window(self) -> Optional[windows.TextWin]:
""" """
Returns the principal TextWin window, if there's one Returns the principal TextWin window, if there's one
""" """
return None return None
def on_input(self, key, raw): def on_input(self, key: str, raw: bool):
""" """
raw indicates if the key should activate the associated command or not. raw indicates if the key should activate the associated command or not.
""" """
@ -417,7 +420,7 @@ class Tab:
self.input.on_delete() self.input.on_delete()
self.closed = True self.closed = True
def matching_names(self): def matching_names(self) -> List[str]:
""" """
Returns a list of strings that are used to name a tab with the /win Returns a list of strings that are used to name a tab with the /win
command. For example you could switch to a tab that returns command. For example you could switch to a tab that returns
@ -505,18 +508,18 @@ class ChatTab(Tab):
self._text_buffer.add_message(**message) self._text_buffer.add_message(**message)
@property @property
def remote_wants_chatstates(self): def remote_wants_chatstates(self) -> bool:
return True return True
@property @property
def general_jid(self): def general_jid(self) -> JID:
return NotImplementedError return NotImplementedError
def load_logs(self, log_nb): def load_logs(self, log_nb: int) -> Optional[List[Dict[str, Any]]]:
logs = logger.get_logs(safeJID(self.name).bare, log_nb) logs = logger.get_logs(safeJID(self.name).bare, log_nb)
return logs return logs
def log_message(self, txt, nickname, time=None, typ=1): def log_message(self, txt: str, nickname: str, time: Optional[datetime] = None, typ=1):
""" """
Log the messages in the archives. Log the messages in the archives.
""" """
@ -600,7 +603,7 @@ class ChatTab(Tab):
if message: if message:
message.send() message.send()
def generate_xhtml_message(self, arg): def generate_xhtml_message(self, arg: str) -> Message:
if not arg: if not arg:
return return
try: try:
@ -618,7 +621,7 @@ class ChatTab(Tab):
msg['html']['body'] = arg msg['html']['body'] = arg
return msg return msg
def get_dest_jid(self): def get_dest_jid(self) -> JID:
return self.name return self.name
@refresh_wrapper.always @refresh_wrapper.always
@ -719,7 +722,7 @@ class ChatTab(Tab):
return True return True
@property @property
def inactive(self): def inactive(self) -> bool:
"""Whether we should send inactive or active as a chatstate""" """Whether we should send inactive or active as a chatstate"""
return self.core.status.show in ('xa', 'away') or\ return self.core.status.show in ('xa', 'away') or\
(hasattr(self, 'directed_presence') and not self.directed_presence) (hasattr(self, 'directed_presence') and not self.directed_presence)