plugins: do not overload __init__, use init() instead
This commit is contained in:
@@ -345,7 +345,8 @@ class ElectrumWindow(QMainWindow):
|
||||
self.notify_transactions()
|
||||
|
||||
# plugins that need to change the GUI do it here
|
||||
self.run_hook('init_gui')
|
||||
self.run_hook('init')
|
||||
|
||||
|
||||
def select_wallet_file(self):
|
||||
wallet_folder = self.wallet.config.path
|
||||
@@ -494,9 +495,9 @@ class ElectrumWindow(QMainWindow):
|
||||
plugins = [ __import__('electrum_plugins.'+name, fromlist=['electrum_plugins']) for name in plugin_names]
|
||||
|
||||
self.plugins = []
|
||||
for p in plugins:
|
||||
for name, p in zip(plugin_names, plugins):
|
||||
try:
|
||||
self.plugins.append( p.Plugin(self) )
|
||||
self.plugins.append( p.Plugin(self, name) )
|
||||
except:
|
||||
print_msg("Error:cannot initialize plugin",p)
|
||||
traceback.print_exc(file=sys.stdout)
|
||||
@@ -2161,15 +2162,14 @@ class ElectrumWindow(QMainWindow):
|
||||
return lambda: cb.setChecked(p.toggle())
|
||||
for i, p in enumerate(self.plugins):
|
||||
try:
|
||||
name, description = p.get_info()
|
||||
cb = QCheckBox(name)
|
||||
cb = QCheckBox(p.fullname())
|
||||
cb.setDisabled(not p.is_available())
|
||||
cb.setChecked(p.is_enabled())
|
||||
cb.clicked.connect(mk_toggle(cb,p))
|
||||
grid_plugins.addWidget(cb, i, 0)
|
||||
if p.requires_settings():
|
||||
grid_plugins.addWidget(EnterButton(_('Settings'), p.settings_dialog), i, 1)
|
||||
grid_plugins.addWidget(HelpButton(description), i, 2)
|
||||
grid_plugins.addWidget(HelpButton(p.description()), i, 2)
|
||||
except:
|
||||
print_msg("Error: cannot display plugin", p)
|
||||
traceback.print_exc(file=sys.stdout)
|
||||
|
||||
@@ -2,27 +2,42 @@
|
||||
|
||||
class BasePlugin:
|
||||
|
||||
def get_info(self):
|
||||
return self.fullname, self.description
|
||||
|
||||
def __init__(self, gui, name, fullname, description):
|
||||
self.name = name
|
||||
self.fullname = fullname
|
||||
self.description = description
|
||||
def __init__(self, gui, name):
|
||||
self.gui = gui
|
||||
self.name = name
|
||||
self.config = gui.config
|
||||
|
||||
def fullname(self):
|
||||
return self.name
|
||||
|
||||
def description(self):
|
||||
return 'undefined'
|
||||
|
||||
def requires_settings(self):
|
||||
return False
|
||||
|
||||
def toggle(self):
|
||||
enabled = not self.is_enabled()
|
||||
self.set_enabled(enabled)
|
||||
self.init_gui()
|
||||
return enabled
|
||||
if self.is_enabled():
|
||||
if self.disable():
|
||||
self.close()
|
||||
else:
|
||||
if self.enable():
|
||||
self.init()
|
||||
|
||||
return self.is_enabled()
|
||||
|
||||
|
||||
def init_gui(self):
|
||||
pass
|
||||
def enable(self):
|
||||
self.set_enabled(True)
|
||||
return True
|
||||
|
||||
def disable(self):
|
||||
self.set_enabled(False)
|
||||
return True
|
||||
|
||||
def init(self): pass
|
||||
|
||||
def close(self): pass
|
||||
|
||||
def is_enabled(self):
|
||||
return self.is_available() and self.config.get('use_'+self.name) is True
|
||||
|
||||
Reference in New Issue
Block a user