* src/Report.py: Fix adding styles and calling doc.init().

* src/BaseDoc.py: Restructure header; Replace tabs with spaces.
* src/plugins/AncestorChart.py (calc): Remove doc.init() call.
* src/plugins/AncestorChart2.py (calc): Remove doc.init() call.
* src/plugins/Ancestors.py (define_table_styles): Add method.
* src/plugins/FamilyGroup.py (define_table_styles): Add method.
* src/plugins/FanChart.py (define_graphics_styles): Add method.
* src/plugins/FtmStyleDescendants.py (define_table_styles):
Add method.
* src/plugins/FtmStyleAncestors.py: Minor cleanups
* src/plugins/IndivComplete.py (define_table_styles): Add method.
* src/plugins/IndivSummary.py (define_table_styles): Add method.
* src/plugins/Partition.py: Remove from CVS.
* src/plugins/StatisticsChart.py (define_graphics_styles):
Add method.
* src/plugins/TimeLine.py (define_graphics_styles): Add method.


svn: r3948
This commit is contained in:
Alex Roitman 2005-01-24 16:33:47 +00:00
parent e70e6c6e68
commit 73f958b915
15 changed files with 99 additions and 347 deletions

View File

@ -1,3 +1,21 @@
2005-01-24 Alex Roitman <shura@alex.neuro.umn.edu>
* src/Report.py: Fix adding styles and calling doc.init().
* src/BaseDoc.py: Restructure header; Replace tabs with spaces.
* src/plugins/AncestorChart.py (calc): Remove doc.init() call.
* src/plugins/AncestorChart2.py (calc): Remove doc.init() call.
* src/plugins/Ancestors.py (define_table_styles): Add method.
* src/plugins/FamilyGroup.py (define_table_styles): Add method.
* src/plugins/FanChart.py (define_graphics_styles): Add method.
* src/plugins/FtmStyleDescendants.py (define_table_styles):
Add method.
* src/plugins/FtmStyleAncestors.py: Minor cleanups
* src/plugins/IndivComplete.py (define_table_styles): Add method.
* src/plugins/IndivSummary.py (define_table_styles): Add method.
* src/plugins/Partition.py: Remove from CVS.
* src/plugins/StatisticsChart.py (define_graphics_styles):
Add method.
* src/plugins/TimeLine.py (define_graphics_styles): Add method.
2005-01-23 Don Allingham <dallingham@users.sourceforge.net> 2005-01-23 Don Allingham <dallingham@users.sourceforge.net>
* src/BaseDoc.py: don't check for init on table or cell addition * src/BaseDoc.py: don't check for init on table or cell addition
* src/Report.py: Call doc.init() before write_report * src/Report.py: Call doc.init() before write_report

View File

