* src/plugins/Verify.py: Convert to new API.

svn: r5259
This commit is contained in:
Alex Roitman 2005-10-01 19:30:20 +00:00
parent b202b65f1c
commit ece8b3cc0c
2 changed files with 209 additions and 46 deletions

View File

@ -1,3 +1,6 @@
2005-10-01 Alex Roitman <shura@gramps-project.org>
* src/plugins/Verify.py: Convert to new API.
2005-09-30 Alex Roitman <shura@gramps-project.org> 2005-09-30 Alex Roitman <shura@gramps-project.org>
* src/docgen/KwordDoc.py: Remove unused latin_utf8 import. * src/docgen/KwordDoc.py: Remove unused latin_utf8 import.
* src/plugins/FilterEditor.py: Convert to new API. * src/plugins/FilterEditor.py: Convert to new API.

View File

@ -48,18 +48,26 @@ from gnome import help_display
import RelLib import RelLib
import Utils import Utils
import Date import Date
import Tool
def runTool(database,active_person,callback,parent=None):
Verify(database,active_person,parent)
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# Actual tool # Actual tool
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
class Verify: class Verify(Tool.Tool):
def __init__(self,database,active_person,parent):
self.db = database def __init__(self,db,person,options_class,name,callback=None,parent=None):
Tool.Tool.__init__(self,db,person,options_class,name)
if parent:
self.init_gui(parent)
else:
err_text,warn_text = self.run_tool(cli=True)
self.print_results(err_text,warn_text)
def init_gui(self,parent):
# Draw dialog and make it handle everything
self.parent = parent self.parent = parent
if self.parent.child_windows.has_key(self.__class__): if self.parent.child_windows.has_key(self.__class__):
self.parent.child_windows[self.__class__].present(None) self.parent.child_windows[self.__class__].present(None)
@ -83,6 +91,37 @@ class Verify:
self.top.get_widget('title'), self.top.get_widget('title'),
_('Database Verify')) _('Database Verify'))
self.top.get_widget("oldage").set_value(
self.options.handler.options_dict['oldage'])
self.top.get_widget("hwdif").set_value(
self.options.handler.options_dict['hwdif'])
self.top.get_widget("cspace").set_value(
self.options.handler.options_dict['cspace'])
self.top.get_widget("cbspan").set_value(
self.options.handler.options_dict['cbspan'])
self.top.get_widget("yngmar").set_value(
self.options.handler.options_dict['yngmar'])
self.top.get_widget("oldmar").set_value(
self.options.handler.options_dict['oldmar'])
self.top.get_widget("oldmom").set_value(
self.options.handler.options_dict['oldmom'])
self.top.get_widget("yngmom").set_value(
self.options.handler.options_dict['yngmom'])
self.top.get_widget("olddad").set_value(
self.options.handler.options_dict['olddad'])
self.top.get_widget("yngdad").set_value(
self.options.handler.options_dict['yngdad'])
self.top.get_widget("wedder").set_value(
self.options.handler.options_dict['wedder'])
self.top.get_widget("mxchildmom").set_value(
self.options.handler.options_dict['mxchildmom'])
self.top.get_widget("mxchilddad").set_value(
self.options.handler.options_dict['mxchilddad'])
self.top.get_widget("lngwdw").set_value(
self.options.handler.options_dict['lngwdw'])
self.top.get_widget("estimate").set_active(
self.options.handler.options_dict['estimate_age'])
self.add_itself_to_menu() self.add_itself_to_menu()
self.window.show() self.window.show()
@ -127,38 +166,76 @@ class Verify:
return year return year
def on_apply_clicked(self,obj): def on_apply_clicked(self,obj):
self.options.handler.options_dict['oldage'] = self.top.get_widget(
"oldage").get_value_as_int()
self.options.handler.options_dict['hwdif'] = self.top.get_widget(
"hwdif").get_value_as_int()
self.options.handler.options_dict['cspace'] = self.top.get_widget(
"cspace").get_value_as_int()
self.options.handler.options_dict['cbspan'] = self.top.get_widget(
"cbspan").get_value_as_int()
self.options.handler.options_dict['yngmar'] = self.top.get_widget(
"yngmar").get_value_as_int()
self.options.handler.options_dict['oldmar'] = self.top.get_widget(
"oldmar").get_value_as_int()
self.options.handler.options_dict['oldmom'] = self.top.get_widget(
"oldmom").get_value_as_int()
self.options.handler.options_dict['yngmom'] = self.top.get_widget(
"yngmom").get_value_as_int()
self.options.handler.options_dict['olddad'] = self.top.get_widget(
"olddad").get_value_as_int()
self.options.handler.options_dict['yngdad'] = self.top.get_widget(
"yngdad").get_value_as_int()
self.options.handler.options_dict['wedder'] = self.top.get_widget(
"wedder").get_value_as_int()
self.options.handler.options_dict['mxchildmom'] = self.top.get_widget(
"mxchildmom").get_value_as_int()
self.options.handler.options_dict['mxchilddad'] = self.top.get_widget(
"mxchilddad").get_value_as_int()
self.options.handler.options_dict['lngwdw'] = self.top.get_widget(
"lngwdw").get_value_as_int()
self.options.handler.options_dict['estimate_age'] = \
self.top.get_widget(
"estimate").get_active()
err_text,warn_text = self.run_tool(cli=False)
# Save options
self.options.handler.save_options()
VerifyResults(err_text,warn_text,self.parent)
def run_tool(self,cli=False):
personList = self.db.get_person_handles(sort_handles=False) personList = self.db.get_person_handles(sort_handles=False)
oldage = self.options.handler.options_dict['oldage']
hwdif = self.options.handler.options_dict['hwdif']
cspace = self.options.handler.options_dict['cspace']
cbspan = self.options.handler.options_dict['cbspan']
yngmar = self.options.handler.options_dict['yngmar']
oldmar = self.options.handler.options_dict['oldmar']
oldmom = self.options.handler.options_dict['oldmom']
yngmom = self.options.handler.options_dict['yngmom']
olddad = self.options.handler.options_dict['olddad']
yngdad = self.options.handler.options_dict['yngdad']
wedder = self.options.handler.options_dict['wedder']
mxchildmom = self.options.handler.options_dict['mxchildmom']
mxchilddad = self.options.handler.options_dict['mxchilddad']
lngwdw = self.options.handler.options_dict['lngwdw']
estimate_age = self.options.handler.options_dict['estimate_age']
oldage = self.top.get_widget("oldage").get_value_as_int() # FIXME: This has to become an option as well!
hwdif = self.top.get_widget("hwdif").get_value_as_int() # OR should be removed. What's the reason behind it?
cspace = self.top.get_widget("cspace").get_value_as_int()
cbspan = self.top.get_widget("cbspan").get_value_as_int()
yngmar = self.top.get_widget("yngmar").get_value_as_int()
oldmar = self.top.get_widget("oldmar").get_value_as_int()
oldmom = self.top.get_widget("oldmom").get_value_as_int()
yngmom = self.top.get_widget("yngmom").get_value_as_int()
olddad = self.top.get_widget("olddad").get_value_as_int()
yngdad = self.top.get_widget("yngdad").get_value_as_int()
wedder = self.top.get_widget("wedder").get_value_as_int()
lngwdw = self.top.get_widget("lngwdw").get_value_as_int()
mxchildmom = self.top.get_widget("mxchildmom").get_value_as_int()
mxchilddad = self.top.get_widget("mxchilddad").get_value_as_int()
lngwdw = self.top.get_widget("lngwdw").get_value_as_int()
estimate_age = self.top.get_widget("estimate").get_active()
oldunm = 99 # maximum age at death for unmarried person oldunm = 99 # maximum age at death for unmarried person
error = cStringIO.StringIO() error = cStringIO.StringIO()
warn = cStringIO.StringIO() warn = cStringIO.StringIO()
if not cli:
progress = Utils.ProgressMeter(_('Verify the database'),'') progress = Utils.ProgressMeter(_('Verify the database'),'')
progress.set_pass(_('Checking data'),
progress.set_pass(_('Checking data'),self.db.get_number_of_people()) self.db.get_number_of_people())
for person_handle in personList: for person_handle in personList:
progress.step()
person = self.db.get_person_from_handle(person_handle) person = self.db.get_person_from_handle(person_handle)
idstr = "%s (%s)" % (person.get_primary_name().get_name(),person.get_gramps_id()) idstr = "%s (%s)" % (person.get_primary_name().get_name(),person.get_gramps_id())
@ -478,19 +555,28 @@ class Verify:
and total_children > mxchildmom): and total_children > mxchildmom):
warn.write(_("Too many children (%(num_children)d) for %(person_name)s.\n") % { warn.write(_("Too many children (%(num_children)d) for %(person_name)s.\n") % {
'num_children' : total_children, 'person_name' : idstr }) 'num_children' : total_children, 'person_name' : idstr })
if not cli:
progress.step()
if not cli:
progress.close() progress.close()
text = ""
err_text = error.getvalue() err_text = error.getvalue()
warn_text = warn.getvalue() warn_text = warn.getvalue()
if err_text.strip():
text = _("ERRORS:\n") + err_text + "\n"
if warn_text.strip():
text = text + _("WARNINGS:\n") + warn_text
error.close() error.close()
warn.close() warn.close()
VerifyResults(text,self.parent)
return err_text.strip(),warn_text.strip()
def print_results(self,err_text,warn_text):
if warn_text:
print "\nWARNINGS:"
print warn_text
if err_text:
print "\nERRORS:"
print err_text
if not (warn_text or err_text):
print "No warnings or errors during verification!"
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
@ -498,9 +584,10 @@ class Verify:
# #
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
class VerifyResults: class VerifyResults:
def __init__(self,text,parent): def __init__(self,err_text,warn_text,parent):
self.parent = parent self.parent = parent
self.text = text self.err_text = err_text
self.warn_text = warn_text
self.win_key = self self.win_key = self
@ -520,8 +607,10 @@ class VerifyResults:
self.window = self.top.get_widget("verify_result") self.window = self.top.get_widget("verify_result")
self.window.set_icon(self.parent.topWindow.get_icon()) self.window.set_icon(self.parent.topWindow.get_icon())
textwindow = self.top.get_widget("textwindow") err_window = self.top.get_widget("err_window")
textwindow.get_buffer().set_text(self.text) warn_window = self.top.get_widget("warn_window")
err_window.get_buffer().set_text(self.err_text)
warn_window.get_buffer().set_text(self.warn_text)
self.add_result_to_menu() self.add_result_to_menu()
self.window.show() self.window.show()
@ -547,6 +636,71 @@ class VerifyResults:
def present_result(self,obj): def present_result(self,obj):
self.window.present() self.window.present()
#------------------------------------------------------------------------
#
#
#
#------------------------------------------------------------------------
class VerifyOptions(Tool.ToolOptions):
"""
Defines options and provides handling interface.
"""
def __init__(self,name,person_id=None):
Tool.ToolOptions.__init__(self,name,person_id)
def set_new_options(self):
# Options specific for this report
self.options_dict = {
'oldage' : 90,
'hwdif' : 30,
'cspace' : 8,
'cbspan' : 25,
'yngmar' : 17,
'oldmar' : 50,
'oldmom' : 48,
'yngmom' : 17,
'yngdad' : 18,
'olddad' : 65,
'wedder' : 3,
'mxchildmom' : 12,
'mxchilddad' : 15,
'lngwdw' : 30,
'estimate_age' : 0,
}
self.options_help = {
'oldage' : ("=num","Maximum age","Age in years"),
'hwdif' : ("=num","Maximum husband-wife age difference",
"Age difference in years"),
'cspace' : ("=num",
"Maximum number of years between children",
"Number of years"),
'cbspan' : ("=num",
"Maximum span of years for all children",
"Span in years"),
'yngmar' : ("=num","Minimum age to marry","Age in years"),
'oldmar' : ("=num","Maximum age to marry","Age in years"),
'oldmom' : ("=num","Maximum age to bear a child",
"Age in years"),
'yngmom' : ("=num","Minimum age to bear a child",
"Age in years"),
'yngdad' : ("=num","Minimum age to father a child",
"Age in years"),
'olddad' : ("=num","Maximum age to father a child",
"Age in years"),
'wedder' : ("=num","Maximum number of spouses for a person",
"Number of spouses"),
'mxchildmom' : ("=num","Maximum number of children for a woman",
"Number of children"),
'mxchilddad' : ("=num","Maximum number of children for a man",
"Number of chidlren"),
'lngwdw' : ("=num","Maximum number of consecutive years "
"of widowhood","Number of years"),
'estimate_age' : ("=0/1","Whether to estimate missing dates",
["Do not estimate","Estimate dates"],
True),
}
#------------------------------------------------------------------------- #-------------------------------------------------------------------------
# #
# #
@ -555,8 +709,14 @@ class VerifyResults:
from PluginMgr import register_tool from PluginMgr import register_tool
register_tool( register_tool(
runTool, name = 'verify',
_("Verify the database"), category = Tool.TOOL_UTILS,
category=_("Utilities"), tool_class = Verify,
description=_("Lists exceptions to assertions or checks about the database") options_class = VerifyOptions,
modes = Tool.MODE_GUI | Tool.MODE_CLI,
translated_name = _("Verify the database"),
author_name = "Donald N. Allingham",
author_email = "dallingham@users.sourceforge.net",
description = _("Lists exceptions to assertions or checks "
"about the database")
) )