new simple optparser. *break* old configuration file compatibility.
This commit is contained in:
parent
d415620b13
commit
92a4fea8a9
|
@ -1,8 +1,8 @@
|
||||||
## common/optparser.py
|
#!/usr/bin/python
|
||||||
##
|
##
|
||||||
## Gajim Team:
|
## Gajim Team:
|
||||||
## - Yann Le Boulanger <asterix@lagaule.org>
|
## - Yann Le Boulanger <asterix@lagaule.org>
|
||||||
## - Vincent Hanquez <tab@snarc.org>
|
## - Vincent Hanquez <tab@snarc.org>
|
||||||
##
|
##
|
||||||
## Copyright (C) 2003-2005 Gajim Team
|
## Copyright (C) 2003-2005 Gajim Team
|
||||||
##
|
##
|
||||||
|
@ -17,194 +17,58 @@
|
||||||
##
|
##
|
||||||
|
|
||||||
import os
|
import os
|
||||||
from common import connection
|
|
||||||
from common import gajim
|
from common import gajim
|
||||||
|
|
||||||
class OptionsParser:
|
class OptionsParser:
|
||||||
def __init__(self, fname):
|
def __init__(self, filename):
|
||||||
self.__fname = os.path.expanduser(fname)
|
self.__filename = os.path.expanduser(filename)
|
||||||
self.tab = {}
|
|
||||||
# END __init__
|
|
||||||
|
|
||||||
def parseCfgFile(self):
|
def read_line(self, line):
|
||||||
try:
|
index = line.find(" = ")
|
||||||
fd = open(self.__fname)
|
var_str = line[0:index]
|
||||||
except:
|
value_str = line[index + 3:-1]
|
||||||
print 'error cannot open file %s\n' % (self.__fname);
|
|
||||||
return
|
i_start = var_str.find('.')
|
||||||
|
i_end = var_str.rfind('.')
|
||||||
section = ''
|
|
||||||
for line in fd.readlines():
|
if i_start == -1:
|
||||||
if line[0] in "#;":
|
gajim.config.set(var_str, value_str)
|
||||||
continue
|
|
||||||
if line[0] == '[':
|
|
||||||
section = line[1:line.find(']')]
|
|
||||||
self.tab[section] = {}
|
|
||||||
continue
|
|
||||||
index = line.find('=')
|
|
||||||
if index == -1:
|
|
||||||
continue
|
|
||||||
option = line[0:index]
|
|
||||||
option = option.strip()
|
|
||||||
value = line[index+2:-1]
|
|
||||||
if option.find('password') == -1:
|
|
||||||
if value == 'False':
|
|
||||||
self.tab[section][option] = False
|
|
||||||
elif value == 'True':
|
|
||||||
self.tab[section][option] = True
|
|
||||||
else:
|
|
||||||
try:
|
|
||||||
i = int(value)
|
|
||||||
except ValueError:
|
|
||||||
self.tab[section][option] = value
|
|
||||||
else:
|
|
||||||
self.tab[section][option] = i
|
|
||||||
else:
|
|
||||||
self.tab[section][option] = value
|
|
||||||
fd.close()
|
|
||||||
# END parseCfgFile
|
|
||||||
|
|
||||||
def _fill_config_key(self, section, option, key):
|
|
||||||
if not self.tab.has_key(section):
|
|
||||||
return
|
|
||||||
if not self.tab[section].has_key(option):
|
|
||||||
return
|
|
||||||
gajim.config.set(key, self.tab[section][option])
|
|
||||||
|
|
||||||
def fill_config(self):
|
|
||||||
self._fill_config_key('Profile', 'log', 'log')
|
|
||||||
self._fill_config_key('Core', 'delauth', 'delauth')
|
|
||||||
self._fill_config_key('Core', 'delroster', 'delroster')
|
|
||||||
self._fill_config_key('Core', 'alwaysauth', 'alwaysauth')
|
|
||||||
self._fill_config_key('Logger', 'lognotsep', 'lognotsep')
|
|
||||||
self._fill_config_key('Logger', 'lognotusr', 'lognotusr')
|
|
||||||
|
|
||||||
if self.tab.has_key('GtkGui'):
|
|
||||||
for k in self.tab['GtkGui']:
|
|
||||||
self._fill_config_key('GtkGui', k, k)
|
|
||||||
# status messages
|
|
||||||
for msg in gajim.config.get_per('statusmsg'):
|
|
||||||
gajim.config.del_per('statusmsg', msg)
|
|
||||||
i = 0
|
|
||||||
while self.tab['GtkGui'].has_key('msg%s_name' % i):
|
|
||||||
gajim.config.add_per('statusmsg', self.tab['GtkGui']['msg%s_name' \
|
|
||||||
% i])
|
|
||||||
gajim.config.set_per('statusmsg', self.tab['GtkGui']['msg%s_name' \
|
|
||||||
% i], 'message', self.tab['GtkGui']['msg%s' % i])
|
|
||||||
i += 1
|
|
||||||
# emoticons
|
|
||||||
if self.tab['GtkGui'].has_key('emoticons'):
|
|
||||||
for emot in gajim.config.get_per('emoticons'):
|
|
||||||
gajim.config.del_per('emoticons', emot)
|
|
||||||
emots = self.tab['GtkGui']['emoticons'].split('\t')
|
|
||||||
for i in range(0, len(emots)/2):
|
|
||||||
gajim.config.add_per('emoticons', emots[2*i])
|
|
||||||
gajim.config.set_per('emoticons', emots[2*i], 'path', \
|
|
||||||
emots[2*i+1])
|
|
||||||
# sound events
|
|
||||||
for event in gajim.config.get_per('soundevents'):
|
|
||||||
gajim.config.del_per('soundevents', event)
|
|
||||||
for key in self.tab['GtkGui']:
|
|
||||||
if key.find('sound_'):
|
|
||||||
continue
|
|
||||||
if not self.tab['GtkGui'].has_key(key + '_file'):
|
|
||||||
continue
|
|
||||||
event = key[6:]
|
|
||||||
gajim.config.add_per('soundevents', event)
|
|
||||||
gajim.config.set_per('soundevents', event, 'enabled', \
|
|
||||||
self.tab['GtkGui'][key])
|
|
||||||
gajim.config.set_per('soundevents', event, 'path', \
|
|
||||||
self.tab['GtkGui'][key + '_file'])
|
|
||||||
|
|
||||||
# accounts
|
|
||||||
if self.tab.has_key('Profile'):
|
|
||||||
if self.tab['Profile'].has_key('accounts'):
|
|
||||||
accounts = self.tab['Profile']['accounts'].split()
|
|
||||||
else:
|
else:
|
||||||
return
|
optname = var_str[0:i_start]
|
||||||
for account in accounts:
|
key = var_str[i_start + 1:i_end]
|
||||||
if not self.tab.has_key(account):
|
subname = var_str[i_end + 1:]
|
||||||
continue
|
gajim.config.add_per(optname, key)
|
||||||
gajim.connections[account] = connection.Connection(account)
|
gajim.config.set_per(optname, key, subname, value_str)
|
||||||
gajim.config.add_per('accounts', account)
|
|
||||||
for key in self.tab[account]:
|
|
||||||
gajim.config.set_per('accounts', account, key, \
|
|
||||||
self.tab[account][key])
|
|
||||||
if gajim.config.get_per('accounts', account, 'savepass'):
|
|
||||||
gajim.connections[account].password = gajim.config.get_per( \
|
|
||||||
'accounts', account, 'password')
|
|
||||||
|
|
||||||
def read_config(self):
|
|
||||||
self.tab = {}
|
|
||||||
self.tab['Profile'] = {}
|
|
||||||
self.tab['Profile']['log'] = gajim.config.get('log')
|
|
||||||
|
|
||||||
self.tab['Core'] = {}
|
def read(self):
|
||||||
self.tab['Core']['delauth'] = gajim.config.get('delauth')
|
|
||||||
self.tab['Core']['delroster'] = gajim.config.get('delroster')
|
|
||||||
self.tab['Core']['alwaysauth'] = gajim.config.get('alwaysauth')
|
|
||||||
|
|
||||||
self.tab['Logger'] = {}
|
|
||||||
self.tab['Logger']['lognotsep'] = gajim.config.get('lognotsep')
|
|
||||||
self.tab['Logger']['lognotusr'] = gajim.config.get('lognotusr')
|
|
||||||
|
|
||||||
self.tab['GtkGui'] = {}
|
|
||||||
for key in gajim.config.get(None):
|
|
||||||
if key in self.tab['Profile']:
|
|
||||||
continue
|
|
||||||
if key in self.tab['Core']:
|
|
||||||
continue
|
|
||||||
if key in self.tab['Logger']:
|
|
||||||
continue
|
|
||||||
self.tab['GtkGui'][key] = gajim.config.get(key)
|
|
||||||
|
|
||||||
# status messages
|
|
||||||
i = 0
|
|
||||||
for msg in gajim.config.get_per('statusmsg'):
|
|
||||||
self.tab['GtkGui']['msg%s_name' % i] = msg
|
|
||||||
self.tab['GtkGui']['msg%s' % i] = gajim.config.get_per('statusmsg', \
|
|
||||||
msg, 'message')
|
|
||||||
i += 1
|
|
||||||
|
|
||||||
# sounds
|
|
||||||
for event in gajim.config.get_per('soundevents'):
|
|
||||||
self.tab['GtkGui']['sound_' + event] = gajim.config.get_per( \
|
|
||||||
'soundevents', event, 'enabled')
|
|
||||||
self.tab['GtkGui']['sound_' + event + '_file'] = gajim.config.get_per(\
|
|
||||||
'soundevents', event, 'path')
|
|
||||||
|
|
||||||
# emoticons
|
|
||||||
emots = []
|
|
||||||
for emot in gajim.config.get_per('emoticons'):
|
|
||||||
emots.append(emot)
|
|
||||||
emots.append(gajim.config.get_per('emoticons', emot, 'path'))
|
|
||||||
self.tab['GtkGui']['emoticons'] = '\t'.join(emots)
|
|
||||||
|
|
||||||
# accounts
|
|
||||||
accounts = gajim.config.get_per('accounts')
|
|
||||||
self.tab['Profile']['accounts'] = ' '.join(accounts)
|
|
||||||
for account in accounts:
|
|
||||||
self.tab[account] = {}
|
|
||||||
for key in gajim.config.get_per('accounts', account):
|
|
||||||
self.tab[account][key] = gajim.config.get_per('accounts', account, \
|
|
||||||
key)
|
|
||||||
|
|
||||||
def writeCfgFile(self):
|
|
||||||
try:
|
try:
|
||||||
fd = open(self.__fname, 'w')
|
fd = open(self.__filename)
|
||||||
except:
|
except:
|
||||||
log.debug('Can\'t write config %s' % self.__fname)
|
print "error: cannot open %s\n" % (self.__filename)
|
||||||
return 0
|
return
|
||||||
index = 0
|
|
||||||
for s in self.tab.keys():
|
|
||||||
if index == 0:
|
|
||||||
fd.write('[' + s + ']\n')
|
|
||||||
else:
|
|
||||||
fd.write('\n[' + s + ']\n')
|
|
||||||
for o in self.tab[s].keys():
|
|
||||||
fd.write(o + ' = ' + str(self.tab[s][o]) + '\n')
|
|
||||||
index += 1
|
|
||||||
return 1
|
|
||||||
# END writeCfgFile
|
|
||||||
|
|
||||||
# END OptionsParser
|
for line in fd.readlines():
|
||||||
|
self.read_line(line)
|
||||||
|
|
||||||
|
fd.close()
|
||||||
|
|
||||||
|
def write_line(self, fd, opt, parents, value):
|
||||||
|
s = ""
|
||||||
|
if parents:
|
||||||
|
if len(parents) == 1:
|
||||||
|
return
|
||||||
|
for p in parents:
|
||||||
|
s += p + "."
|
||||||
|
if value == None:
|
||||||
|
return
|
||||||
|
s += opt
|
||||||
|
fd.write(s + " = " + str(value[1]) + "\n")
|
||||||
|
|
||||||
|
def write(self):
|
||||||
|
try:
|
||||||
|
fd = open(self.__filename, 'w')
|
||||||
|
except:
|
||||||
|
print "error: cannot open %s\n" % (self.__filename)
|
||||||
|
return
|
||||||
|
gajim.config.foreach(self.write_line, fd)
|
||||||
|
fd.close()
|
||||||
|
|
|
@ -634,8 +634,8 @@ class Interface:
|
||||||
sys.exit()
|
sys.exit()
|
||||||
|
|
||||||
def save_config(self):
|
def save_config(self):
|
||||||
parser.read_config()
|
parser.read()
|
||||||
parser.writeCfgFile()
|
parser.write()
|
||||||
|
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
if gtk.pygtk_version >= (2, 6, 0):
|
if gtk.pygtk_version >= (2, 6, 0):
|
||||||
|
@ -712,7 +712,6 @@ if __name__ == '__main__':
|
||||||
except ImportError:
|
except ImportError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
parser.parseCfgFile()
|
parser.read()
|
||||||
parser.fill_config()
|
|
||||||
Interface()
|
Interface()
|
||||||
gtk.main()
|
gtk.main()
|
||||||
|
|
Loading…
Reference in New Issue