gramps/src/gen/lib/primaryobj.py

380 lines
12 KiB
Python
Raw Normal View History

2007-02-20 00:39:10 +00:00
#
# Gramps - a GTK+/GNOME based genealogy program
#
# Copyright (C) 2000-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$
"""
Basic Primary Object class for GRAMPS.
2007-02-20 00:39:10 +00:00
"""
#-------------------------------------------------------------------------
#
# standard python modules
#
#-------------------------------------------------------------------------
import time
import locale
2007-02-20 00:39:10 +00:00
#-------------------------------------------------------------------------
#
# GRAMPS modules
#
#-------------------------------------------------------------------------
from gen.lib.baseobj import BaseObject
from gen.lib.privacybase import PrivacyBase
from gen.lib.markertype import MarkerType
from gen.lib.srcbase import SourceBase
from gen.lib.mediabase import MediaBase
2007-02-20 00:39:10 +00:00
#-------------------------------------------------------------------------
#
# Localized constants
#
#-------------------------------------------------------------------------
try:
CODESET = locale.nl_langinfo(locale.CODESET)
except:
CODESET = locale.getpreferredencoding()
2007-02-20 00:39:10 +00:00
#-------------------------------------------------------------------------
#
# Basic Primary Object class
#
#-------------------------------------------------------------------------
class BasicPrimaryObject(BaseObject, PrivacyBase):
"""
The BasicPrimaryObject is the base class for Note objects.
2007-02-20 00:39:10 +00:00
It is also the base class for the PrimaryObject class.
The PrimaryObject is the base class for all other primary objects in the
database. Primary objects are the core objects in the database.
Each object has a database handle and a GRAMPS ID value. The database
handle is used as the record number for the database, and the GRAMPS
ID is the user visible version.
"""
def __init__(self, source=None):
"""
Initialize a PrimaryObject.
If source is None, both the ID and handle are assigned as empty
strings. If source is not None, then object is initialized from values
of the source object.
2007-02-20 00:39:10 +00:00
:param source: Object used to initialize the new object
:type source: PrimaryObject
2007-02-20 00:39:10 +00:00
"""
PrivacyBase.__init__(self, source)
if source:
self.gramps_id = source.gramps_id
self.handle = source.handle
self.change = source.change
self.marker = source.marker
else:
self.gramps_id = None
self.handle = None
self.change = 0
self.marker = MarkerType()
def get_change_time(self):
"""
Return the time that the data was last changed.
The value in the format returned by the time.time() command.
2007-02-20 00:39:10 +00:00
:returns: Time that the data was last changed. The value in the format
returned by the time.time() command.
:rtype: int
2007-02-20 00:39:10 +00:00
"""
return self.change
def set_change_time(self, change):
"""
Modify the time that the data was last changed.
The value must be in the format returned by the time.time() command.
@param change: new time
@type change: int in format as time.time() command
"""
self.change = change
2007-02-20 00:39:10 +00:00
def get_change_display(self):
"""
Return the string representation of the last change time.
2007-02-20 00:39:10 +00:00
:returns: string representation of the last change time.
:rtype: str
2007-02-20 00:39:10 +00:00
"""
if self.change:
return unicode(time.strftime('%x %X', time.localtime(self.change)),
CODESET)
2007-02-20 00:39:10 +00:00
else:
return u''
def set_handle(self, handle):
"""
Set the database handle for the primary object.
2007-02-20 00:39:10 +00:00
:param handle: object database handle
:type handle: str
2007-02-20 00:39:10 +00:00
"""
self.handle = handle
def get_handle(self):
"""
Return the database handle for the primary object.
2007-02-20 00:39:10 +00:00
:returns: database handle associated with the object
:rtype: str
2007-02-20 00:39:10 +00:00
"""
return self.handle
def set_gramps_id(self, gramps_id):
"""
Set the GRAMPS ID for the primary object.
2007-02-20 00:39:10 +00:00
:param gramps_id: GRAMPS ID
:type gramps_id: str
2007-02-20 00:39:10 +00:00
"""
self.gramps_id = gramps_id
def get_gramps_id(self):
"""
Return the GRAMPS ID for the primary object.
2007-02-20 00:39:10 +00:00
:returns: GRAMPS ID associated with the object
:rtype: str
2007-02-20 00:39:10 +00:00
"""
return self.gramps_id
def has_handle_reference(self, classname, handle):
"""
Return True if the object has reference to a given handle of given
primary object type.
2007-02-20 00:39:10 +00:00
:param classname: The name of the primary object class.
:type classname: str
:param handle: The handle to be checked.
:type handle: str
:returns:
Returns whether the object has reference to this handle of
this object type.
:rtype: bool
2007-02-20 00:39:10 +00:00
"""
return False
def remove_handle_references(self, classname, handle_list):
"""
Remove all references in this object to object handles in the list.
2007-02-20 00:39:10 +00:00
:param classname: The name of the primary object class.
:type classname: str
:param handle_list: The list of handles to be removed.
:type handle_list: str
2007-02-20 00:39:10 +00:00
"""
pass
def replace_handle_reference(self, classname, old_handle, new_handle):
"""
Replace all references to old handle with those to the new handle.
2007-02-20 00:39:10 +00:00
:param classname: The name of the primary object class.
:type classname: str
:param old_handle: The handle to be replaced.
:type old_handle: str
:param new_handle: The handle to replace the old one with.
:type new_handle: str
2007-02-20 00:39:10 +00:00
"""
pass
def set_marker(self, marker):
"""
Set the marker for the object.
:param marker: marker assigned to the object
:type marker: MarkerType
"""
2007-02-20 00:39:10 +00:00
self.marker.set(marker)
def get_marker(self):
"""
Return the marker for the object.
The exact type depends on the derived class type.
:returns: Returns the marker for the object.
:rtype: MarkerType
"""
2007-02-20 00:39:10 +00:00
return self.marker
def has_source_reference(self, handle):
"""
Indicate if the object has a source references.
In the base class, no such references exist. Derived classes should
override this if they provide source references.
"""
2007-02-20 00:39:10 +00:00
return False
def has_media_reference(self, handle):
"""
Indicate if the object has a media references.
In the base class, no such references exist. Derived classes should
override this if they provide media references.
"""
2007-02-20 00:39:10 +00:00
return False
def remove_source_references(self, handle_list):
"""
Remove the specified source references from the object.
In the base class no such references exist. Derived classes should
override this if they provide source references.
"""
2007-02-20 00:39:10 +00:00
pass
def remove_media_references(self, handle_list):
"""
Remove the specified media references from the object.
In the base class no such references exist. Derived classes should
override this if they provide media references.
"""
2007-02-20 00:39:10 +00:00
pass
def replace_source_references(self, old_handle, new_handle):
pass
def replace_media_references(self, old_handle, new_handle):
pass
#-------------------------------------------------------------------------
#
# Primary Object class
#
#-------------------------------------------------------------------------
class PrimaryObject(BasicPrimaryObject):
"""
The PrimaryObject is the base class for all primary objects in the
database.
Primary objects are the core objects in the database.
Each object has a database handle and a GRAMPS ID value. The database
handle is used as the record number for the database, and the GRAMPS
ID is the user visible version.
"""
def __init__(self, source=None):
"""
Initialize a PrimaryObject.
If source is None, both the ID and handle are assigned as empty
strings. If source is not None, then object is initialized from values
of the source object.
:param source: Object used to initialize the new object
:type source: PrimaryObject
"""
BasicPrimaryObject.__init__(self, source)
def has_handle_reference(self, classname, handle):
"""
Return True if the object has reference to a given handle of given
primary object type.
:param classname: The name of the primary object class.
:type classname: str
:param handle: The handle to be checked.
:type handle: str
:returns: Returns whether the object has reference to this handle
of this object type.
:rtype: bool
"""
if classname == 'Source' and isinstance(self, SourceBase):
return self.has_source_reference(handle)
elif classname == 'MediaObject' and isinstance(self, MediaBase):
return self.has_media_reference(handle)
else:
return self._has_handle_reference(classname, handle)
def remove_handle_references(self, classname, handle_list):
"""
Remove all references in this object to object handles in the list.
:param classname: The name of the primary object class.
:type classname: str
:param handle_list: The list of handles to be removed.
:type handle_list: str
"""
if classname == 'Source' and isinstance(self, SourceBase):
self.remove_source_references(handle_list)
elif classname == 'MediaObject' and isinstance(self, MediaBase):
self.remove_media_references(handle_list)
else:
self._remove_handle_references(classname, handle_list)
def replace_handle_reference(self, classname, old_handle, new_handle):
"""
Replace all references to old handle with those to the new handle.
:param classname: The name of the primary object class.
:type classname: str
:param old_handle: The handle to be replaced.
:type old_handle: str
:param new_handle: The handle to replace the old one with.
:type new_handle: str
"""
if classname == 'Source' and isinstance(self, SourceBase):
self.replace_source_references(old_handle, new_handle)
elif classname == 'MediaObject' and isinstance(self, MediaBase):
self.replace_media_references(old_handle, new_handle)
else:
self._replace_handle_reference(classname, old_handle, new_handle)
def _has_handle_reference(self, classname, handle):
"""
Return True if the handle is referenced by the object.
"""
return False
def _remove_handle_references(self, classname, handle_list):
"""
Remove the handle references from the object.
"""
pass
def _replace_handle_reference(self, classname, old_handle, new_handle):
"""
Replace the handle reference with the new reference.
"""
pass
def set_marker(self, marker):
self.marker.set(marker)
def get_marker(self):
return self.marker