app.py and main.py refactoring and fixes
This commit is contained in:
parent
8a2665ed4d
commit
0ba1aadf70
194
toxygen/app.py
194
toxygen/app.py
@ -1,6 +1,7 @@
|
||||
from middleware import threads
|
||||
import middleware.callbacks as callbacks
|
||||
from PyQt5 import QtWidgets, QtGui, QtCore
|
||||
import ui.password_screen as passwordscreen
|
||||
import ui.password_screen as password_screen
|
||||
from util.util import *
|
||||
import updater.updater as updater
|
||||
import os
|
||||
@ -20,32 +21,30 @@ class App:
|
||||
|
||||
def __init__(self, version, path_to_profile=None, uri=None):
|
||||
self._version = version
|
||||
self._app = None
|
||||
self._tox = self._ms = self._init = self._app = self.tray = self._main_loop = self._av_loop = None
|
||||
self.uri = self._toxes = self._tray = None
|
||||
self._app = self._settings = self._profile_manager = self._plugin_loader = None
|
||||
self._tox = self._ms = self._init = self.tray = self._main_loop = self._av_loop = None
|
||||
self._uri = self._toxes = self._tray = None
|
||||
if uri is not None and uri.startswith('tox:'):
|
||||
self.uri = uri[4:]
|
||||
self._uri = uri[4:]
|
||||
self._path = path_to_profile
|
||||
|
||||
def enter_pass(self, data):
|
||||
"""
|
||||
Show password screen
|
||||
"""
|
||||
p = passwordscreen.PasswordScreen(self._toxes, data)
|
||||
p = password_screen.PasswordScreen(self._toxes, data)
|
||||
p.show()
|
||||
self._app.lastWindowClosed.connect(self._app.quit)
|
||||
self._app.exec_()
|
||||
result = p.result
|
||||
if result is None:
|
||||
raise SystemExit()
|
||||
else:
|
||||
return result
|
||||
if p.result is not None:
|
||||
return p.result
|
||||
raise SystemExit()
|
||||
|
||||
def main(self):
|
||||
"""
|
||||
Main function of app. loads login screen if needed and starts main screen
|
||||
"""
|
||||
self._app= QtWidgets.QApplication([])
|
||||
self._app = QtWidgets.QApplication([])
|
||||
icon_file = os.path.join(get_images_directory(), 'icon.png')
|
||||
self._app.setWindowIcon(QtGui.QIcon(icon_file))
|
||||
|
||||
@ -59,28 +58,13 @@ class App:
|
||||
encrypt_save = tox_encrypt_save.ToxEncryptSave()
|
||||
self._toxes = user_data.toxes.ToxES(encrypt_save)
|
||||
|
||||
if self._path is not None:
|
||||
path = os.path.dirname(self._path) + '/'
|
||||
name = os.path.basename(self._path)[:-4]
|
||||
self._settings = Settings(self._toxes, self._path.replace('.tox', '.json'))
|
||||
self._profile_manager = ProfileManager(self._settings, self._toxes, path)
|
||||
data = self._profile_manager.open_profile()
|
||||
if encrypt_save.is_data_encrypted(data):
|
||||
data = self.enter_pass(data)
|
||||
self._tox = self.create_tox(data)
|
||||
if self._path is not None: # toxygen was started with path to profile
|
||||
self.load_existing_profile(self._path)
|
||||
else:
|
||||
auto_profile = Settings.get_auto_profile()
|
||||
if not auto_profile[0]:
|
||||
if auto_profile is None: # no default profile
|
||||
# show login screen if default profile not found
|
||||
current_locale = QtCore.QLocale()
|
||||
curr_lang = current_locale.languageToString(current_locale.language())
|
||||
langs = Settings.supported_languages()
|
||||
if curr_lang in langs:
|
||||
lang_path = langs[curr_lang]
|
||||
translator = QtCore.QTranslator()
|
||||
translator.load(get_translations_directory() + lang_path)
|
||||
self._app.installTranslator(translator)
|
||||
self._app.translator = translator
|
||||
self.load_login_screen_translations()
|
||||
ls = LoginScreen()
|
||||
ls.setWindowIconText("Toxygen")
|
||||
profiles = ProfileManager.find_profiles()
|
||||
@ -90,59 +74,25 @@ class App:
|
||||
result = ls.result
|
||||
if result is None:
|
||||
return
|
||||
elif result.is_new_profile(): # create new profile
|
||||
name = get_profile_name_from_path(result.profile_path) or 'toxygen_user'
|
||||
pr = map(lambda x: x[1], ProfileManager.find_profiles())
|
||||
if name in list(pr):
|
||||
util_ui.message_box(util_ui.tr('Profile with this name already exists'),
|
||||
util_ui.tr('Error'))
|
||||
return
|
||||
self._tox = tox_factory()
|
||||
self._tox.self_set_name(bytes(name, 'utf-8') if name else b'Toxygen User')
|
||||
self._tox.self_set_status_message(b'Toxing on Toxygen')
|
||||
# TODO: set profile password
|
||||
path = result.profile_path
|
||||
self._profile_manager = ProfileManager(self._toxes, path)
|
||||
try:
|
||||
self._profile_manager.save_profile(self._tox.get_savedata())
|
||||
except Exception as ex:
|
||||
print(str(ex))
|
||||
log('Profile creation exception: ' + str(ex))
|
||||
text = util_ui.tr('Profile saving error! Does Toxygen have permission to write to this directory?')
|
||||
util_ui.message_box(text, util_ui.tr('Error'))
|
||||
return
|
||||
path = Settings.get_default_path()
|
||||
self._settings = Settings()
|
||||
if curr_lang in langs:
|
||||
self._settings['language'] = curr_lang
|
||||
self._settings.save()
|
||||
if result.is_new_profile(): # create new profile
|
||||
self.create_new_profile(result.profile_path)
|
||||
else: # load existing profile
|
||||
path = result.profile_path
|
||||
if result.load_as_default:
|
||||
Settings.set_auto_profile(path)
|
||||
self._settings = Settings(self._toxes, path.replace('.tox', '.json'))
|
||||
self._profile_manager = ProfileManager(self._settings, self._toxes, path)
|
||||
data = self._profile_manager.open_profile()
|
||||
if self._toxes.is_data_encrypted(data):
|
||||
data = self.enter_pass(data)
|
||||
self._tox = self.create_tox(data)
|
||||
else:
|
||||
self.load_existing_profile(result.profile_path)
|
||||
self._path = result.profile_path
|
||||
else: # default profile
|
||||
path, name = auto_profile
|
||||
self._settings = Settings(self._toxes, path + name + '.json')
|
||||
self._profile_manager = ProfileManager(self._settings, self._toxes, path)
|
||||
data = self._profile_manager.open_profile()
|
||||
if encrypt_save.is_data_encrypted(data):
|
||||
data = self.enter_pass(data)
|
||||
self.tox = self.create_tox(data)
|
||||
self._path = os.path.join(path, name + '.tox')
|
||||
self.load_existing_profile(self._path)
|
||||
|
||||
if Settings.is_active_profile(path, get_profile_name_from_path(path)): # profile is in use
|
||||
title = util_ui.tr('Profile {}').format(name)
|
||||
if Settings.is_active_profile(self._path): # profile is in use
|
||||
profile_name = get_profile_name_from_path(self._path)
|
||||
title = util_ui.tr('Profile {}').format(profile_name)
|
||||
text = util_ui.tr('Other instance of Toxygen uses this profile or profile was not properly closed. Continue?')
|
||||
reply = util_ui.question(text, title)
|
||||
if not reply:
|
||||
return
|
||||
else:
|
||||
self._settings.set_active_profile()
|
||||
|
||||
self._settings.set_active_profile()
|
||||
|
||||
self.load_app_styles()
|
||||
self.load_app_translations()
|
||||
@ -151,17 +101,21 @@ class App:
|
||||
return
|
||||
|
||||
self._ms = MainWindow(self._settings, self._tox, self.reset, self._tray)
|
||||
self._profile = self._ms.profile
|
||||
profile = self._ms.profile
|
||||
self._ms.show()
|
||||
|
||||
self._tray = tray.init_tray(self._profile, self._settings, self._ms)
|
||||
self._tray = tray.init_tray(profile, self._settings, self._ms)
|
||||
self._tray.show()
|
||||
|
||||
self._plugin_loader = PluginLoader(self._tox, self._toxes, self._profile, self._settings) # plugins support
|
||||
self._plugin_loader.load() # TODO; move to separate thread?
|
||||
self._plugin_loader = PluginLoader(self._tox, self._toxes, profile, self._settings) # plugins support
|
||||
self.start_threads()
|
||||
|
||||
if self.uri is not None:
|
||||
self._ms.add_contact(self.uri)
|
||||
# callbacks initialization
|
||||
callbacks.init_callbacks(self._tox, profile, self._settings, self._plugin_loader, None, None, None,
|
||||
self._ms, self._tray)
|
||||
|
||||
if self._uri is not None:
|
||||
self._ms.add_contact(self._uri)
|
||||
|
||||
self._app.lastWindowClosed.connect(self._app.quit)
|
||||
self._app.exec_()
|
||||
@ -169,8 +123,7 @@ class App:
|
||||
self._plugin_loader.stop()
|
||||
self.stop_threads()
|
||||
self._tray.hide()
|
||||
data = self._tox.get_savedata()
|
||||
self._profile_manager.save_profile(data)
|
||||
self.save_profile()
|
||||
self._settings.close()
|
||||
del self._tox
|
||||
|
||||
@ -181,10 +134,10 @@ class App:
|
||||
"""
|
||||
self.stop_threads()
|
||||
data = self._tox.get_savedata()
|
||||
self._profile_manager.save_profile(data)
|
||||
self.save_profile(data)
|
||||
del self._tox
|
||||
# create new tox instance
|
||||
self._tox = tox_factory(data, self._settings)
|
||||
self._tox = self.create_tox(data)
|
||||
self.start_threads()
|
||||
|
||||
self._plugin_loader.set_tox(self._tox)
|
||||
@ -199,25 +152,41 @@ class App:
|
||||
style = fl.read()
|
||||
self._app.setStyleSheet(style)
|
||||
|
||||
def load_login_screen_translations(self):
|
||||
current_language, supported_languages = self.get_languages()
|
||||
if current_language in supported_languages:
|
||||
lang_path = supported_languages[current_language]
|
||||
translator = QtCore.QTranslator()
|
||||
translator.load(get_translations_directory() + lang_path)
|
||||
self._app.installTranslator(translator)
|
||||
self._app.translator = translator
|
||||
|
||||
@staticmethod
|
||||
def get_languages():
|
||||
current_locale = QtCore.QLocale()
|
||||
curr_language = current_locale.languageToString(current_locale.language())
|
||||
supported_languages = Settings.supported_languages()
|
||||
|
||||
return curr_language, supported_languages
|
||||
|
||||
def load_app_translations(self):
|
||||
lang = Settings.supported_languages()[self._settings['language']]
|
||||
translator = QtCore.QTranslator()
|
||||
translator.load(curr_directory(__file__) + '/translations/' + lang)
|
||||
translator.load(os.path.join(get_translations_directory(), lang))
|
||||
self._app.installTranslator(translator)
|
||||
self._app.translator = translator
|
||||
|
||||
def try_to_update(self):
|
||||
updating = updater.start_update_if_needed(self._version, self._settings)
|
||||
if updating:
|
||||
data = self._tox.get_savedata()
|
||||
self._profile_manager.save_profile(data)
|
||||
self.save_profile()
|
||||
self._settings.close()
|
||||
del self._tox
|
||||
return updating
|
||||
|
||||
def start_threads(self):
|
||||
# init thread
|
||||
self._init = threads.InitThread(self._tox, self._ms, self._tray)
|
||||
self._init = threads.InitThread(self._tox, self._plugin_loader)
|
||||
self._init.start()
|
||||
|
||||
# starting threads for tox iterate and toxav iterate
|
||||
@ -226,11 +195,52 @@ class App:
|
||||
self._av_loop = threads.ToxAVIterateThread(self._tox.AV)
|
||||
self._av_loop.start()
|
||||
|
||||
threads.start_file_transfer_thread()
|
||||
|
||||
def stop_threads(self):
|
||||
self._init.stop_thread()
|
||||
|
||||
self._main_loop.stop_thread()
|
||||
self._av_loop.stop_thread()
|
||||
self._main_loop.stop_thread()
|
||||
|
||||
threads.stop_file_transfer_thread()
|
||||
|
||||
def create_tox(self, data):
|
||||
return tox_factory(data, self._settings)
|
||||
|
||||
def load_existing_profile(self, profile_path):
|
||||
self._settings = Settings(self._toxes, profile_path.replace('.tox', '.json'))
|
||||
self._profile_manager = ProfileManager(self._settings, self._toxes, profile_path)
|
||||
data = self._profile_manager.open_profile()
|
||||
if self._toxes.is_data_encrypted(data):
|
||||
data = self.enter_pass(data)
|
||||
self._tox = self.create_tox(data)
|
||||
|
||||
def create_new_profile(self, profile_path):
|
||||
name = get_profile_name_from_path(profile_path) or 'toxygen_user'
|
||||
if os.path.isfile(profile_path):
|
||||
util_ui.message_box(util_ui.tr('Profile with this name already exists'),
|
||||
util_ui.tr('Error'))
|
||||
return
|
||||
self._tox = tox_factory()
|
||||
self._tox.self_set_name(bytes(name, 'utf-8') if name else b'Toxygen User')
|
||||
self._tox.self_set_status_message(b'Toxing on Toxygen')
|
||||
# TODO: set profile password
|
||||
self._settings = Settings(self._toxes, self._path.replace('.tox', '.json'))
|
||||
self._profile_manager = ProfileManager(self._settings, self._toxes, profile_path)
|
||||
try:
|
||||
self.save_profile()
|
||||
except Exception as ex:
|
||||
print(ex)
|
||||
log('Profile creation exception: ' + str(ex))
|
||||
text = util_ui.tr('Profile saving error! Does Toxygen have permission to write to this directory?')
|
||||
util_ui.message_box(text, util_ui.tr('Error'))
|
||||
return
|
||||
current_language, supported_languages = self.get_languages()
|
||||
if current_language in supported_languages:
|
||||
self._settings['language'] = current_language
|
||||
self._settings.save()
|
||||
|
||||
def save_profile(self, data=None):
|
||||
data = data or self._tox.get_savedata()
|
||||
self._profile_manager.save_profile(data)
|
||||
|
@ -1,4 +1,3 @@
|
||||
import sys
|
||||
import app
|
||||
from user_data.settings import *
|
||||
from util.util import curr_directory, remove
|
||||
@ -11,7 +10,7 @@ __version__ = '0.5.0'
|
||||
|
||||
def clean():
|
||||
"""Removes all windows libs from libs folder"""
|
||||
d = curr_directory() + '/libs/'
|
||||
d = os.path.join(curr_directory(__file__), 'libs')
|
||||
remove(d)
|
||||
|
||||
|
||||
@ -25,10 +24,11 @@ def print_toxygen_version():
|
||||
|
||||
def main():
|
||||
parser = argparse.ArgumentParser()
|
||||
parser.add_argument('--version', help='Prints Toxygen version')
|
||||
parser.add_argument('--clean', help='Deletes toxcore libs from libs folder')
|
||||
parser.add_argument('--reset', help='Resets default profile')
|
||||
parser.add_argument('profile_path', nargs='?', default=None, help='Resets default profile')
|
||||
parser.add_argument('--version', action='store_true', help='Prints Toxygen version')
|
||||
parser.add_argument('--clean', action='store_true', help='Deletes toxcore libs from libs folder')
|
||||
parser.add_argument('--reset', action='store_true', help='Resets default profile')
|
||||
parser.add_argument('--uri', help='Adds specified TOX ID to friends')
|
||||
parser.add_argument('profile', nargs='?', default=None, help='Path to TOX profile')
|
||||
args = parser.parse_args()
|
||||
|
||||
if args.version:
|
||||
@ -43,7 +43,7 @@ def main():
|
||||
reset()
|
||||
return
|
||||
|
||||
toxygen = app.App(__version__, path_to_profile=args.profile_path)
|
||||
toxygen = app.App(__version__, args.profile, args.uri)
|
||||
toxygen.main()
|
||||
|
||||
|
||||
|
@ -1,15 +1,18 @@
|
||||
from PyQt5 import QtGui
|
||||
from PyQt5 import QtGui, QtCore
|
||||
from user_data.settings import Settings
|
||||
from contacts.profile import Profile
|
||||
from wrapper.toxcore_enums_and_consts import *
|
||||
from wrapper.toxav_enums import *
|
||||
from wrapper.tox import bin_to_string
|
||||
from plugin_support.plugin_support import PluginLoader
|
||||
import util.ui as util_ui
|
||||
import util.util as util
|
||||
import cv2
|
||||
import numpy as np
|
||||
from middleware.threads import invoke_in_main_thread, execute
|
||||
from notifications.tray import tray_notification
|
||||
from notifications.sound import *
|
||||
|
||||
# TODO: use closures
|
||||
# TODO: gc callbacks and refactoring
|
||||
|
||||
# -----------------------------------------------------------------------------------------------------------------
|
||||
# Callbacks - current user
|
||||
@ -111,7 +114,8 @@ def friend_message(profile, settings, window, tray):
|
||||
invoke_in_main_thread(tray_notification, friend.name, message, tray, window)
|
||||
if settings['sound_notifications'] and profile.status != TOX_USER_STATUS['BUSY']:
|
||||
sound_notification(SOUND_NOTIFICATION['MESSAGE'])
|
||||
invoke_in_main_thread(tray.setIcon, QtGui.QIcon(curr_directory() + '/images/icon_new_messages.png'))
|
||||
icon = os.path.join(util.get_images_directory(), 'icon_new_messages.png')
|
||||
invoke_in_main_thread(tray.setIcon, QtGui.QIcon(icon))
|
||||
|
||||
return wrapped
|
||||
|
||||
@ -169,11 +173,12 @@ def tox_file_recv(window, tray, profile, file_transfer_handler, contacts_manager
|
||||
if not window.isActiveWindow():
|
||||
friend = contacts_manager.get_friend_by_number(friend_number)
|
||||
if settings['notifications'] and profile.status != TOX_USER_STATUS['BUSY'] and not settings.locked:
|
||||
file_from = QtWidgets.QApplication.translate("Callback", "File from")
|
||||
file_from = util_ui.tr("File from")
|
||||
invoke_in_main_thread(tray_notification, file_from + ' ' + friend.name, file_name, tray, window)
|
||||
if settings['sound_notifications'] and profile.status != TOX_USER_STATUS['BUSY']:
|
||||
sound_notification(SOUND_NOTIFICATION['FILE_TRANSFER'])
|
||||
invoke_in_main_thread(tray.setIcon, QtGui.QIcon(curr_directory() + '/images/icon_new_messages.png'))
|
||||
icon = os.path.join(util.get_images_directory(), 'icon_new_messages.png')
|
||||
invoke_in_main_thread(tray.setIcon, QtGui.QIcon(icon))
|
||||
else: # AVATAR
|
||||
print('Avatar')
|
||||
invoke_in_main_thread(file_transfer_handler.incoming_avatar,
|
||||
@ -240,8 +245,7 @@ def lossy_packet(plugin_loader):
|
||||
Incoming lossy packet
|
||||
"""
|
||||
data = data[:length]
|
||||
plugin = PluginLoader.get_instance()
|
||||
invoke_in_main_thread(plugin.callback_lossy, friend_number, data)
|
||||
invoke_in_main_thread(plugin_loader.callback_lossy, friend_number, data)
|
||||
|
||||
return wrapped
|
||||
|
||||
@ -358,7 +362,8 @@ def show_gc_notification(window, tray, message, group_number, peer_number):
|
||||
invoke_in_main_thread(tray_notification, chat.name + ' ' + peer_name, message, tray, window)
|
||||
if settings['sound_notifications'] and profile.status != TOX_USER_STATUS['BUSY']:
|
||||
sound_notification(SOUND_NOTIFICATION['MESSAGE'])
|
||||
invoke_in_main_thread(tray.setIcon, QtGui.QIcon(curr_directory() + '/images/icon_new_messages.png'))
|
||||
icon = os.path.join(util.get_images_directory(), 'icon_new_messages.png')
|
||||
invoke_in_main_thread(tray.setIcon, QtGui.QIcon(icon))
|
||||
|
||||
# -----------------------------------------------------------------------------------------------------------------
|
||||
# Callbacks - initialization
|
||||
@ -366,17 +371,20 @@ def show_gc_notification(window, tray, message, group_number, peer_number):
|
||||
|
||||
|
||||
def init_callbacks(tox, profile, settings, plugin_loader, contacts_manager,
|
||||
calls_manager, file_transfer_handler, window, tray):
|
||||
calls_manager, file_transfer_handler, main_window, tray):
|
||||
"""
|
||||
Initialization of all callbacks.
|
||||
:param tox: tox instance
|
||||
:param window: main window
|
||||
:param tox: Tox instance
|
||||
:param profile: Profile instance
|
||||
:param settings: Settings instance
|
||||
:param plugin_loader: PluginLoader instance
|
||||
:param main_window: main window screen
|
||||
:param tray: tray (for notifications)
|
||||
"""
|
||||
tox.callback_self_connection_status(self_connection_status(tox, profile), 0)
|
||||
|
||||
tox.callback_friend_status(friend_status(profile, settings), 0)
|
||||
tox.callback_friend_message(friend_message(profile, settings, window, tray), 0)
|
||||
tox.callback_friend_message(friend_message(profile, settings, main_window, tray), 0)
|
||||
tox.callback_friend_connection_status(friend_connection_status(profile, settings, plugin_loader), 0)
|
||||
tox.callback_friend_name(friend_name(profile), 0)
|
||||
tox.callback_friend_status_message(friend_status_message(profile), 0)
|
||||
@ -384,11 +392,13 @@ def init_callbacks(tox, profile, settings, plugin_loader, contacts_manager,
|
||||
tox.callback_friend_typing(friend_typing(contacts_manager), 0)
|
||||
tox.callback_friend_read_receipt(friend_read_receipt(contacts_manager), 0)
|
||||
|
||||
tox.callback_file_recv(tox_file_recv(window, tray, profile, file_transfer_handler, contacts_manager, settings), 0)
|
||||
tox.callback_file_recv(tox_file_recv(main_window, tray, profile, file_transfer_handler,
|
||||
contacts_manager, settings), 0)
|
||||
tox.callback_file_recv_chunk(file_recv_chunk(file_transfer_handler), 0)
|
||||
tox.callback_file_chunk_request(file_chunk_request(file_transfer_handler), 0)
|
||||
tox.callback_file_recv_control(file_recv_control(file_transfer_handler), 0)
|
||||
|
||||
toxav = tox.AV
|
||||
toxav.callback_call_state(call_state(calls_manager), 0)
|
||||
toxav.callback_call(call(calls_manager), 0)
|
||||
toxav.callback_audio_receive_frame(callback_audio(calls_manager), 0)
|
||||
|
@ -9,44 +9,44 @@ class BaseThread(threading.Thread):
|
||||
|
||||
def __init__(self):
|
||||
super().__init__()
|
||||
self._stop = False
|
||||
self._stop_thread = False
|
||||
|
||||
def stop_thread(self):
|
||||
self._stop = True
|
||||
self._stop_thread = True
|
||||
self.join()
|
||||
|
||||
|
||||
class InitThread(BaseThread):
|
||||
|
||||
def __init__(self, tox, ms, tray):
|
||||
def __init__(self, tox, plugin_loader):
|
||||
super().__init__()
|
||||
self.tox, self.ms, self.tray = tox, ms, tray
|
||||
self._tox, self._plugin_loader = tox, plugin_loader
|
||||
|
||||
def run(self):
|
||||
# initializing callbacks
|
||||
init_callbacks(self.tox, self.ms, self.tray)
|
||||
# download list of nodes if needed
|
||||
download_nodes_list()
|
||||
# start plugins
|
||||
self._plugin_loader.load()
|
||||
# bootstrap
|
||||
try:
|
||||
for data in generate_nodes():
|
||||
if self._stop:
|
||||
if self._stop_thread:
|
||||
return
|
||||
self.tox.bootstrap(*data)
|
||||
self.tox.add_tcp_relay(*data)
|
||||
self._tox.bootstrap(*data)
|
||||
self._tox.add_tcp_relay(*data)
|
||||
except:
|
||||
pass
|
||||
for _ in range(10):
|
||||
if self._stop:
|
||||
if self._stop_thread:
|
||||
return
|
||||
time.sleep(1)
|
||||
while not self.tox.self_get_connection_status():
|
||||
while not self._tox.self_get_connection_status():
|
||||
try:
|
||||
for data in generate_nodes():
|
||||
if self._stop:
|
||||
if self._stop_thread:
|
||||
return
|
||||
self.tox.bootstrap(*data)
|
||||
self.tox.add_tcp_relay(*data)
|
||||
self._tox.bootstrap(*data)
|
||||
self._tox.add_tcp_relay(*data)
|
||||
except:
|
||||
pass
|
||||
finally:
|
||||
@ -60,7 +60,7 @@ class ToxIterateThread(BaseThread):
|
||||
self._tox = tox
|
||||
|
||||
def run(self):
|
||||
while not self._stop:
|
||||
while not self._stop_thread:
|
||||
self._tox.iterate()
|
||||
time.sleep(self._tox.iteration_interval() / 1000)
|
||||
|
||||
@ -72,7 +72,7 @@ class ToxAVIterateThread(BaseThread):
|
||||
self._toxav = toxav
|
||||
|
||||
def run(self):
|
||||
while not self._stop:
|
||||
while not self._stop_thread:
|
||||
self._toxav.iterate()
|
||||
time.sleep(self._toxav.iteration_interval() / 1000)
|
||||
|
||||
@ -88,7 +88,7 @@ class FileTransfersThread(BaseThread):
|
||||
self._queue.put((func, args, kwargs))
|
||||
|
||||
def run(self):
|
||||
while not self._stop:
|
||||
while not self._stop_thread:
|
||||
try:
|
||||
func, args, kwargs = self._queue.get(timeout=self._timeout)
|
||||
func(*args, **kwargs)
|
||||
@ -103,11 +103,11 @@ class FileTransfersThread(BaseThread):
|
||||
_thread = FileTransfersThread()
|
||||
|
||||
|
||||
def start():
|
||||
def start_file_transfer_thread():
|
||||
_thread.start()
|
||||
|
||||
|
||||
def stop():
|
||||
def stop_file_transfer_thread():
|
||||
_thread.stop_thread()
|
||||
|
||||
|
||||
|
@ -1,9 +1,7 @@
|
||||
from platform import system
|
||||
import json
|
||||
import os
|
||||
from util.util import log, curr_directory, append_slash
|
||||
from util.util import log, get_base_directory, append_slash, get_platform
|
||||
import pyaudio
|
||||
from user_data.toxes import ToxES
|
||||
import smileys.smileys as smileys
|
||||
|
||||
|
||||
@ -60,7 +58,7 @@ class Settings(dict):
|
||||
name = str(auto['name'])
|
||||
if os.path.isfile(append_slash(path) + name + '.tox'):
|
||||
return path, name
|
||||
return '', ''
|
||||
return None
|
||||
|
||||
@staticmethod
|
||||
def set_auto_profile(path, name):
|
||||
@ -92,9 +90,8 @@ class Settings(dict):
|
||||
fl.write(json.dumps(data))
|
||||
|
||||
@staticmethod
|
||||
def is_active_profile(path, name):
|
||||
path = path + name + '.lock'
|
||||
return os.path.isfile(path)
|
||||
def is_active_profile(profile_path):
|
||||
return os.path.isfile(profile_path + '.lock')
|
||||
|
||||
@staticmethod
|
||||
def get_default_settings():
|
||||
@ -204,13 +201,14 @@ class Settings(dict):
|
||||
|
||||
@staticmethod
|
||||
def get_global_settings_path():
|
||||
return curr_directory() + '/toxygen.json'
|
||||
return os.path.join(get_base_directory(), 'toxygen.json')
|
||||
|
||||
@staticmethod
|
||||
def get_default_path():
|
||||
if system() == 'Windows':
|
||||
system = get_platform()
|
||||
if system == 'Windows':
|
||||
return os.getenv('APPDATA') + '/Tox/'
|
||||
elif system() == 'Darwin':
|
||||
elif system == 'Darwin':
|
||||
return os.getenv('HOME') + '/Library/Application Support/Tox/'
|
||||
else:
|
||||
return os.getenv('HOME') + '/.config/tox/'
|
||||
|
Loading…
Reference in New Issue
Block a user