Complete remove of GCONF settings and upgrade possibility

Note: Gconf still used in GNOME for thumbnailers


svn: r11444
This commit is contained in:
Benny Malengier 2008-12-08 09:16:46 +00:00
parent c2c4fe3786
commit 0d084cc677
4 changed files with 0 additions and 322 deletions

View File

@ -7,7 +7,6 @@ pkgdatadir = $(datadir)/@PACKAGE@/Config
pkgdata_PYTHON = \ pkgdata_PYTHON = \
__init__.py\ __init__.py\
_GrampsGconfKeys.py\
_GrampsConfigKeys.py\ _GrampsConfigKeys.py\
_GrampsIniKeys.py _GrampsIniKeys.py
@ -19,10 +18,6 @@ MOSTLYCLEANFILES = *pyc *pyo
GRAMPS_PY_MODPATH = "../" GRAMPS_PY_MODPATH = "../"
keys:
echo "Re-generating the _GrampsConfigKeys.py file..." ;
python gen_schema_keys.py ../../data/gramps.schemas.in
pycheck: pycheck:
(export PYTHONPATH=$(GRAMPS_PY_MODPATH); \ (export PYTHONPATH=$(GRAMPS_PY_MODPATH); \
pychecker $(pkgdata_PYTHON)); pychecker $(pkgdata_PYTHON));

View File

@ -1,173 +0,0 @@
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2004-2005 Donald N. Allingham
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# $Id$
"""
gconf is no longer supported. This functino serves only to provide an upgrade
path to the new system.
"""
#-------------------------------------------------------------------------
#
# GConf
#
#-------------------------------------------------------------------------
# SUSE calls the gconf module "gnome.gconf"
try:
import gconf
except ImportError:
import gnome.gconf
gconf = gnome.gconf
import Errors
from _GrampsConfigKeys import default_value
client = gconf.client_get_default()
client.add_dir("/apps/gramps", gconf.CLIENT_PRELOAD_NONE)
#-------------------------------------------------------------------------
#
# Functions to obtain values from gconf keys
# and store values into gconf keys
#
# All gramps keys should be accessed through these functions!
#
#-------------------------------------------------------------------------
def get_date_format(date_format_list):
return get_int("/apps/gramps/preferences/date-format",
range(len(date_format_list)))
def save_date_format(val, date_format_list):
set_int("/apps/gramps/preferences/date-format", val,
range(len(date_format_list)))
def get_name_format(_name_format_list):
return get_int("/apps/gramps/preferences/name-format",
range(len(_name_format_list)))
def save_name_format(val, _name_format_list):
set_int("/apps/gramps/preferences/name-format", val,
range(len(_name_format_list)))
#-------------------------------------------------------------------------
#
# Low-level grabbing and saving keys with error checking.
#
#-------------------------------------------------------------------------
def set(key, value):
token = "/apps/gramps/%s/%s" % (key[0], key[1])
if key[2] == 0:
set_bool(token, value)
elif key[2] == 1:
set_int(token, value)
else:
set_string(token, value)
def get(key):
token = "/apps/gramps/%s/%s" % (key[0], key[1])
if key[2] == 0:
try:
val = get_bool(token)
except:
val = default_value[key]
elif key[2] == 1:
try:
val = get_int(token)
except:
val = default_value[key]
else:
try:
val = get_string(token)
except:
val = default_value[key]
if val is None:
val = default_value[key]
return val
def get_bool(key):
val = client.get(key)
if val is None:
return None
val = client.get_bool(key)
if val in (True, False):
return val
else:
val = client.get_default_from_schema(key)
if val is None:
raise Errors.GConfSchemaError("No default value for key "+key)
return val.get_bool()
def set_bool(key, val):
if val in (True, False):
client.set_bool(key, val)
def get_int(key, correct_tuple=None):
val = client.get(key)
if val is None:
return None
val = client.get_int(key)
if not correct_tuple or val in correct_tuple:
return val
else:
val = client.get_default_from_schema(key)
if val is None:
raise Errors.GConfSchemaError("No default value for key "+key)
return val.get_int()
def set_int(key, val, correct_tuple=None):
if not correct_tuple or val in correct_tuple:
client.set_int(key, val)
def get_string(key, test_func=None):
val = client.get(key)
if val is None:
return None
val = client.get_string(key)
if not test_func or test_func(val):
return val
else:
val = client.get_default_from_schema(key)
if val is None:
raise Errors.GConfSchemaError("No default value for key "+key)
return val.get_string()
def set_string(key, val, test_func=None):
if not test_func or test_func(val):
client.set_string(key, val)
def sync():
client.suggest_sync()
def get_default(key, sample=''):
token = "/apps/gramps/%s/%s" % (key[0], key[1])
value = client.get_default_from_schema(token)
if value is None:
raise Errors.GConfSchemaError("No default value for key "+key[1])
if isinstance(sample, basestring):
return value.get_string()
elif isinstance(sample, int):
return value.get_int()
elif isinstance(sample, bool):
return value.get_bool()
return None