@ -1,8 +1,23 @@
# #
# Gramps - a GTK+/GNOME based genealogy program # Gramps - a GTK+/GNOME based genealogy program
# #
# Copyright (C) 2000-2004 Donald N. Allingham # Copyright (C) 2000-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
#
# Modified September 2002 by Gary Shao # Modified September 2002 by Gary Shao
# #
# Added line_break() method to BaseDoc class to allow breaking a line # Added line_break() method to BaseDoc class to allow breaking a line
@ -34,20 +49,6 @@
# modules the PDF generator is based on does not support them at this # modules the PDF generator is based on does not support them at this
# time) # time)
# #
# 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$ # $Id$
@ -120,7 +121,6 @@ GRAPHICS_MODE = 1
SOLID = 0 SOLID = 0
DASHED = 1 DASHED = 1
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# #
# cnv2color # cnv2color
@ -287,7 +287,7 @@ class FontStyle:
def get_color(self): def get_color(self):
"Returns an RGB color tuple" "Returns an RGB color tuple"
return self.color return self.color
def set_size(self,val): def set_size(self,val):
"sets font size in points" "sets font size in points"
@ -385,7 +385,7 @@ class TableStyle:
@param index: column being set (index starts at 0) @param index: column being set (index starts at 0)
@param width: percentage of the table width assigned to the column @param width: percentage of the table width assigned to the column
""" """
self.colwid[index] = width self.colwid[index] = width
def get_column_width(self,index): def get_column_width(self,index):
""" """
@ -394,7 +394,7 @@ class TableStyle:
@param index: column to return (index starts at 0) @param index: column to return (index starts at 0)
""" """
return self.colwid[index] return self.colwid[index]
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# #
@ -419,15 +419,15 @@ class TableCellStyle:
self.tborder = obj.tborder self.tborder = obj.tborder
self.bborder = obj.bborder self.bborder = obj.bborder
self.padding = obj.padding self.padding = obj.padding
self.longlist = obj.longlist self.longlist = obj.longlist
else: else:
self.rborder = 0 self.rborder = 0
self.lborder = 0 self.lborder = 0
self.tborder = 0 self.tborder = 0
self.bborder = 0 self.bborder = 0
self.padding = 0 self.padding = 0
self.longlist = 0 self.longlist = 0
def set_padding(self,val): def set_padding(self,val):
"Returns the cell padding in centimeters" "Returns the cell padding in centimeters"
self.padding = val self.padding = val
@ -514,11 +514,11 @@ class ParagraphStyle:
self.lmargin = source.lmargin self.lmargin = source.lmargin
self.first_indent = source.first_indent self.first_indent = source.first_indent
self.align = source.align self.align = source.align
self.level = source.level self.level = source.level
self.top_border = source.top_border self.top_border = source.top_border
self.bottom_border = source.bottom_border self.bottom_border = source.bottom_border
self.right_border = source.right_border self.right_border = source.right_border
self.left_border = source.left_border self.left_border = source.left_border
self.pad = source.pad self.pad = source.pad
self.bgcolor = source.bgcolor self.bgcolor = source.bgcolor
self.description = source.description self.description = source.description
@ -528,11 +528,11 @@ class ParagraphStyle:
self.lmargin = 0 self.lmargin = 0
self.first_indent = 0 self.first_indent = 0
self.align = PARA_ALIGN_LEFT self.align = PARA_ALIGN_LEFT
self.level = 0 self.level = 0
self.top_border = 0 self.top_border = 0
self.bottom_border = 0 self.bottom_border = 0
self.right_border = 0 self.right_border = 0
self.left_border = 0 self.left_border = 0
self.pad = 0 self.pad = 0
self.bgcolor = (255,255,255) self.bgcolor = (255,255,255)
self.description = "" self.description = ""
@ -646,7 +646,7 @@ class ParagraphStyle:
def get_bottom_border(self): def get_bottom_border(self):
"Returns 1 if a bottom border is specified" "Returns 1 if a bottom border is specified"
return self.bottom_border return self.bottom_border
def set_left_border(self,val): def set_left_border(self,val):
""" """
@ -719,27 +719,27 @@ class ParagraphStyle:
return "unknown" return "unknown"
def set_left_margin(self,value): def set_left_margin(self,value):
"sets the left paragraph margin in centimeters" "sets the left paragraph margin in centimeters"
self.lmargin = value self.lmargin = value
def set_right_margin(self,value): def set_right_margin(self,value):
"sets the right paragraph margin in centimeters" "sets the right paragraph margin in centimeters"
self.rmargin = value self.rmargin = value
def set_first_indent(self,value): def set_first_indent(self,value):
"sets the first indent margin in centimeters" "sets the first indent margin in centimeters"
self.first_indent = value self.first_indent = value
def get_left_margin(self): def get_left_margin(self):
"returns the left margin in centimeters" "returns the left margin in centimeters"
return self.lmargin return self.lmargin
def get_right_margin(self): def get_right_margin(self):
"returns the right margin in centimeters" "returns the right margin in centimeters"
return self.rmargin return self.rmargin
def get_first_indent(self): def get_first_indent(self):
"returns the first indent margin in centimeters" "returns the first indent margin in centimeters"
return self.first_indent return self.first_indent
#------------------------------------------------------------------------ #------------------------------------------------------------------------
@ -996,7 +996,7 @@ class GraphicsStyle:
self.para_name = obj.para_name self.para_name = obj.para_name
self.shadow = obj.shadow self.shadow = obj.shadow
self.shadow_space = obj.shadow_space self.shadow_space = obj.shadow_space
self.color = obj.color self.color = obj.color
self.fill_color = obj.fill_color self.fill_color = obj.fill_color
self.lwidth = obj.lwidth self.lwidth = obj.lwidth
self.lstyle = obj.lstyle self.lstyle = obj.lstyle
@ -1049,7 +1049,7 @@ class GraphicsStyle:
return self.height return self.height
def get_width(self): def get_width(self):
return self.width return self.width
def get_paragraph_style(self): def get_paragraph_style(self):
return self.para_name return self.para_name
@ -1105,10 +1105,10 @@ class BaseDoc:
self.title = "" self.title = ""
self.owner = '' self.owner = ''
self.draw_styles = {} self.draw_styles = {}
self.font = FontStyle() self.font = FontStyle()
self.style_list = styles.get_styles() self.style_list = styles.get_styles()
self.table_styles = {} self.table_styles = {}
self.cell_styles = {} self.cell_styles = {}
self.name = "" self.name = ""
self.media_list = [] self.media_list = []
@ -1235,7 +1235,7 @@ class BaseDoc:
def line_break(self): def line_break(self):
"Forces a line break within a paragraph" "Forces a line break within a paragraph"
pass pass
def page_break(self): def page_break(self):
"Forces a page break, creating a new page" "Forces a page break, creating a new page"
@ -1255,10 +1255,10 @@ class BaseDoc:
def start_listing(self,style_name): def start_listing(self,style_name):
""" """
Starts a new listing block, using the specified style name. Starts a new listing block, using the specified style name.
@param style_name: name of the ParagraphStyle to use for the block. @param style_name: name of the ParagraphStyle to use for the block.
""" """
pass pass
def end_listing(self): def end_listing(self):
@ -1353,10 +1353,10 @@ class BaseDoc:
pass pass
def draw_box(self,style,text,x,y): def draw_box(self,style,text,x,y):
pass pass
def write_at(self,style,text,x,y): def write_at(self,style,text,x,y):
pass pass
def draw_bar(self,style,x1,y1,x2,y2): def draw_bar(self,style,x1,y1,x2,y2):
pass pass
@ -1371,7 +1371,7 @@ class BaseDoc:
pass pass
def draw_line(self,style,x1,y1,x2,y2): def draw_line(self,style,x1,y1,x2,y2):
pass pass
def draw_wedge(self, style, centerx, centery, radius, start_angle, def draw_wedge(self, style, centerx, centery, radius, start_angle,
end_angle, short_radius=0): end_angle, short_radius=0):

