Update
svn: r6789
This commit is contained in:
parent
a6025569d3
commit
a32ed5e6bb
@ -20,7 +20,10 @@
|
||||
|
||||
# $Id$
|
||||
|
||||
"View/Verify"
|
||||
"""
|
||||
A plugin to verify the data against user-adjsted tests.
|
||||
This is the research tool, not the low-level data ingerity check.
|
||||
"""
|
||||
|
||||
#------------------------------------------------------------------------
|
||||
#
|
||||
@ -56,38 +59,38 @@ from PluginUtils import Tool, register_tool
|
||||
# temp storage and related functions
|
||||
#
|
||||
#-------------------------------------------------------------------------
|
||||
_person_store = {}
|
||||
_family_store = {}
|
||||
_event_store = {}
|
||||
_person_cache = {}
|
||||
_family_cache = {}
|
||||
_event_cache = {}
|
||||
|
||||
def find_event(db,handle):
|
||||
try:
|
||||
obj = _event_store[handle]
|
||||
obj = _event_cache[handle]
|
||||
except KeyError:
|
||||
obj = db.get_event_from_handle(handle)
|
||||
_event_store[handle] = obj
|
||||
_event_cache[handle] = obj
|
||||
return obj
|
||||
|
||||
def find_person(db,handle):
|
||||
try:
|
||||
obj = _person_store[handle]
|
||||
obj = _person_cache[handle]
|
||||
except KeyError:
|
||||
obj = db.get_person_from_handle(handle)
|
||||
_person_store[handle] = obj
|
||||
_person_cache[handle] = obj
|
||||
return obj
|
||||
|
||||
def find_family(db,handle):
|
||||
try:
|
||||
obj = _family_store[handle]
|
||||
obj = _family_cache[handle]
|
||||
except KeyError:
|
||||
obj = db.get_family_from_handle(handle)
|
||||
_family_store[handle] = obj
|
||||
_family_cache[handle] = obj
|
||||
return obj
|
||||
|
||||
def clear_storage():
|
||||
_person_store.clear()
|
||||
_family_store.clear()
|
||||
_event_store.clear()
|
||||
def clear_cache():
|
||||
_person_cache.clear()
|
||||
_family_cache.clear()
|
||||
_event_cache.clear()
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -210,8 +213,11 @@ class Verify(Tool.Tool, ManagedWindow, UpdateCallback):
|
||||
|
||||
def add_results_cli(self,results):
|
||||
# print data for the user, no GUI
|
||||
(msg,gramps_id,name,the_type,rule_id,handle) = results
|
||||
print "%s, %s: %s, %s" % (msg,the_type,gramps_id,name)
|
||||
(msg,gramps_id,name,the_type,rule_id,severity,handle) = results
|
||||
if severity == Rule.WARNING:
|
||||
print "W: %s, %s: %s, %s" % (msg,the_type,gramps_id,name)
|
||||
elif severity == Rule.ERROR:
|
||||
print "E: %s, %s: %s, %s" % (msg,the_type,gramps_id,name)
|
||||
|
||||
def init_gui(self):
|
||||
# Draw dialog and make it handle everything
|
||||
@ -365,10 +371,6 @@ class Verify(Tool.Tool, ManagedWindow, UpdateCallback):
|
||||
oldunm = self.options.handler.options_dict['oldunm']
|
||||
estimate_age = self.options.handler.options_dict['estimate_age']
|
||||
|
||||
## if not cli:
|
||||
## progress = Utils.ProgressMeter(_('Verify the database'),'')
|
||||
## progress.set_pass(_('Checking people data'),
|
||||
## self.db.get_number_of_people())
|
||||
|
||||
self.set_total(self.db.get_number_of_people() +
|
||||
self.db.get_number_of_families())
|
||||
@ -376,134 +378,56 @@ class Verify(Tool.Tool, ManagedWindow, UpdateCallback):
|
||||
for person_handle in person_handles:
|
||||
person = find_person(self.db,person_handle)
|
||||
|
||||
the_rule = BirthAfterBapt(self.db,person)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = DeathBeforeBapt(self.db,person)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = BirthAfterBury(self.db,person)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = DeathAfterBury(self.db,person)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = BirthAfterDeath(self.db,person)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = BaptAfterBury(self.db,person)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = OldAge(self.db,person,oldage,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = UnknownGender(self.db,person)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = MultipleParents(self.db,person)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = MarriedOften(self.db,person,wedder)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = OldUnmarried(self.db,person,oldunm,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = TooManyChildren(self.db,person,mxchilddad,mxchildmom)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
clear_storage()
|
||||
## if not cli:
|
||||
## progress.step()
|
||||
self.update()
|
||||
rule_list = [
|
||||
BirthAfterBapt(self.db,person),
|
||||
DeathBeforeBapt(self.db,person),
|
||||
BirthAfterBury(self.db,person),
|
||||
DeathAfterBury(self.db,person),
|
||||
BirthAfterDeath(self.db,person),
|
||||
BaptAfterBury(self.db,person),
|
||||
OldAge(self.db,person,oldage,estimate_age),
|
||||
UnknownGender(self.db,person),
|
||||
MultipleParents(self.db,person),
|
||||
MarriedOften(self.db,person,wedder),
|
||||
OldUnmarried(self.db,person,oldunm,estimate_age),
|
||||
TooManyChildren(self.db,person,mxchilddad,mxchildmom),
|
||||
]
|
||||
|
||||
## if not cli:
|
||||
## progress.set_pass(_('Checking family data'),
|
||||
## self.db.get_number_of_families())
|
||||
for rule in rule_list:
|
||||
if rule.broken():
|
||||
self.add_results(rule.report_itself())
|
||||
|
||||
clear_cache()
|
||||
self.update()
|
||||
|
||||
# Family-based rules
|
||||
for family_handle in self.db.get_family_handles():
|
||||
family = find_family(self.db,family_handle)
|
||||
|
||||
the_rule = SameSexFamily(self.db,family)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
rule_list = [
|
||||
SameSexFamily(self.db,family),
|
||||
FemaleHusband(self.db,family),
|
||||
MaleWife(self.db,family),
|
||||
SameSurnameFamily(self.db,family),
|
||||
LargeAgeGapFamily(self.db,family,hwdif,estimate_age),
|
||||
MarriageBeforeBirth(self.db,family,estimate_age),
|
||||
MarriageAfterDeath(self.db,family,estimate_age),
|
||||
EarlyMarriage(self.db,family,yngmar,estimate_age),
|
||||
LateMarriage(self.db,family,oldmar,estimate_age),
|
||||
OldParent(self.db,family,oldmom,olddad,estimate_age),
|
||||
YoungParent(self.db,family,yngmom,yngdad,estimate_age),
|
||||
UnbornParent(self.db,family,estimate_age),
|
||||
DeadParent(self.db,family,estimate_age),
|
||||
LargeChildrenSpan(self.db,family,cbspan,estimate_age),
|
||||
LargeChildrenAgeDiff(self.db,family,cspace,estimate_age),
|
||||
]
|
||||
|
||||
the_rule = FemaleHusband(self.db,family)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = MaleWife(self.db,family)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = SameSurnameFamily(self.db,family)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = LargeAgeGapFamily(self.db,family,hwdif,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = MarriageBeforeBirth(self.db,family,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = MarriageAfterDeath(self.db,family,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = EarlyMarriage(self.db,family,yngmar,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = LateMarriage(self.db,family,oldmar,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = OldParent(self.db,family,oldmom,olddad,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = YoungParent(self.db,family,yngmom,yngdad,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = UnbornParent(self.db,family,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = DeadParent(self.db,family,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = LargeChildrenSpan(self.db,family,cbspan,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
the_rule = LargeChildrenAgeDiff(self.db,family,cspace,estimate_age)
|
||||
if the_rule.broken():
|
||||
self.add_results(the_rule.report_itself())
|
||||
|
||||
clear_storage()
|
||||
for rule in rule_list:
|
||||
if rule.broken():
|
||||
self.add_results(rule.report_itself())
|
||||
|
||||
clear_cache()
|
||||
self.update()
|
||||
## if not cli:
|
||||
## progress.step()
|
||||
|
||||
## if not cli:
|
||||
## progress.close()
|
||||
|
||||
#-------------------------------------------------------------------------
|
||||
#
|
||||
@ -572,8 +496,14 @@ class VerifyResults(ManagedWindow):
|
||||
cell.set_property('stock-id', 'gramps-family' )
|
||||
|
||||
def add_results(self,results):
|
||||
fg = None
|
||||
(msg,gramps_id,name,the_type,rule_id,handle) = results
|
||||
(msg,gramps_id,name,the_type,rule_id,severity,handle) = results
|
||||
if severity == Rule.ERROR:
|
||||
fg = 'red'
|
||||
## fg = '#8b008b'
|
||||
## elif severity == Rule.WARNING:
|
||||
## fg = '#008b00'
|
||||
else:
|
||||
fg = None
|
||||
self.warn_model.append(row=[msg,gramps_id,name,
|
||||
the_type,rule_id,handle,fg])
|
||||
|
||||
@ -670,6 +600,8 @@ class Rule:
|
||||
ERROR = 1
|
||||
WARNING = 2
|
||||
|
||||
SEVERITY = WARNING
|
||||
|
||||
def __init__(self,db,obj):
|
||||
self.db = db
|
||||
self.obj = obj
|
||||
@ -699,10 +631,11 @@ class Rule:
|
||||
handle = self.get_handle()
|
||||
the_type = self.TYPE
|
||||
rule_id = self.ID
|
||||
severity = self.SEVERITY
|
||||
name = self.get_name()
|
||||
gramps_id = self.get_id()
|
||||
msg = self.get_message()
|
||||
return (msg,gramps_id,name,the_type,rule_id,handle)
|
||||
return (msg,gramps_id,name,the_type,rule_id,severity,handle)
|
||||
|
||||
class PersonRule(Rule):
|
||||
"""
|
||||
@ -727,6 +660,7 @@ class FamilyRule(Rule):
|
||||
#-------------------------------------------------------------------------
|
||||
class BirthAfterBapt(PersonRule):
|
||||
ID = 1
|
||||
SEVERITY = Rule.ERROR
|
||||
def broken(self):
|
||||
birth_date = get_birth_date(self.db,self.obj)
|
||||
bapt_date = get_bapt_date(self.db,self.obj)
|
||||
@ -740,6 +674,7 @@ class BirthAfterBapt(PersonRule):
|
||||
|
||||
class DeathBeforeBapt(PersonRule):
|
||||
ID = 2
|
||||
SEVERITY = Rule.ERROR
|
||||
def broken(self):
|
||||
death_date = get_death_date(self.db,self.obj)
|
||||
bapt_date = get_bapt_date(self.db,self.obj)
|
||||
@ -753,6 +688,7 @@ class DeathBeforeBapt(PersonRule):
|
||||
|
||||
class BirthAfterBury(PersonRule):
|
||||
ID = 3
|
||||
SEVERITY = Rule.ERROR
|
||||
def broken(self):
|
||||
birth_date = get_birth_date(self.db,self.obj)
|
||||
bury_date = get_bury_date(self.db,self.obj)
|
||||
@ -766,6 +702,7 @@ class BirthAfterBury(PersonRule):
|
||||
|
||||
class DeathAfterBury(PersonRule):
|
||||
ID = 4
|
||||
SEVERITY = Rule.ERROR
|
||||
def broken(self):
|
||||
death_date = get_death_date(self.db,self.obj)
|
||||
bury_date = get_bury_date(self.db,self.obj)
|
||||
@ -779,6 +716,7 @@ class DeathAfterBury(PersonRule):
|
||||
|
||||
class BirthAfterDeath(PersonRule):
|
||||
ID = 5
|
||||
SEVERITY = Rule.ERROR
|
||||
def broken(self):
|
||||
birth_date = get_birth_date(self.db,self.obj)
|
||||
death_date = get_death_date(self.db,self.obj)
|
||||
@ -792,6 +730,7 @@ class BirthAfterDeath(PersonRule):
|
||||
|
||||
class BaptAfterBury(PersonRule):
|
||||
ID = 6
|
||||
SEVERITY = Rule.ERROR
|
||||
def broken(self):
|
||||
bapt_date = get_bapt_date(self.db,self.obj)
|
||||
bury_date = get_bury_date(self.db,self.obj)
|
||||
@ -805,6 +744,7 @@ class BaptAfterBury(PersonRule):
|
||||
|
||||
class OldAge(PersonRule):
|
||||
ID = 7
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,person,old_age,est):
|
||||
PersonRule.__init__(self,db,person)
|
||||
self.old_age = old_age
|
||||
@ -819,6 +759,7 @@ class OldAge(PersonRule):
|
||||
|
||||
class UnknownGender(PersonRule):
|
||||
ID = 8
|
||||
SEVERITY = Rule.WARNING
|
||||
def broken(self):
|
||||
female = self.obj.get_gender() == RelLib.Person.FEMALE
|
||||
male = self.obj.get_gender() == RelLib.Person.MALE
|
||||
@ -829,6 +770,7 @@ class UnknownGender(PersonRule):
|
||||
|
||||
class MultipleParents(PersonRule):
|
||||
ID = 9
|
||||
SEVERITY = Rule.WARNING
|
||||
def broken(self):
|
||||
n_parent_sets = len(self.obj.get_parent_family_handle_list())
|
||||
return (n_parent_sets>1)
|
||||
@ -838,6 +780,7 @@ class MultipleParents(PersonRule):
|
||||
|
||||
class MarriedOften(PersonRule):
|
||||
ID = 10
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,person,wedder):
|
||||
PersonRule.__init__(self,db,person)
|
||||
self.wedder = wedder
|
||||
@ -851,6 +794,7 @@ class MarriedOften(PersonRule):
|
||||
|
||||
class OldUnmarried(PersonRule):
|
||||
ID = 11
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,person,old_unm,est):
|
||||
PersonRule.__init__(self,db,person)
|
||||
self.old_unm = old_unm
|
||||
@ -866,6 +810,7 @@ class OldUnmarried(PersonRule):
|
||||
|
||||
class TooManyChildren(PersonRule):
|
||||
ID = 12
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,obj,mx_child_dad,mx_child_mom):
|
||||
PersonRule.__init__(self,db,obj)
|
||||
self.mx_child_dad = mx_child_dad
|
||||
@ -889,6 +834,7 @@ class TooManyChildren(PersonRule):
|
||||
|
||||
class SameSexFamily(FamilyRule):
|
||||
ID = 13
|
||||
SEVERITY = Rule.WARNING
|
||||
def broken(self):
|
||||
mother = get_mother(self.db,self.obj)
|
||||
father = get_father(self.db,self.obj)
|
||||
@ -903,6 +849,7 @@ class SameSexFamily(FamilyRule):
|
||||
|
||||
class FemaleHusband(FamilyRule):
|
||||
ID = 14
|
||||
SEVERITY = Rule.WARNING
|
||||
def broken(self):
|
||||
father = get_father(self.db,self.obj)
|
||||
return (father and (father.get_gender() == RelLib.Person.FEMALE))
|
||||
@ -912,6 +859,7 @@ class FemaleHusband(FamilyRule):
|
||||
|
||||
class MaleWife(FamilyRule):
|
||||
ID = 15
|
||||
SEVERITY = Rule.WARNING
|
||||
def broken(self):
|
||||
mother = get_mother(self.db,self.obj)
|
||||
return (mother and (mother.get_gender() == RelLib.Person.MALE))
|
||||
@ -921,6 +869,7 @@ class MaleWife(FamilyRule):
|
||||
|
||||
class SameSurnameFamily(FamilyRule):
|
||||
ID = 16
|
||||
SEVERITY = Rule.WARNING
|
||||
def broken(self):
|
||||
mother = get_mother(self.db,self.obj)
|
||||
father = get_father(self.db,self.obj)
|
||||
@ -936,6 +885,7 @@ class SameSurnameFamily(FamilyRule):
|
||||
|
||||
class LargeAgeGapFamily(FamilyRule):
|
||||
ID = 17
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,obj,hw_diff,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.hw_diff = hw_diff
|
||||
@ -956,6 +906,7 @@ class LargeAgeGapFamily(FamilyRule):
|
||||
|
||||
class MarriageBeforeBirth(FamilyRule):
|
||||
ID = 18
|
||||
SEVERITY = Rule.ERROR
|
||||
def __init__(self,db,obj,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.est = est
|
||||
@ -983,6 +934,7 @@ class MarriageBeforeBirth(FamilyRule):
|
||||
|
||||
class MarriageAfterDeath(FamilyRule):
|
||||
ID = 19
|
||||
SEVERITY = Rule.ERROR
|
||||
def __init__(self,db,obj,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.est = est
|
||||
@ -1010,6 +962,7 @@ class MarriageAfterDeath(FamilyRule):
|
||||
|
||||
class EarlyMarriage(FamilyRule):
|
||||
ID = 20
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,obj,yng_mar,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.yng_mar = yng_mar
|
||||
@ -1038,6 +991,7 @@ class EarlyMarriage(FamilyRule):
|
||||
|
||||
class LateMarriage(FamilyRule):
|
||||
ID = 21
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,obj,old_mar,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.old_mar = old_mar
|
||||
@ -1085,6 +1039,7 @@ class LateMarriage(FamilyRule):
|
||||
|
||||
class OldParent(FamilyRule):
|
||||
ID = 22
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,obj,old_mom,old_dad,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.old_mom = old_mom
|
||||
@ -1126,6 +1081,7 @@ class OldParent(FamilyRule):
|
||||
|
||||
class YoungParent(FamilyRule):
|
||||
ID = 23
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,obj,yng_mom,yng_dad,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.yng_dad = yng_dad
|
||||
@ -1167,6 +1123,7 @@ class YoungParent(FamilyRule):
|
||||
|
||||
class UnbornParent(FamilyRule):
|
||||
ID = 24
|
||||
SEVERITY = Rule.ERROR
|
||||
def __init__(self,db,obj,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.est = est
|
||||
@ -1205,6 +1162,7 @@ class UnbornParent(FamilyRule):
|
||||
|
||||
class DeadParent(FamilyRule):
|
||||
ID = 25
|
||||
SEVERITY = Rule.ERROR
|
||||
def __init__(self,db,obj,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.est = est
|
||||
@ -1243,6 +1201,7 @@ class DeadParent(FamilyRule):
|
||||
|
||||
class LargeChildrenSpan(FamilyRule):
|
||||
ID = 26
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,obj,cb_span,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.cb_span = cb_span
|
||||
@ -1260,6 +1219,7 @@ class LargeChildrenSpan(FamilyRule):
|
||||
|
||||
class LargeChildrenAgeDiff(FamilyRule):
|
||||
ID = 27
|
||||
SEVERITY = Rule.WARNING
|
||||
def __init__(self,db,obj,c_space,est):
|
||||
FamilyRule.__init__(self,db,obj)
|
||||
self.c_space = c_space
|
||||
|
@ -1124,9 +1124,10 @@
|
||||
|
||||
<child>
|
||||
<widget class="GtkVBox" id="vbox5">
|
||||
<property name="border_width">6</property>
|
||||
<property name="visible">True</property>
|
||||
<property name="homogeneous">False</property>
|
||||
<property name="spacing">0</property>
|
||||
<property name="spacing">6</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkLabel" id="title">
|
||||
@ -1154,27 +1155,107 @@
|
||||
</child>
|
||||
|
||||
<child>
|
||||
<widget class="GtkScrolledWindow" id="scrolledwindow2">
|
||||
<property name="border_width">6</property>
|
||||
<widget class="GtkHBox" id="hbox1">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="hscrollbar_policy">GTK_POLICY_AUTOMATIC</property>
|
||||
<property name="vscrollbar_policy">GTK_POLICY_AUTOMATIC</property>
|
||||
<property name="shadow_type">GTK_SHADOW_IN</property>
|
||||
<property name="window_placement">GTK_CORNER_TOP_LEFT</property>
|
||||
<property name="homogeneous">False</property>
|
||||
<property name="spacing">0</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkTreeView" id="warn_tree">
|
||||
<widget class="GtkScrolledWindow" id="scrolledwindow4">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="headers_visible">True</property>
|
||||
<property name="rules_hint">True</property>
|
||||
<property name="reorderable">False</property>
|
||||
<property name="enable_search">True</property>
|
||||
<property name="fixed_height_mode">False</property>
|
||||
<property name="hover_selection">False</property>
|
||||
<property name="hover_expand">False</property>
|
||||
<property name="hscrollbar_policy">GTK_POLICY_ALWAYS</property>
|
||||
<property name="vscrollbar_policy">GTK_POLICY_ALWAYS</property>
|
||||
<property name="shadow_type">GTK_SHADOW_NONE</property>
|
||||
<property name="window_placement">GTK_CORNER_TOP_LEFT</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkTreeView" id="warn_tree">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="headers_visible">True</property>
|
||||
<property name="rules_hint">True</property>
|
||||
<property name="reorderable">False</property>
|
||||
<property name="enable_search">True</property>
|
||||
<property name="fixed_height_mode">False</property>
|
||||
<property name="hover_selection">False</property>
|
||||
<property name="hover_expand">False</property>
|
||||
</widget>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="padding">0</property>
|
||||
<property name="expand">True</property>
|
||||
<property name="fill">True</property>
|
||||
</packing>
|
||||
</child>
|
||||
|
||||
<child>
|
||||
<widget class="GtkVBox" id="vbox7">
|
||||
<property name="border_width">6</property>
|
||||
<property name="visible">True</property>
|
||||
<property name="homogeneous">False</property>
|
||||
<property name="spacing">6</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkButton" id="hide_sel_button">
|
||||
<property name="visible">True</property>
|
||||
<property name="tooltip" translatable="yes">Mark selected rows as ignored</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="relief">GTK_RELIEF_NORMAL</property>
|
||||
<property name="focus_on_click">True</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkImage" id="image5">
|
||||
<property name="visible">True</property>
|
||||
<property name="stock">gtk-delete</property>
|
||||
<property name="icon_size">4</property>
|
||||
<property name="xalign">0.5</property>
|
||||
<property name="yalign">0.5</property>
|
||||
<property name="xpad">0</property>
|
||||
<property name="ypad">0</property>
|
||||
</widget>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="padding">0</property>
|
||||
<property name="expand">False</property>
|
||||
<property name="fill">False</property>
|
||||
</packing>
|
||||
</child>
|
||||
|
||||
<child>
|
||||
<widget class="GtkButton" id="hide_all_button">
|
||||
<property name="visible">True</property>
|
||||
<property name="tooltip" translatable="yes">Mark all rows as ignored</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="relief">GTK_RELIEF_NORMAL</property>
|
||||
<property name="focus_on_click">True</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkImage" id="image4">
|
||||
<property name="visible">True</property>
|
||||
<property name="stock">gtk-clear</property>
|
||||
<property name="icon_size">4</property>
|
||||
<property name="xalign">0.5</property>
|
||||
<property name="yalign">0.5</property>
|
||||
<property name="xpad">0</property>
|
||||
<property name="ypad">0</property>
|
||||
</widget>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="padding">0</property>
|
||||
<property name="expand">False</property>
|
||||
<property name="fill">False</property>
|
||||
</packing>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="padding">0</property>
|
||||
<property name="expand">False</property>
|
||||
<property name="fill">True</property>
|
||||
</packing>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
@ -1192,27 +1273,107 @@
|
||||
<property name="spacing">0</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkScrolledWindow" id="scrolledwindow3">
|
||||
<property name="border_width">6</property>
|
||||
<widget class="GtkHBox" id="hbox2">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="hscrollbar_policy">GTK_POLICY_AUTOMATIC</property>
|
||||
<property name="vscrollbar_policy">GTK_POLICY_AUTOMATIC</property>
|
||||
<property name="shadow_type">GTK_SHADOW_IN</property>
|
||||
<property name="window_placement">GTK_CORNER_TOP_LEFT</property>
|
||||
<property name="homogeneous">False</property>
|
||||
<property name="spacing">0</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkTreeView" id="hide_tree">
|
||||
<widget class="GtkScrolledWindow" id="scrolledwindow5">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="headers_visible">True</property>
|
||||
<property name="rules_hint">True</property>
|
||||
<property name="reorderable">False</property>
|
||||
<property name="enable_search">True</property>
|
||||
<property name="fixed_height_mode">False</property>
|
||||
<property name="hover_selection">False</property>
|
||||
<property name="hover_expand">False</property>
|
||||
<property name="hscrollbar_policy">GTK_POLICY_ALWAYS</property>
|
||||
<property name="vscrollbar_policy">GTK_POLICY_ALWAYS</property>
|
||||
<property name="shadow_type">GTK_SHADOW_NONE</property>
|
||||
<property name="window_placement">GTK_CORNER_TOP_LEFT</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkTreeView" id="hide_tree">
|
||||
<property name="visible">True</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="headers_visible">True</property>
|
||||
<property name="rules_hint">True</property>
|
||||
<property name="reorderable">False</property>
|
||||
<property name="enable_search">True</property>
|
||||
<property name="fixed_height_mode">False</property>
|
||||
<property name="hover_selection">False</property>
|
||||
<property name="hover_expand">False</property>
|
||||
</widget>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="padding">0</property>
|
||||
<property name="expand">True</property>
|
||||
<property name="fill">True</property>
|
||||
</packing>
|
||||
</child>
|
||||
|
||||
<child>
|
||||
<widget class="GtkVBox" id="vbox8">
|
||||
<property name="border_width">6</property>
|
||||
<property name="visible">True</property>
|
||||
<property name="homogeneous">False</property>
|
||||
<property name="spacing">6</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkButton" id="unhide_sel_rows">
|
||||
<property name="visible">True</property>
|
||||
<property name="tooltip" translatable="yes">Unmark selected rows to not be ignored</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="relief">GTK_RELIEF_NORMAL</property>
|
||||
<property name="focus_on_click">True</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkImage" id="image8">
|
||||
<property name="visible">True</property>
|
||||
<property name="stock">gtk-undelete</property>
|
||||
<property name="icon_size">4</property>
|
||||
<property name="xalign">0.5</property>
|
||||
<property name="yalign">0.5</property>
|
||||
<property name="xpad">0</property>
|
||||
<property name="ypad">0</property>
|
||||
</widget>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="padding">0</property>
|
||||
<property name="expand">False</property>
|
||||
<property name="fill">False</property>
|
||||
</packing>
|
||||
</child>
|
||||
|
||||
<child>
|
||||
<widget class="GtkButton" id="unhide_all_rows">
|
||||
<property name="visible">True</property>
|
||||
<property name="tooltip" translatable="yes">Unmark all rows to not be ignored</property>
|
||||
<property name="can_focus">True</property>
|
||||
<property name="relief">GTK_RELIEF_NORMAL</property>
|
||||
<property name="focus_on_click">True</property>
|
||||
|
||||
<child>
|
||||
<widget class="GtkImage" id="image7">
|
||||
<property name="visible">True</property>
|
||||
<property name="stock">gtk-clear</property>
|
||||
<property name="icon_size">4</property>
|
||||
<property name="xalign">0.5</property>
|
||||
<property name="yalign">0.5</property>
|
||||
<property name="xpad">0</property>
|
||||
<property name="ypad">0</property>
|
||||
</widget>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="padding">0</property>
|
||||
<property name="expand">False</property>
|
||||
<property name="fill">False</property>
|
||||
</packing>
|
||||
</child>
|
||||
</widget>
|
||||
<packing>
|
||||
<property name="padding">0</property>
|
||||
<property name="expand">False</property>
|
||||
<property name="fill">False</property>
|
||||
</packing>
|
||||
</child>
|
||||
</widget>
|
||||
</child>
|
||||
|
Loading…
Reference in New Issue
Block a user