mirror of
https://github.com/LBRYFoundation/LBRY-Vault.git
synced 2025-09-01 09:45:18 +00:00
Added SimpleConfig class to deal with simple config options added for fallback to other gui when missing deps
This commit is contained in:
parent
23d314462f
commit
3252b5ae4e
3 changed files with 50 additions and 2 deletions
11
electrum
11
electrum
|
@ -40,8 +40,9 @@ try:
|
||||||
from lib import Wallet, WalletSynchronizer, format_satoshis, mnemonic, prompt_password
|
from lib import Wallet, WalletSynchronizer, format_satoshis, mnemonic, prompt_password
|
||||||
except ImportError:
|
except ImportError:
|
||||||
from electrum import Wallet, WalletSynchronizer, format_satoshis, mnemonic, prompt_password
|
from electrum import Wallet, WalletSynchronizer, format_satoshis, mnemonic, prompt_password
|
||||||
|
|
||||||
from decimal import Decimal
|
from decimal import Decimal
|
||||||
|
from lib import SimpleConfig
|
||||||
|
|
||||||
known_commands = {
|
known_commands = {
|
||||||
'help':'Prints this help',
|
'help':'Prints this help',
|
||||||
|
@ -101,9 +102,12 @@ protected_commands = ['payto', 'password', 'mktx', 'seed', 'import','signmessage
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|
||||||
|
# Load simple config class
|
||||||
|
simple_config = SimpleConfig()
|
||||||
|
|
||||||
usage = "usage: %prog [options] command\nCommands: "+ (', '.join(known_commands))
|
usage = "usage: %prog [options] command\nCommands: "+ (', '.join(known_commands))
|
||||||
parser = optparse.OptionParser(prog=usage)
|
parser = optparse.OptionParser(prog=usage)
|
||||||
parser.add_option("-g", "--gui", dest="gui", default="lite", help="gui")
|
parser.add_option("-g", "--gui", dest="gui", default=simple_config.config["gui"], help="gui")
|
||||||
parser.add_option("-w", "--wallet", dest="wallet_path", help="wallet path (default: electrum.dat)")
|
parser.add_option("-w", "--wallet", dest="wallet_path", help="wallet path (default: electrum.dat)")
|
||||||
parser.add_option("-o", "--offline", action="store_true", dest="offline", default=False, help="remain offline")
|
parser.add_option("-o", "--offline", action="store_true", dest="offline", default=False, help="remain offline")
|
||||||
parser.add_option("-a", "--all", action="store_true", dest="show_all", default=False, help="show all addresses")
|
parser.add_option("-a", "--all", action="store_true", dest="show_all", default=False, help="show all addresses")
|
||||||
|
@ -115,6 +119,7 @@ if __name__ == '__main__':
|
||||||
parser.add_option("-r", "--remote", dest="remote_url", default=None, help="URL of a remote wallet")
|
parser.add_option("-r", "--remote", dest="remote_url", default=None, help="URL of a remote wallet")
|
||||||
options, args = parser.parse_args()
|
options, args = parser.parse_args()
|
||||||
|
|
||||||
|
|
||||||
wallet = Wallet()
|
wallet = Wallet()
|
||||||
wallet.set_path(options.wallet_path)
|
wallet.set_path(options.wallet_path)
|
||||||
wallet.read()
|
wallet.read()
|
||||||
|
@ -161,6 +166,8 @@ if __name__ == '__main__':
|
||||||
error_message = QErrorMessage()
|
error_message = QErrorMessage()
|
||||||
error_message.setFixedSize(350,200)
|
error_message.setFixedSize(350,200)
|
||||||
error_message.showMessage("<p>Sorry, the Electrum 'Lite GUI' requires Qt >= 4.7 to run. The pro GUI will be started instead.</p><p>Check your distributions packages for upgrades.</p>")
|
error_message.showMessage("<p>Sorry, the Electrum 'Lite GUI' requires Qt >= 4.7 to run. The pro GUI will be started instead.</p><p>Check your distributions packages for upgrades.</p>")
|
||||||
|
simple_config.config["gui"] = "qt"
|
||||||
|
simple_config.save_config
|
||||||
app.exec_()
|
app.exec_()
|
||||||
|
|
||||||
try:
|
try:
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
from wallet import Wallet, format_satoshis, prompt_password
|
from wallet import Wallet, format_satoshis, prompt_password
|
||||||
from interface import WalletSynchronizer
|
from interface import WalletSynchronizer
|
||||||
from interface import TcpStratumInterface
|
from interface import TcpStratumInterface
|
||||||
|
from simple_config import SimpleConfig
|
||||||
|
|
40
lib/simple_config.py
Normal file
40
lib/simple_config.py
Normal file
|
@ -0,0 +1,40 @@
|
||||||
|
import json
|
||||||
|
import os
|
||||||
|
|
||||||
|
class SimpleConfig:
|
||||||
|
default_options = {"gui": "lite"}
|
||||||
|
|
||||||
|
def save_config(self):
|
||||||
|
f = open(self.config_file_path(), "w+")
|
||||||
|
f.write(json.dumps(self.config))
|
||||||
|
|
||||||
|
def load_config(self):
|
||||||
|
f = open(self.config_file_path(), "r")
|
||||||
|
file_contents = f.read()
|
||||||
|
if file_contents:
|
||||||
|
self.config = json.loads(file_contents)
|
||||||
|
else:
|
||||||
|
self.config = self.default_options
|
||||||
|
self.save_config()
|
||||||
|
|
||||||
|
def config_file_path(self):
|
||||||
|
return "%s" % (self.config_folder + "/config.json")
|
||||||
|
|
||||||
|
def __init__(self):
|
||||||
|
# Find electrum data folder
|
||||||
|
if "HOME" in os.environ:
|
||||||
|
self.config_folder = os.path.join(os.environ["HOME"], ".electrum")
|
||||||
|
elif "LOCALAPPDATA" in os.environ:
|
||||||
|
self.config_folder = os.path.join(os.environ["LOCALAPPDATA"], "Electrum")
|
||||||
|
elif "APPDATA" in os.environ:
|
||||||
|
self.config_folder = os.path.join(os.environ["APPDATA"], "Electrum")
|
||||||
|
else:
|
||||||
|
raise BaseException("No home directory found in environment variables.")
|
||||||
|
|
||||||
|
# Read the file
|
||||||
|
if os.path.exists(self.config_file_path()):
|
||||||
|
self.load_config()
|
||||||
|
else:
|
||||||
|
self.config = self.default_options
|
||||||
|
self.save_config()
|
||||||
|
|
Loading…
Add table
Reference in a new issue