View File

@ -29,21 +29,3 @@ It provides the choice between different storage backends.
from _GrampsConfigKeys import * from _GrampsConfigKeys import *
from _GrampsIniKeys import * from _GrampsIniKeys import *
import os
def __upgrade_gconf():
import _GrampsGconfKeys as GconfKeys
print "Upgrading INI file"
for key in default_value.keys():
data = GconfKeys.get(key)
set(key, data)
if not os.path.exists(INIFILE):
try:
__upgrade_gconf()
except ImportError:
print "Cannot upgrade GCONF settings"

View File

@ -1,126 +0,0 @@
copy = """#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2006-2007 Donald N. Allingham
#
# This program is free software; you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 2 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
# $Id$
# NOTE: This file is autogenerated by gen_schema_keys.py script
# from the data/gramps.schemas.in file. To generate, run:
# python gen_schema_keys.py ../../data/gramps.schemas.in
# in the src/Config directory.
"""
from xml.parsers.expat import ParserCreate
class SchemaHandler:
def __init__(self):
self.list = []
self.clean()
def clean(self):
self.tlist = []
self.type = ""
self.default = ""
self.key = ""
self.include = False
self.short = ""
self.long = ""
def startElement(self,tag,attrs):
pass
def endElement(self,tag):
data = ''.join(self.tlist).strip()
if tag == "type":
self.type = data
elif tag == "default":
self.default = data
elif tag == "include":
self.include = int(data)
elif tag == "short":
self.short = data
elif tag == "long":
self.long = data.replace('\n','')
elif tag == "applyto":
self.key = data
elif tag == "schema":
self.list.append((self.key, self.type, self.default,
self.long, self.short, self.include))
self.clean()
self.tlist = []
def characters(self, data):
self.tlist.append(data)
def parse(self, name):
f = open(name)
self.p = ParserCreate()
self.p.StartElementHandler = self.startElement
self.p.EndElementHandler = self.endElement
self.p.CharacterDataHandler = self.characters
self.p.ParseFile(f)
f.close()
if __name__ == "__main__":
import sys
type_map = { 'bool' : 0, 'int' : 1 , 'string' : 2 }
parser = SchemaHandler()
parser.parse(sys.argv[1])
f = open("_GrampsConfigKeys.py","w")
f.write(copy)
for (key, key_type, default, long, short, include) in parser.list:
data = key.split('/')
category = data[3]
token = data[4]
tkey = token.upper().replace('-','_')
tmap = type_map[key_type]
f.write("%-20s = ('%s','%s', %d)\n" % (tkey,
category,
token,
tmap))
f.write('\n\ndefault_value = {\n')
for (key, key_type, default, long, short, include) in parser.list:
data = key.split('/')
category = data[3]
token = data[4]
tkey = token.upper().replace('-','_')
if key_type == 'bool':
if default == "1":
f.write(" %-20s : True,\n" % tkey)
else:
f.write(" %-20s : False,\n" % tkey)
elif key_type == "int":
f.write(" %-20s : %s,\n" % (tkey,default))
else:
f.write(" %-20s : '%s',\n" % (tkey,default))
f.write('}\n')
f.close()