Tweaks to database objects plus initial documentation in rst format
svn: r13157
This commit is contained in:
parent
939ef94e67
commit
ee9f1e82e0
@ -6,4 +6,38 @@ Contents:
|
|||||||
|
|
||||||
.. automodule:: gen.db
|
.. automodule:: gen.db
|
||||||
|
|
||||||
**TODO**
|
*****************************
|
||||||
|
Base object
|
||||||
|
*****************************
|
||||||
|
|
||||||
|
GrampsDbBase
|
||||||
|
====================================
|
||||||
|
.. automodule:: gen.db.base
|
||||||
|
.. autoclass:: gen.db.base.GrampsDbBase
|
||||||
|
:members:
|
||||||
|
:undoc-members:
|
||||||
|
:show-inheritance:
|
||||||
|
|
||||||
|
*****************************
|
||||||
|
Read object
|
||||||
|
*****************************
|
||||||
|
|
||||||
|
GrampsDbRead
|
||||||
|
====================================
|
||||||
|
.. automodule:: gen.db.read
|
||||||
|
.. autoclass:: gen.db.read.GrampsDbRead
|
||||||
|
:members:
|
||||||
|
:show-inheritance:
|
||||||
|
|
||||||
|
*****************************
|
||||||
|
Write object
|
||||||
|
*****************************
|
||||||
|
|
||||||
|
GrampsDbWrite
|
||||||
|
====================================
|
||||||
|
.. automodule:: gen.db.write
|
||||||
|
.. autoclass:: gen.db.write.GrampsDBDir
|
||||||
|
:members:
|
||||||
|
:undoc-members:
|
||||||
|
:show-inheritance:
|
||||||
|
|
||||||
|
@ -20,8 +20,8 @@
|
|||||||
|
|
||||||
from base import *
|
from base import *
|
||||||
from dbconst import *
|
from dbconst import *
|
||||||
from read import *
|
|
||||||
from cursor import *
|
from cursor import *
|
||||||
|
from read import *
|
||||||
from bsddbtxn import *
|
from bsddbtxn import *
|
||||||
from txn import *
|
from txn import *
|
||||||
from undoredo import *
|
from undoredo import *
|
||||||
|
@ -94,52 +94,14 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def del_person(self, handle):
|
def set_auto_remove(self):
|
||||||
"""
|
"""
|
||||||
Delete a Person object given the handle
|
BSDDB change log settings using new method with renamed attributes
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def del_source(self, handle):
|
def write_version(self, name):
|
||||||
"""
|
"""Write version number for a newly created DB."""
|
||||||
Delete a Source object given the handle
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def del_repository(self, handle):
|
|
||||||
"""
|
|
||||||
Delete a Repository object given the handle
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def del_note(self, handle):
|
|
||||||
"""
|
|
||||||
Delete a Person object given the handle
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def del_place(self, handle):
|
|
||||||
"""
|
|
||||||
Delete a Place object given the handle
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def del_media(self, handle):
|
|
||||||
"""
|
|
||||||
Delete a Media object given the handle
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def del_family(self, handle):
|
|
||||||
"""
|
|
||||||
Delete a Family object given the handle
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def del_event(self, handle):
|
|
||||||
"""
|
|
||||||
Delete an Event object given the handle
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def create_id(self):
|
def create_id(self):
|
||||||
@ -154,93 +116,63 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_person_cursor_iter(self, msg=None):
|
|
||||||
"""
|
|
||||||
Return a reference to a cursor iterator over Person objects
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_family_cursor(self):
|
def get_family_cursor(self):
|
||||||
"""
|
"""
|
||||||
Return a reference to a cursor over Family objects
|
Return a reference to a cursor over Family objects
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_family_cursor_iter(self, msg=None):
|
|
||||||
"""
|
|
||||||
Return a reference to a cursor iterator over Family objects
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_event_cursor(self):
|
def get_event_cursor(self):
|
||||||
"""
|
"""
|
||||||
Return a reference to a cursor over Family objects
|
Return a reference to a cursor over Family objects
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_event_cursor_iter(self, msg=None):
|
|
||||||
"""
|
|
||||||
Return a reference to a cursor iterator over Family objects
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_place_cursor(self):
|
def get_place_cursor(self):
|
||||||
"""
|
"""
|
||||||
Return a reference to a cursor over Place objects
|
Return a reference to a cursor over Place objects
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_place_cursor_iter(self, msg=None):
|
|
||||||
"""
|
|
||||||
Return a reference to a cursor iterator over Place objects
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_source_cursor(self):
|
def get_source_cursor(self):
|
||||||
"""
|
"""
|
||||||
Return a reference to a cursor over Source objects
|
Return a reference to a cursor over Source objects
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_source_cursor_iter(self, msg=None):
|
|
||||||
"""
|
|
||||||
Return a reference to a cursor iterator over Source objects
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_media_cursor(self):
|
def get_media_cursor(self):
|
||||||
"""
|
"""
|
||||||
Return a reference to a cursor over Media objects
|
Return a reference to a cursor over Media objects
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_media_cursor_iter(self, msg=None):
|
|
||||||
"""
|
|
||||||
Return a reference to a cursor iterator over Media objects
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_repository_cursor(self):
|
def get_repository_cursor(self):
|
||||||
"""
|
"""
|
||||||
Return a reference to a cursor over Repository objects
|
Return a reference to a cursor over Repository objects
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_repository_cursor_iter(self, msg=None):
|
|
||||||
"""
|
|
||||||
Return a reference to a cursor iterator over Repository objects
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_note_cursor(self):
|
def get_note_cursor(self):
|
||||||
"""
|
"""
|
||||||
Return a reference to a cursor over Note objects
|
Return a reference to a cursor over Note objects
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_note_cursor_iter(self, msg=None):
|
def get_reference_map_cursor(self):
|
||||||
"""
|
"""
|
||||||
Return a reference to a cursor iterator over Note objects
|
Returns a reference to a cursor over the reference map
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def get_reference_map_primary_cursor(self):
|
||||||
|
"""
|
||||||
|
Returns a reference to a cursor over the reference map primary map
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def get_reference_map_referenced_cursor(self):
|
||||||
|
"""
|
||||||
|
Returns a reference to a cursor over the reference map referenced map
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -293,8 +225,7 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def commit_base(self, obj, data_map, key, update_list, add_list,
|
def commit_base(self, obj, data_map, key, transaction, change_time):
|
||||||
transaction, change_time):
|
|
||||||
"""
|
"""
|
||||||
Commit the specified object to the database, storing the changes as
|
Commit the specified object to the database, storing the changes as
|
||||||
part of the transaction.
|
part of the transaction.
|
||||||
@ -504,9 +435,9 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
If no object exists, a new object is added to the database.
|
If no object exists, a new object is added to the database.
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -516,9 +447,9 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
If no such Person exists, a new Person is added to the database.
|
If no such Person exists, a new Person is added to the database.
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -528,9 +459,9 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
If no such Source exists, a new Source is added to the database.
|
If no such Source exists, a new Source is added to the database.
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -539,10 +470,8 @@ class GrampsDbBase(object):
|
|||||||
Find a Event in the database from the passed handle.
|
Find a Event in the database from the passed handle.
|
||||||
|
|
||||||
If no such Event exists, a new Event is added to the database.
|
If no such Event exists, a new Event is added to the database.
|
||||||
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -552,9 +481,9 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
If no such MediaObject exists, a new Object is added to the database.
|
If no such MediaObject exists, a new Object is added to the database.
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -564,9 +493,9 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
If no such Place exists, a new Place is added to the database.
|
If no such Place exists, a new Place is added to the database.
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -576,9 +505,9 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
If no such Family exists, a new Family is added to the database.
|
If no such Family exists, a new Family is added to the database.
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -588,9 +517,9 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
If no such Repository exists, a new Repository is added to the database.
|
If no such Repository exists, a new Repository is added to the database.
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -600,9 +529,9 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
If no such Note exists, a new Note is added to the database.
|
If no such Note exists, a new Note is added to the database.
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
:returns: Returns a tuple, first the object, second a bool which is True
|
||||||
if the object is new
|
if the object is new
|
||||||
@rtype: tuple
|
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -927,15 +856,17 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def iter_person_handles(self):
|
def get_family_handles(self):
|
||||||
"""
|
"""
|
||||||
Return an iterator over handles for Persons in the database
|
Return a list of database handles, one handle for each Family in
|
||||||
|
the database.
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def iter_people(self):
|
def get_event_handles(self):
|
||||||
"""
|
"""
|
||||||
Return an iterator over handles and objects for Persons in the database
|
Return a list of database handles, one handle for each Event in the
|
||||||
|
database.
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
@ -948,12 +879,6 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def iter_place_handles(self):
|
|
||||||
"""
|
|
||||||
Return an iterator over handles for Places in the database
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_source_handles(self, sort_handles=True):
|
def get_source_handles(self, sort_handles=True):
|
||||||
"""
|
"""
|
||||||
Return a list of database handles, one handle for each Source in
|
Return a list of database handles, one handle for each Source in
|
||||||
@ -963,12 +888,6 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def iter_source_handles(self):
|
|
||||||
"""
|
|
||||||
Return an iterator over handles for Sources in the database
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_media_object_handles(self, sort_handles=True):
|
def get_media_object_handles(self, sort_handles=True):
|
||||||
"""
|
"""
|
||||||
Return a list of database handles, one handle for each MediaObject in
|
Return a list of database handles, one handle for each MediaObject in
|
||||||
@ -978,38 +897,6 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def iter_media_object_handles(self):
|
|
||||||
"""
|
|
||||||
Return an iterator over handles for Media in the database
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_event_handles(self):
|
|
||||||
"""
|
|
||||||
Return a list of database handles, one handle for each Event in the
|
|
||||||
database.
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def iter_event_handles(self):
|
|
||||||
"""
|
|
||||||
Return an iterator over handles for Events in the database
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_family_handles(self):
|
|
||||||
"""
|
|
||||||
Return a list of database handles, one handle for each Family in
|
|
||||||
the database.
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def iter_family_handles(self):
|
|
||||||
"""
|
|
||||||
Return an iterator over handles for Families in the database
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_repository_handles(self):
|
def get_repository_handles(self):
|
||||||
"""
|
"""
|
||||||
Return a list of database handles, one handle for each Repository in
|
Return a list of database handles, one handle for each Repository in
|
||||||
@ -1017,12 +904,6 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def iter_repository_handles(self):
|
|
||||||
"""
|
|
||||||
Return an iterator over handles for Repositories in the database
|
|
||||||
"""
|
|
||||||
raise NotImplementedError
|
|
||||||
|
|
||||||
def get_note_handles(self):
|
def get_note_handles(self):
|
||||||
"""
|
"""
|
||||||
Return a list of database handles, one handle for each Note in the
|
Return a list of database handles, one handle for each Note in the
|
||||||
@ -1030,12 +911,102 @@ class GrampsDbBase(object):
|
|||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_person_handles(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over handles for Persons in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_family_handles(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over handles for Families in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_event_handles(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over handles for Events in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_place_handles(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over handles for Places in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_source_handles(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over handles for Sources in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_media_object_handles(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over handles for Media in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_repository_handles(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over handles for Repositories in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def iter_note_handles(self):
|
def iter_note_handles(self):
|
||||||
"""
|
"""
|
||||||
Return an iterator over handles for Notes in the database
|
Return an iterator over handles for Notes in the database
|
||||||
"""
|
"""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_people(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over objects for Persons in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_families(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over objects for Families in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_events(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over objects for Events in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_places(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over objects for Places in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_sources(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over objects for Sources in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_media_objects(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over objects for MediaObjects in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_repositories(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over objects for Repositories in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def iter_notes(self):
|
||||||
|
"""
|
||||||
|
Return an iterator over objects for Notes in the database
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def get_gramps_ids(self, obj_key):
|
def get_gramps_ids(self, obj_key):
|
||||||
"""
|
"""
|
||||||
Returns all the keys from a table given a table name
|
Returns all the keys from a table given a table name
|
||||||
@ -1552,6 +1523,12 @@ class GrampsDbBase(object):
|
|||||||
"""Return the default media path of the database."""
|
"""Return the default media path of the database."""
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
|
def set_column_order(self, col_list, name):
|
||||||
|
"""
|
||||||
|
Store the display information in the database's metadata.
|
||||||
|
"""
|
||||||
|
raise NotImplementedError
|
||||||
|
|
||||||
def set_person_column_order(self, col_list):
|
def set_person_column_order(self, col_list):
|
||||||
"""
|
"""
|
||||||
Store the Person display common information in the database's metadata.
|
Store the Person display common information in the database's metadata.
|
||||||
@ -1700,11 +1677,11 @@ class GrampsDbBase(object):
|
|||||||
|
|
||||||
Returns an iterator over a list of (class_name, handle) tuples.
|
Returns an iterator over a list of (class_name, handle) tuples.
|
||||||
|
|
||||||
@param handle: handle of the object to search for.
|
:param handle: handle of the object to search for.
|
||||||
@type handle: database handle
|
:type handle: database handle
|
||||||
@param include_classes: list of class names to include in the results.
|
:param include_classes: list of class names to include in the results.
|
||||||
Default: None means include all classes.
|
Default is None which includes all classes.
|
||||||
@type include_classes: list of class names
|
:type include_classes: list of class names
|
||||||
|
|
||||||
This default implementation does a sequential scan through all
|
This default implementation does a sequential scan through all
|
||||||
the primary object databases and is very slow. Backends can
|
the primary object databases and is very slow. Backends can
|
||||||
@ -1712,10 +1689,11 @@ class GrampsDbBase(object):
|
|||||||
make use of additional capabilities of the backend.
|
make use of additional capabilities of the backend.
|
||||||
|
|
||||||
Note that this is a generator function, it returns a iterator for
|
Note that this is a generator function, it returns a iterator for
|
||||||
use in loops. If you want a list of the results use:
|
use in loops. If you want a list of the results use::
|
||||||
|
|
||||||
> result_list = list(find_backlink_handles(handle))
|
result_list = list(find_backlink_handles(handle))
|
||||||
"""
|
"""
|
||||||
|
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
||||||
def report_bm_change(self):
|
def report_bm_change(self):
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
# $Id: read.py 12786 2009-07-11 15:32:37Z gburto01 $
|
# $Id: read.py 12786 2009-07-11 15:32:37Z gburto01 $
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Read class for the GRAMPS databases.
|
Read classes for the GRAMPS databases.
|
||||||
"""
|
"""
|
||||||
from __future__ import with_statement
|
from __future__ import with_statement
|
||||||
#-------------------------------------------------------------------------
|
#-------------------------------------------------------------------------
|
||||||
@ -49,9 +49,7 @@ from gen.lib import (MediaObject, Person, Family, Source, Event, Place,
|
|||||||
Repository, Note, GenderStats, Researcher)
|
Repository, Note, GenderStats, Researcher)
|
||||||
from gen.db.dbconst import *
|
from gen.db.dbconst import *
|
||||||
from gen.utils.callback import Callback
|
from gen.utils.callback import Callback
|
||||||
from gen.db.cursor import GrampsCursor
|
from gen.db import (GrampsCursor, GrampsDbBase)
|
||||||
from gen.db.iterator import CursorIterator
|
|
||||||
from gen.db.base import GrampsDbBase
|
|
||||||
from Utils import create_id
|
from Utils import create_id
|
||||||
import Errors
|
import Errors
|
||||||
|
|
||||||
@ -107,7 +105,61 @@ class GrampsDbReadCursor(GrampsCursor):
|
|||||||
|
|
||||||
class GrampsDbRead(GrampsDbBase, Callback):
|
class GrampsDbRead(GrampsDbBase, Callback):
|
||||||
"""
|
"""
|
||||||
GRAMPS database read access object.
|
Read class for the GRAMPS databases. Implements methods necessary to read
|
||||||
|
the various object classes. Currently, there are eight (8) classes:
|
||||||
|
|
||||||
|
Person, Family, Event, Place, Source, MediaObject, Repository and Note
|
||||||
|
|
||||||
|
For each object class, there are methods to retrieve data in various ways.
|
||||||
|
In the methods described below, <object> can be one of person, family,
|
||||||
|
event, place, source, media_object, respository or note unless otherwise
|
||||||
|
specified.
|
||||||
|
|
||||||
|
.. method:: get_<object>_from_handle()
|
||||||
|
|
||||||
|
returns an object given its handle
|
||||||
|
|
||||||
|
.. method:: get_<object>_from_gramps_id()
|
||||||
|
|
||||||
|
returns an object given its gramps id
|
||||||
|
|
||||||
|
.. method:: get_<object>_cursor()
|
||||||
|
|
||||||
|
returns a cursor over an object. Example use::
|
||||||
|
|
||||||
|
with get_person_cursor() as cursor:
|
||||||
|
for handle, person in cursor:
|
||||||
|
# process person object pointed to by the handle
|
||||||
|
|
||||||
|
.. method:: get_<object>_handles()
|
||||||
|
|
||||||
|
returns a list of handles for the object type, optionally sorted
|
||||||
|
(for Person, Place, Source and Media objects)
|
||||||
|
|
||||||
|
.. method:: iter_<object>_handles()
|
||||||
|
|
||||||
|
returns an iterator that yields one object handle per call.
|
||||||
|
|
||||||
|
.. method:: iter_<objects>()
|
||||||
|
|
||||||
|
returns an iterator that yields one object per call.
|
||||||
|
The objects available are: people, families, events, places,
|
||||||
|
sources, media_objects, repositories and notes.
|
||||||
|
|
||||||
|
.. method:: get_<object>_event_types()
|
||||||
|
|
||||||
|
returns a list of all Event types assocated with instances of <object>
|
||||||
|
in the database.
|
||||||
|
|
||||||
|
.. method:: get_<object>_attribute_types()
|
||||||
|
|
||||||
|
returns a list of all Event types assocated with instances of <object>
|
||||||
|
in the database.
|
||||||
|
|
||||||
|
.. method:: get_<object>_column_order()
|
||||||
|
|
||||||
|
returns the object's display common information.
|
||||||
|
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# This holds a reference to the gramps Config module if
|
# This holds a reference to the gramps Config module if
|
||||||
@ -259,30 +311,6 @@ class GrampsDbRead(GrampsDbBase, Callback):
|
|||||||
def get_note_cursor(self):
|
def get_note_cursor(self):
|
||||||
return self.__get_cursor(self.note_map)
|
return self.__get_cursor(self.note_map)
|
||||||
|
|
||||||
def get_person_cursor_iter(self, msg=_("Processing Person records")):
|
|
||||||
return CursorIterator(self, self.get_person_cursor(), msg)
|
|
||||||
|
|
||||||
def get_family_cursor_iter(self, msg=_("Processing Family records")):
|
|
||||||
return CursorIterator(self, self.get_family_cursor(), msg)
|
|
||||||
|
|
||||||
def get_event_cursor_iter(self, msg=_("Processing Event records")):
|
|
||||||
return CursorIterator(self, self.get_event_cursor(), msg)
|
|
||||||
|
|
||||||
def get_place_cursor_iter(self, msg=_("Processing Place records")):
|
|
||||||
return CursorIterator(self, self.get_place_cursor(), msg)
|
|
||||||
|
|
||||||
def get_source_cursor_iter(self, msg=_("Processing Source records")):
|
|
||||||
return CursorIterator(self, self.get_source_cursor(), msg)
|
|
||||||
|
|
||||||
def get_media_cursor_iter(self, msg=_("Processing Media records")):
|
|
||||||
return CursorIterator(self, self.get_media_cursor(), msg)
|
|
||||||
|
|
||||||
def get_repository_cursor_iter(self, msg=_("Processing Repository records")):
|
|
||||||
return CursorIterator(self, self.get_repository_cursor(), msg)
|
|
||||||
|
|
||||||
def get_note_cursor_iter(self, msg=_("Processing Note records")):
|
|
||||||
return CursorIterator(self, self.get_note_cursor(), msg)
|
|
||||||
|
|
||||||
def load(self, name, callback, mode=DBMODE_R):
|
def load(self, name, callback, mode=DBMODE_R):
|
||||||
"""
|
"""
|
||||||
Open the specified database.
|
Open the specified database.
|
||||||
@ -787,6 +815,7 @@ class GrampsDbRead(GrampsDbBase, Callback):
|
|||||||
iter_media_object_handles = _f(get_media_cursor)
|
iter_media_object_handles = _f(get_media_cursor)
|
||||||
iter_repository_handles = _f(get_repository_cursor)
|
iter_repository_handles = _f(get_repository_cursor)
|
||||||
iter_note_handles = _f(get_note_cursor)
|
iter_note_handles = _f(get_note_cursor)
|
||||||
|
del _f
|
||||||
|
|
||||||
def _f(curs_, obj_):
|
def _f(curs_, obj_):
|
||||||
"""
|
"""
|
||||||
@ -810,6 +839,7 @@ class GrampsDbRead(GrampsDbBase, Callback):
|
|||||||
iter_media_objects = _f(get_media_cursor, MediaObject)
|
iter_media_objects = _f(get_media_cursor, MediaObject)
|
||||||
iter_repositories = _f(get_repository_cursor, Repository)
|
iter_repositories = _f(get_repository_cursor, Repository)
|
||||||
iter_notes = _f(get_note_cursor, Note)
|
iter_notes = _f(get_note_cursor, Note)
|
||||||
|
del _f
|
||||||
|
|
||||||
def get_gramps_ids(self, obj_key):
|
def get_gramps_ids(self, obj_key):
|
||||||
key2table = {
|
key2table = {
|
||||||
@ -1483,11 +1513,11 @@ class GrampsDbRead(GrampsDbBase, Callback):
|
|||||||
|
|
||||||
Returns an interator over alist of (class_name, handle) tuples.
|
Returns an interator over alist of (class_name, handle) tuples.
|
||||||
|
|
||||||
@param handle: handle of the object to search for.
|
:param handle: handle of the object to search for.
|
||||||
@type handle: database handle
|
:type handle: database handle
|
||||||
@param include_classes: list of class names to include in the results.
|
:param include_classes: list of class names to include in the results.
|
||||||
Default: None means include all classes.
|
Defaults to None, which includes all classes.
|
||||||
@type include_classes: list of class names
|
:type include_classes: list of class names
|
||||||
|
|
||||||
This default implementation does a sequencial scan through all
|
This default implementation does a sequencial scan through all
|
||||||
the primary object databases and is very slow. Backends can
|
the primary object databases and is very slow. Backends can
|
||||||
@ -1495,9 +1525,9 @@ class GrampsDbRead(GrampsDbBase, Callback):
|
|||||||
make use of additional capabilities of the backend.
|
make use of additional capabilities of the backend.
|
||||||
|
|
||||||
Note that this is a generator function, it returns a iterator for
|
Note that this is a generator function, it returns a iterator for
|
||||||
use in loops. If you want a list of the results use:
|
use in loops. If you want a list of the results use::
|
||||||
|
|
||||||
> result_list = list(ind_backlink_handles(handle))
|
result_list = list(find_backlink_handles(handle))
|
||||||
"""
|
"""
|
||||||
assert False, "read:find_backlink_handles -- shouldn't get here!!!"
|
assert False, "read:find_backlink_handles -- shouldn't get here!!!"
|
||||||
# Make a dictionary of the functions and classes that we need for
|
# Make a dictionary of the functions and classes that we need for
|
||||||
|
@ -249,6 +249,9 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
# the main index is unique, the others allow duplicate entries.
|
# the main index is unique, the others allow duplicate entries.
|
||||||
|
|
||||||
def get_reference_map_cursor(self):
|
def get_reference_map_cursor(self):
|
||||||
|
"""
|
||||||
|
Returns a reference to a cursor over the reference map
|
||||||
|
"""
|
||||||
try:
|
try:
|
||||||
return GrampsDBDirAssocCursor(self.reference_map, self.txn)
|
return GrampsDBDirAssocCursor(self.reference_map, self.txn)
|
||||||
except DBERRS, msg:
|
except DBERRS, msg:
|
||||||
@ -256,6 +259,9 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
raise Errors.DbError(msg)
|
raise Errors.DbError(msg)
|
||||||
|
|
||||||
def get_reference_map_primary_cursor(self):
|
def get_reference_map_primary_cursor(self):
|
||||||
|
"""
|
||||||
|
Returns a reference to a cursor over the reference map primary map
|
||||||
|
"""
|
||||||
try:
|
try:
|
||||||
return GrampsDBDirAssocCursor(self.reference_map_primary_map,
|
return GrampsDBDirAssocCursor(self.reference_map_primary_map,
|
||||||
self.txn)
|
self.txn)
|
||||||
@ -264,6 +270,9 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
raise Errors.DbError(msg)
|
raise Errors.DbError(msg)
|
||||||
|
|
||||||
def get_reference_map_referenced_cursor(self):
|
def get_reference_map_referenced_cursor(self):
|
||||||
|
"""
|
||||||
|
Returns a reference to a cursor over the reference map referenced map
|
||||||
|
"""
|
||||||
try:
|
try:
|
||||||
return GrampsDBDirAssocCursor(self.reference_map_referenced_map,
|
return GrampsDBDirAssocCursor(self.reference_map_referenced_map,
|
||||||
self.txn)
|
self.txn)
|
||||||
@ -696,16 +705,16 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
|
|
||||||
Returns an interator over a list of (class_name, handle) tuples.
|
Returns an interator over a list of (class_name, handle) tuples.
|
||||||
|
|
||||||
@param handle: handle of the object to search for.
|
:param handle: handle of the object to search for.
|
||||||
@type handle: database handle
|
:type handle: database handle
|
||||||
@param include_classes: list of class names to include in the results.
|
:param include_classes: list of class names to include in the results.
|
||||||
Default: None means include all classes.
|
Default: None means include all classes.
|
||||||
@type include_classes: list of class names
|
:type include_classes: list of class names
|
||||||
|
|
||||||
Note that this is a generator function, it returns a iterator for
|
Note that this is a generator function, it returns a iterator for
|
||||||
use in loops. If you want a list of the results use:
|
use in loops. If you want a list of the results use::
|
||||||
|
|
||||||
> result_list = list(find_backlink_handles(handle))
|
result_list = list(find_backlink_handles(handle))
|
||||||
"""
|
"""
|
||||||
|
|
||||||
# Use the secondary index to locate all the reference_map entries
|
# Use the secondary index to locate all the reference_map entries
|
||||||
@ -1210,7 +1219,7 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
self.find_next_note_gramps_id if set_gid else None,
|
self.find_next_note_gramps_id if set_gid else None,
|
||||||
self.commit_note)
|
self.commit_note)
|
||||||
|
|
||||||
def do_remove_object(self, handle, transaction, data_map, key):
|
def __do_remove(self, handle, transaction, data_map, key):
|
||||||
if self.readonly or not handle:
|
if self.readonly or not handle:
|
||||||
return
|
return
|
||||||
|
|
||||||
@ -1250,7 +1259,7 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
Remove the Source specified by the database handle from the
|
Remove the Source specified by the database handle from the
|
||||||
database, preserving the change in the passed transaction.
|
database, preserving the change in the passed transaction.
|
||||||
"""
|
"""
|
||||||
self.do_remove_object(handle, transaction, self.source_map,
|
self.__do_remove(handle, transaction, self.source_map,
|
||||||
SOURCE_KEY)
|
SOURCE_KEY)
|
||||||
|
|
||||||
def remove_event(self, handle, transaction):
|
def remove_event(self, handle, transaction):
|
||||||
@ -1258,7 +1267,7 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
Remove the Event specified by the database handle from the
|
Remove the Event specified by the database handle from the
|
||||||
database, preserving the change in the passed transaction.
|
database, preserving the change in the passed transaction.
|
||||||
"""
|
"""
|
||||||
self.do_remove_object(handle, transaction, self.event_map,
|
self.__do_remove(handle, transaction, self.event_map,
|
||||||
EVENT_KEY)
|
EVENT_KEY)
|
||||||
|
|
||||||
def remove_object(self, handle, transaction):
|
def remove_object(self, handle, transaction):
|
||||||
@ -1266,7 +1275,7 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
Remove the MediaObjectPerson specified by the database handle from the
|
Remove the MediaObjectPerson specified by the database handle from the
|
||||||
database, preserving the change in the passed transaction.
|
database, preserving the change in the passed transaction.
|
||||||
"""
|
"""
|
||||||
self.do_remove_object(handle, transaction, self.media_map,
|
self.__do_remove(handle, transaction, self.media_map,
|
||||||
MEDIA_KEY)
|
MEDIA_KEY)
|
||||||
|
|
||||||
def remove_place(self, handle, transaction):
|
def remove_place(self, handle, transaction):
|
||||||
@ -1274,7 +1283,7 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
Remove the Place specified by the database handle from the
|
Remove the Place specified by the database handle from the
|
||||||
database, preserving the change in the passed transaction.
|
database, preserving the change in the passed transaction.
|
||||||
"""
|
"""
|
||||||
self.do_remove_object(handle, transaction, self.place_map,
|
self.__do_remove(handle, transaction, self.place_map,
|
||||||
PLACE_KEY)
|
PLACE_KEY)
|
||||||
|
|
||||||
def remove_family(self, handle, transaction):
|
def remove_family(self, handle, transaction):
|
||||||
@ -1282,7 +1291,7 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
Remove the Family specified by the database handle from the
|
Remove the Family specified by the database handle from the
|
||||||
database, preserving the change in the passed transaction.
|
database, preserving the change in the passed transaction.
|
||||||
"""
|
"""
|
||||||
self.do_remove_object(handle, transaction, self.family_map,
|
self.__do_remove(handle, transaction, self.family_map,
|
||||||
FAMILY_KEY)
|
FAMILY_KEY)
|
||||||
|
|
||||||
def remove_repository(self, handle, transaction):
|
def remove_repository(self, handle, transaction):
|
||||||
@ -1290,7 +1299,7 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
Remove the Repository specified by the database handle from the
|
Remove the Repository specified by the database handle from the
|
||||||
database, preserving the change in the passed transaction.
|
database, preserving the change in the passed transaction.
|
||||||
"""
|
"""
|
||||||
self.do_remove_object(handle, transaction, self.repository_map,
|
self.__do_remove(handle, transaction, self.repository_map,
|
||||||
REPOSITORY_KEY)
|
REPOSITORY_KEY)
|
||||||
|
|
||||||
def remove_note(self, handle, transaction):
|
def remove_note(self, handle, transaction):
|
||||||
@ -1298,7 +1307,7 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
Remove the Note specified by the database handle from the
|
Remove the Note specified by the database handle from the
|
||||||
database, preserving the change in the passed transaction.
|
database, preserving the change in the passed transaction.
|
||||||
"""
|
"""
|
||||||
self.do_remove_object(handle, transaction, self.note_map,
|
self.__do_remove(handle, transaction, self.note_map,
|
||||||
NOTE_KEY)
|
NOTE_KEY)
|
||||||
|
|
||||||
def __set_name_group_mapping(self, name, group):
|
def __set_name_group_mapping(self, name, group):
|
||||||
@ -1580,30 +1589,6 @@ class GrampsDBDir(GrampsDbRead, Callback, UpdateCallback):
|
|||||||
return newobj
|
return newobj
|
||||||
return None
|
return None
|
||||||
|
|
||||||
def find_from_handle(self, handle, transaction, class_type, dmap, add_func):
|
|
||||||
"""
|
|
||||||
Find a object of class_type in the database from the passed handle.
|
|
||||||
|
|
||||||
If no object exists, a new object is added to the database.
|
|
||||||
|
|
||||||
@return: Returns a tuple, first the object, second a bool which is True
|
|
||||||
if the object is new
|
|
||||||
@rtype: tuple
|
|
||||||
"""
|
|
||||||
obj = class_type()
|
|
||||||
handle = str(handle)
|
|
||||||
new = True
|
|
||||||
if handle in dmap:
|
|
||||||
data = dmap.get(handle, txn=self.txn)
|
|
||||||
obj.unserialize(data)
|
|
||||||
#references create object with id None before object is really made
|
|
||||||
if obj.gramps_id is not None:
|
|
||||||
new = False
|
|
||||||
else:
|
|
||||||
obj.set_handle(handle)
|
|
||||||
add_func(obj, transaction)
|
|
||||||
return obj, new
|
|
||||||
|
|
||||||
def transaction_begin(self, msg="", batch=False, no_magic=False):
|
def transaction_begin(self, msg="", batch=False, no_magic=False):
|
||||||
try:
|
try:
|
||||||
return self.__transaction_begin(msg, batch, no_magic)
|
return self.__transaction_begin(msg, batch, no_magic)
|
||||||
|
Loading…
Reference in New Issue
Block a user