2007-02-03 20:08:41 +00:00
|
|
|
#
|
|
|
|
# Gramps - a GTK+/GNOME based genealogy program
|
|
|
|
#
|
2007-02-20 00:39:10 +00:00
|
|
|
# Copyright (C) 2004-2007 Donald N. Allingham
|
2007-02-03 20:08:41 +00:00
|
|
|
#
|
|
|
|
# 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
|
|
|
|
#
|
|
|
|
|
2008-01-22 10:17:42 +00:00
|
|
|
# $Id$
|
2007-02-03 20:08:41 +00:00
|
|
|
|
2009-08-31 18:42:29 +00:00
|
|
|
"""
|
|
|
|
Declare constants used by database modules
|
|
|
|
"""
|
|
|
|
|
2007-02-20 00:39:10 +00:00
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# standard python modules
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
2007-02-03 17:11:05 +00:00
|
|
|
|
|
|
|
#-------------------------------------------------------------------------
|
|
|
|
#
|
|
|
|
# constants
|
|
|
|
#
|
|
|
|
#-------------------------------------------------------------------------
|
2009-08-31 18:42:29 +00:00
|
|
|
__all__ = (
|
|
|
|
('DBPAGE', 'DBMODE', 'DBCACHE', 'DBLOCKS', 'DBOBJECTS', 'DBUNDO',
|
|
|
|
'DBEXT', 'DBMODE_R', 'DBMODE_W', 'DBUNDOFN', 'DBLOCKFN',
|
|
|
|
'DBRECOVFN', 'DBLOGNAME', 'DBFLAGS_O', 'DBFLAGS_R', 'DBFLAGS_D',
|
|
|
|
) +
|
|
|
|
|
|
|
|
('PERSON_KEY', 'FAMILY_KEY', 'SOURCE_KEY', 'EVENT_KEY',
|
|
|
|
'MEDIA_KEY', 'PLACE_KEY', 'REPOSITORY_KEY', 'NOTE_KEY',
|
2010-02-01 07:01:45 +00:00
|
|
|
'REFERENCE_KEY'
|
2009-08-31 18:42:29 +00:00
|
|
|
) +
|
|
|
|
|
|
|
|
('TXNADD', 'TXNUPD', 'TXNDEL')
|
|
|
|
)
|
|
|
|
|
|
|
|
DBEXT = ".db" # File extension to be used for database files
|
|
|
|
DBUNDOFN = "undo.db" # File name of 'undo' database
|
|
|
|
DBLOCKFN = "lock" # File name of lock file
|
|
|
|
DBRECOVFN = "need_recover" # File name of recovery file
|
2009-12-23 15:55:58 +00:00
|
|
|
DBLOGNAME = ".Db" # Name of logger
|
2009-08-31 18:42:29 +00:00
|
|
|
DBMODE_R = "r" # Read-only access
|
|
|
|
DBMODE_W = "w" # Full Reaw/Write access
|
|
|
|
DBPAGE = 16384 # Size of the pages used to hold items in the database
|
|
|
|
DBMODE = 0666 # Unix mode for database creation
|
|
|
|
DBCACHE = 0x4000000 # Size of the shared memory buffer pool
|
|
|
|
DBLOCKS = 25000 # Maximum number of locks supported
|
|
|
|
DBOBJECTS = 25000 # Maximum number of simultaneously locked objects
|
|
|
|
DBUNDO = 1000 # Maximum size of undo buffer
|
|
|
|
|
|
|
|
from bsddb.db import DB_CREATE, DB_AUTO_COMMIT, DB_DUP, DB_DUPSORT, DB_RDONLY
|
|
|
|
DBFLAGS_O = DB_CREATE | DB_AUTO_COMMIT # Default flags for database open
|
|
|
|
DBFLAGS_R = DB_RDONLY # Flags to open a database read-only
|
|
|
|
DBFLAGS_D = DB_DUP | DB_DUPSORT # Default flags for duplicate keys
|
2007-02-03 17:11:05 +00:00
|
|
|
|
|
|
|
PERSON_KEY = 0
|
|
|
|
FAMILY_KEY = 1
|
|
|
|
SOURCE_KEY = 2
|
|
|
|
EVENT_KEY = 3
|
|
|
|
MEDIA_KEY = 4
|
|
|
|
PLACE_KEY = 5
|
|
|
|
REPOSITORY_KEY = 6
|
|
|
|
REFERENCE_KEY = 7
|
2007-02-20 00:39:10 +00:00
|
|
|
NOTE_KEY = 8
|
2007-02-03 17:11:05 +00:00
|
|
|
|
2009-08-31 18:42:29 +00:00
|
|
|
TXNADD, TXNUPD, TXNDEL = 0, 1, 2
|