summaryrefslogtreecommitdiff
path: root/src/core/commands.py
diff options
context:
space:
mode:
authormathieui <mathieui@mathieui.net>2014-10-20 23:24:27 +0200
committermathieui <mathieui@mathieui.net>2014-10-20 23:24:27 +0200
commit9d58c9d32ea67364933b1980c374237de6c3646d (patch)
tree8fd79b67067fe2f1e0eed788da2422a83dd0a0a8 /src/core/commands.py
parent6b8af2413e47fc13796ea061ff759d7c1ca74c5c (diff)
downloadpoezio-9d58c9d32ea67364933b1980c374237de6c3646d.tar.gz
poezio-9d58c9d32ea67364933b1980c374237de6c3646d.tar.bz2
poezio-9d58c9d32ea67364933b1980c374237de6c3646d.tar.xz
poezio-9d58c9d32ea67364933b1980c374237de6c3646d.zip
Fix #2719 (write/read in the plugin config files even when not loaded)
Diffstat (limited to 'src/core/commands.py')
-rw-r--r--src/core/commands.py20
1 files changed, 14 insertions, 6 deletions
diff --git a/src/core/commands.py b/src/core/commands.py
index b44f3483..d212de9b 100644
--- a/src/core/commands.py
+++ b/src/core/commands.py
@@ -6,6 +6,7 @@ import logging
log = logging.getLogger(__name__)
+import os
import sys
from datetime import datetime
from gettext import gettext as _
@@ -23,6 +24,7 @@ import tabs
from common import safeJID
from config import config, options as config_opts
import multiuserchat as muc
+from plugin import PluginConfig
from roster import roster
from theming import dump_tuple, get_theme
@@ -600,9 +602,12 @@ def command_set(self, arg):
section = plugin_name
option = args[1]
if not plugin_name in self.plugin_manager.plugins:
- return
- plugin = self.plugin_manager.plugins[plugin_name]
- value = plugin.config.get(option, default='', section=section)
+ file_name = self.plugin_manager.plugins_conf_dir
+ file_name = os.path.join(file_name, plugin_name + '.cfg')
+ plugin_config = PluginConfig(file_name, plugin_name)
+ else:
+ plugin_config = self.plugin_manager.plugins[plugin_name].config
+ value = plugin_config.get(option, default='', section=section)
info = ('%s=%s' % (option, value), 'Info')
else:
possible_section = args[0]
@@ -624,9 +629,12 @@ def command_set(self, arg):
option = args[1]
value = args[2]
if not plugin_name in self.plugin_manager.plugins:
- return
- plugin = self.plugin_manager.plugins[plugin_name]
- info = plugin.config.set_and_save(option, value, section)
+ file_name = self.plugin_manager.plugins_conf_dir
+ file_name = os.path.join(file_name, plugin_name + '.cfg')
+ plugin_config = PluginConfig(file_name, plugin_name)
+ else:
+ plugin_config = self.plugin_manager.plugins[plugin_name].config
+ info = plugin_config.set_and_save(option, value, section)
else:
section = args[0]
option = args[1]