View File

@ -216,12 +216,13 @@ class Report:
if output: if output:
self.standalone = True self.standalone = True
self.doc.open(options_class.get_output()) self.doc.open(options_class.get_output())
self.doc.init()
else: else:
self.standalone = False self.standalone = False
self.define_table_styles()
self.define_graphics_styles()
def begin_report(self): def begin_report(self):
self.doc.init()
if self.options_class.get_newpage(): if self.options_class.get_newpage():
self.doc.page_break() self.doc.page_break()
@ -232,6 +233,18 @@ class Report:
if self.standalone: if self.standalone:
self.doc.close() self.doc.close()
def define_table_styles(self):
"""
This method MUST be used for adding table and cell styles.
"""
pass
def define_graphics_styles(self):
"""
This method MUST be used for adding drawing styles.
"""
pass
def get_progressbar_data(self): def get_progressbar_data(self):
"""The window title for this dialog, and the header line to """The window title for this dialog, and the header line to
put at the top of the contents of the dialog box.""" put at the top of the contents of the dialog box."""
@ -1759,6 +1772,7 @@ def report(database,person,report_class,options_class,translated_name,name,categ
if response: if response:
try: try:
MyReport = report_class(dialog.db,dialog.person,dialog.options) MyReport = report_class(dialog.db,dialog.person,dialog.options)
MyReport.doc.init()
MyReport.begin_report() MyReport.begin_report()
MyReport.write_report() MyReport.write_report()
MyReport.end_report() MyReport.end_report()
@ -1806,6 +1820,7 @@ def cl_report(database,name,category,report_class,options_class,options_str_dict
clr.option_class.handler.doc = clr.format( clr.option_class.handler.doc = clr.format(
clr.selected_style,clr.paper,clr.template_name,clr.orien) clr.selected_style,clr.paper,clr.template_name,clr.orien)
MyReport = report_class(database, clr.person, clr.option_class) MyReport = report_class(database, clr.person, clr.option_class)
MyReport.doc.init()
MyReport.begin_report() MyReport.begin_report()
MyReport.write_report() MyReport.write_report()
MyReport.end_report() MyReport.end_report()

View File

@ -177,8 +177,6 @@ class AncestorChart(Report.Report):
g = BaseDoc.GraphicsStyle() g = BaseDoc.GraphicsStyle()
self.doc.add_draw_style("AC-line",g) self.doc.add_draw_style("AC-line",g)
if self.standalone:
self.doc.init()
def get_numbers(self,start,index,vals): def get_numbers(self,start,index,vals):
if index > 4: if index > 4:

View File

@ -344,8 +344,6 @@ class AncestorChart(Report.Report):
g = BaseDoc.GraphicsStyle() g = BaseDoc.GraphicsStyle()
self.doc.add_draw_style("AC2-line",g) self.doc.add_draw_style("AC2-line",g)
if self.standalone:
self.doc.init()
def print_page(self,startx,stopx,starty,stopy,colx,coly): def print_page(self,startx,stopx,starty,stopy,colx,coly):

View File

@ -86,6 +86,7 @@ class ComprehensiveAncestorsReport (Report.Report):
self.RelClass = PluginMgr.relationship_class self.RelClass = PluginMgr.relationship_class
self.relationship = self.RelClass(database) self.relationship = self.RelClass(database)
def define_table_styles(self):
table = BaseDoc.TableStyle () table = BaseDoc.TableStyle ()
table.set_column_widths ([15, 85]) table.set_column_widths ([15, 85])
table.set_width (100) table.set_width (100)
@ -131,7 +132,6 @@ class ComprehensiveAncestorsReport (Report.Report):
cell.set_padding (0.1) cell.set_padding (0.1)
self.doc.add_cell_style ("AR-Entry", cell) self.doc.add_cell_style ("AR-Entry", cell)
def write_report(self): def write_report(self):
self.sources = [] self.sources = []
name = self.person_name (self.start_person.get_handle()) name = self.person_name (self.start_person.get_handle())

View File

@ -89,9 +89,7 @@ class FamilyGroup(Report.Report):
self.family = family self.family = family
break break
self.setup() def define_table_styles(self):
def setup(self):
""" """
Define the table styles used by the report. Define the table styles used by the report.
""" """

View File

@ -54,7 +54,6 @@ from ReportUtils import pt2cm
class FanChart(Report.Report): class FanChart(Report.Report):
def __init__(self,database,person,options_class): def __init__(self,database,person,options_class):
#database,person,display,doc,output,newpage=0):
""" """
Creates the FanChart object that produces the report. Creates the FanChart object that produces the report.
@ -78,9 +77,7 @@ class FanChart(Report.Report):
self.text= {} self.text= {}
self.box_width = 0 self.box_width = 0
self.setup() def define_graphics_styles(self):
def setup(self):
g = BaseDoc.GraphicsStyle() g = BaseDoc.GraphicsStyle()
g.set_paragraph_style('FC-Title') g.set_paragraph_style('FC-Title')
g.set_line_width(0) g.set_line_width(0)

View File

@ -1,7 +1,7 @@
# #
# Gramps - a GTK+/GNOME based genealogy program # Gramps - a GTK+/GNOME based genealogy program
# #
# Copyright (C) 2003-2004 Donald N. Allingham # Copyright (C) 2003-2005 Donald N. Allingham
# #
# This program is free software; you can redistribute it and/or modify # 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 # it under the terms of the GNU General Public License as published by
@ -37,19 +37,10 @@ from gettext import gettext as _
import Report import Report
import BaseDoc import BaseDoc
import RelLib import RelLib
import Errors
from QuestionDialog import ErrorDialog
import ReportOptions import ReportOptions
import DateHandler from DateHandler import displayer as dd
import const import const
#------------------------------------------------------------------------
#
#
#
#------------------------------------------------------------------------
dd = DateHandler.displayer
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# #
# AncestorReport # AncestorReport

View File

@ -1,7 +1,7 @@
# #
# Gramps - a GTK+/GNOME based genealogy program # Gramps - a GTK+/GNOME based genealogy program
# #
# Copyright (C) 2003-2004 Donald N. Allingham # Copyright (C) 2003-2005 Donald N. Allingham
# #
# This program is free software; you can redistribute it and/or modify # 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 # it under the terms of the GNU General Public License as published by
@ -40,20 +40,11 @@ from gettext import gettext as _
import Report import Report
import BaseDoc import BaseDoc
import RelLib import RelLib
import Errors
import Utils import Utils
import ReportOptions import ReportOptions
from QuestionDialog import ErrorDialog from DateHandler import displayer as dd
import DateHandler
import const import const
#------------------------------------------------------------------------
#
#
#
#------------------------------------------------------------------------
dd = DateHandler.displayer
#------------------------------------------------------------------------ #------------------------------------------------------------------------
# #
# DescendantReport # DescendantReport
@ -86,12 +77,10 @@ class FtmDescendantReport(Report.Report):
(self.max_generations,self.pgbrk) \ (self.max_generations,self.pgbrk) \
= options_class.get_report_generations() = options_class.get_report_generations()
self.setup()
self.sref_map = {} self.sref_map = {}
self.sref_index = 0 self.sref_index = 0
def setup(self): def define_table_styles(self):
tbl = BaseDoc.TableStyle() tbl = BaseDoc.TableStyle()
tbl.set_width(100) tbl.set_width(100)
tbl.set_columns(3) tbl.set_columns(3)

View File

@ -1,7 +1,7 @@
# #
# Gramps - a GTK+/GNOME based genealogy program # Gramps - a GTK+/GNOME based genealogy program
# #
# Copyright (C) 2000-2004 Donald N. Allingham # Copyright (C) 2000-2005 Donald N. Allingham
# #
# This program is free software; you can redistribute it and/or modify # 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 # it under the terms of the GNU General Public License as published by
@ -43,11 +43,8 @@ import gtk
import RelLib import RelLib
import const import const
import BaseDoc import BaseDoc
import StyleEditor
import Report import Report
import GenericFilter import GenericFilter
import Errors
from QuestionDialog import ErrorDialog
import ReportOptions import ReportOptions
#------------------------------------------------------------------------ #------------------------------------------------------------------------
@ -84,13 +81,8 @@ class IndivCompleteReport(Report.Report):
filters = options_class.get_report_filters(person) filters = options_class.get_report_filters(person)
filters.extend(GenericFilter.CustomFilters.get_filters()) filters.extend(GenericFilter.CustomFilters.get_filters())
self.filter = filters[filter_num] self.filter = filters[filter_num]
c = database.get_researcher().get_name()
self.doc.creator(c)
self.map = {}
self.setup()
def setup(self): def define_table_styles(self):
tbl = BaseDoc.TableStyle() tbl = BaseDoc.TableStyle()
tbl.set_width(100) tbl.set_width(100)
tbl.set_columns(2) tbl.set_columns(2)

View File

@ -1,7 +1,7 @@
# #
# Gramps - a GTK+/GNOME based genealogy program # Gramps - a GTK+/GNOME based genealogy program
# #
# Copyright (C) 2000-2004 Donald N. Allingham # Copyright (C) 2000-2005 Donald N. Allingham
# #
# This program is free software; you can redistribute it and/or modify # 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 # it under the terms of the GNU General Public License as published by
@ -45,10 +45,7 @@ import gtk
import RelLib import RelLib
import const import const
import BaseDoc import BaseDoc
import StyleEditor
import Report import Report
import Errors
from QuestionDialog import ErrorDialog
import ReportOptions import ReportOptions
import const import const
@ -73,10 +70,7 @@ class IndivSummary(Report.Report):
Report.Report.__init__(self,database,person,options_class) Report.Report.__init__(self,database,person,options_class)
self.map = {} def define_table_styles(self):
self.setup()
def setup(self):
tbl = BaseDoc.TableStyle() tbl = BaseDoc.TableStyle()
tbl.set_width(100) tbl.set_width(100)
tbl.set_columns(2) tbl.set_columns(2)

View File

@ -1,234 +0,0 @@
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2003 Jesper Zedlitz
# Copyright (C) 2003-2004 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$
"Export/Partition"
#------------------------------------------------------------------------
#
# standard python modules
#
#------------------------------------------------------------------------
import os
import posixpath
#------------------------------------------------------------------------
#
# GRAMPS modules
#
#------------------------------------------------------------------------
import Utils
import RelLib
import GrampsCfg
from QuestionDialog import ErrorDialog
from gettext import gettext as _
#------------------------------------------------------------------------
#
# GNOME/GTK modules
#
#------------------------------------------------------------------------
import gobject
import gtk
import gtk.glade
from gnome.ui import *
import WriteXML
personSeen = []
familySeen = []
#database_for_unlinked_persons = RelLib.GrampsDB()
prefix = "/tmp/test"
#-------------------------------------------------------------------------
#
#
#
#-------------------------------------------------------------------------
def work_on_person( db, person ):
global personSeen
if (len(person.get_family_handle_list()) + len(person.get_parent_family_handle_list())) > 0:
database = db
#else:
# database = database_for_unlinked_persons
if( database.get_person_handle_map().has_key( person.get_handle() ) ):
return
database.add_person_no_map( person, person.get_handle() )
personSeen.append(person)
for source_ref in person.get_primary_name().get_source_references():
work_on_sourceref( database, source_ref)
for name in person.get_alternate_names():
for source_ref in name.get_source_references():
work_on_sourceref( database, source_ref)
work_on_event( database, person.get_birth() )
work_on_event( database, person.get_death() )
for event in person.get_event_list():
work_on_event(database, event)
# recursion
for fam in person.get_family_handle_list():
work_on_family( database, fam )
for fam in person.get_parent_family_handle_list():
work_on_family( database, fam[0] )
#-------------------------------------------------------------------------
#
#
#
#-------------------------------------------------------------------------
def work_on_family( database, family ):
global familySeen
if database.get_family_handle_map().has_key( family.get_handle() ):
return
database.get_family_handle_map()[family.get_handle()] = family
familySeen.append(family)
work_on_event( database, family.get_marriage() )
for event in family.get_event_list():
work_on_event(database, event)
# recursion
father = family.get_father_handle()
if( father != None ):
work_on_person( database, father )
mother = family.get_mother_handle()
if( mother != None ):
work_on_person( database, mother )
for person in family.get_child_handle_list():
work_on_person( database, person )
#-------------------------------------------------------------------------
#
#
#
#-------------------------------------------------------------------------
def work_on_sourceref( database, source_ref ):
if source_ref == None:
return
source = source_ref.get_base_handle()
if source == None:
return
if database.get_source_map().has_key(source.get_handle()):
return
database.add_source_no_map( source, source.get_handle() );
#-------------------------------------------------------------------------
#
#
#
#-------------------------------------------------------------------------
def work_on_event( database, event ):
if event == None:
return
for source_ref in event.get_source_references():
work_on_sourceref( database, source_ref)
work_on_place( database, event.get_place_handle() )
#-------------------------------------------------------------------------
#
#
#
#-------------------------------------------------------------------------
def work_on_place( database, place ):
if place == None:
return
if place in database.get_place_handles():
return
database.add_place_no_map(place, place.get_handle())
#-------------------------------------------------------------------------
#
#
#
#-------------------------------------------------------------------------
def report(db, person):
global personSeen
global prefix
global database_for_unlinked_persons
text = "=== Partitions ===\n"
count = 0
for p in db.get_person_handle_map().values():
if not p in personSeen:
database = RelLib.GrampsDB()
work_on_person( database, p )
person_len = len(database.get_person_handles(sort_handles=False))
if person_len > 0:
g = WriteXML.XmlWriter(database,None,0,0)
g.write(prefix+str(count)+".xml")
text += "partition "+prefix+str(count)+".xml written ( "+str(person_len)+" persons)\n"
count += 1
g = WriteXML.XmlWriter(database_for_unlinked_persons,None,0,0)
g.write(prefix+".xml")
text += "partition "+prefix+".xml written ( "+str(len(database_for_unlinked_persons.get_person_handles(sort_handles=False)))+" persons)\n"
base = os.path.dirname(__file__)
glade_file = "%s/summary.glade" % base
topDialog = gtk.glade.XML(glade_file,"summary","gramps")
topDialog.signal_autoconnect({
"destroy_passed_object" : Utils.destroy_passed_object,
})
top = topDialog.get_widget("summary")
textwindow = topDialog.get_widget("textwindow")
textwindow.get_buffer().set_text(text)
top.show()
#-------------------------------------------------------------------------
#
#
#
#-------------------------------------------------------------------------
from PluginMgr import register_report
register_report(
report,
_("Partitions"),
status=(_("Alpha")),
category=_("Export"),
description=_("This program partitions individuals in a database into disjoint partitions.\n"+
"A partition is composed of people related by one or more multiple relations.\n"+
"There should be no known relationship between people in different partitions.")
)

View File

@ -409,8 +409,6 @@ class StatisticsChart(Report.Report):
print heading print heading
print table[1] print table[1]
self.setup()
def index_items(self, data, sort, reverse): def index_items(self, data, sort, reverse):
"""creates & stores a sorted index for the items""" """creates & stores a sorted index for the items"""
@ -434,7 +432,7 @@ class StatisticsChart(Report.Report):
return index return index
def setup(self): def define_graphics_styles(self):
""" """
Define the graphics styles used by the report. Paragraph definitions Define the graphics styles used by the report. Paragraph definitions
have already been defined in the document. The styles used are: have already been defined in the document. The styles used are:
@ -466,7 +464,7 @@ class StatisticsChart(Report.Report):
g.set_width(self.doc.get_usable_width()) g.set_width(self.doc.get_usable_width())
self.doc.add_draw_style("SC-title",g) self.doc.add_draw_style("SC-title",g)
def write_report(self): def write_report(self):
"output the selected statistics..." "output the selected statistics..."

View File

@ -95,9 +95,7 @@ class TimeLine(Report.Report):
sort_functions = options_class.get_sort_functions(Sort.Sort(database)) sort_functions = options_class.get_sort_functions(Sort.Sort(database))
self.sort_func = sort_functions[sort_func_num][1] self.sort_func = sort_functions[sort_func_num][1]
self.setup() def define_graphics_styles(self):
def setup(self):
""" """
Define the graphics styles used by the report. Paragraph definitions Define the graphics styles used by the report. Paragraph definitions
have already been defined in the document. The styles used are: have already been defined in the document. The styles used are: