| Guido van Rossum | 4ac0050 | 1995-08-10 19:24:30 +0000 | [diff] [blame] | 1 | """Generic interface to all dbm clones. | 
| Guido van Rossum | cc6764c | 1995-02-09 17:18:10 +0000 | [diff] [blame] | 2 |  | 
 | 3 | Instead of | 
 | 4 |  | 
| Tim Peters | 146965a | 2001-01-14 18:09:23 +0000 | [diff] [blame] | 5 |         import dbm | 
 | 6 |         d = dbm.open(file, 'w', 0666) | 
| Guido van Rossum | cc6764c | 1995-02-09 17:18:10 +0000 | [diff] [blame] | 7 |  | 
 | 8 | use | 
 | 9 |  | 
| Tim Peters | 146965a | 2001-01-14 18:09:23 +0000 | [diff] [blame] | 10 |         import anydbm | 
 | 11 |         d = anydbm.open(file, 'w') | 
| Guido van Rossum | cc6764c | 1995-02-09 17:18:10 +0000 | [diff] [blame] | 12 |  | 
| Guido van Rossum | 4ac0050 | 1995-08-10 19:24:30 +0000 | [diff] [blame] | 13 | The returned object is a dbhash, gdbm, dbm or dumbdbm object, | 
| Guido van Rossum | a5c0998 | 1998-04-28 15:19:34 +0000 | [diff] [blame] | 14 | dependent on the type of database being opened (determined by whichdb | 
 | 15 | module) in the case of an existing dbm. If the dbm does not exist and | 
 | 16 | the create or new flag ('c' or 'n') was specified, the dbm type will | 
 | 17 | be determined by the availability of the modules (tested in the above | 
 | 18 | order). | 
| Guido van Rossum | cc6764c | 1995-02-09 17:18:10 +0000 | [diff] [blame] | 19 |  | 
 | 20 | It has the following interface (key and data are strings): | 
 | 21 |  | 
| Tim Peters | 146965a | 2001-01-14 18:09:23 +0000 | [diff] [blame] | 22 |         d[key] = data   # store data at key (may override data at | 
 | 23 |                         # existing key) | 
 | 24 |         data = d[key]   # retrieve data at key (raise KeyError if no | 
 | 25 |                         # such key) | 
 | 26 |         del d[key]      # delete data stored at key (raises KeyError | 
 | 27 |                         # if no such key) | 
| Raymond Hettinger | 54f0222 | 2002-06-01 14:18:47 +0000 | [diff] [blame] | 28 |         flag = key in d   # true if the key exists | 
| Tim Peters | 146965a | 2001-01-14 18:09:23 +0000 | [diff] [blame] | 29 |         list = d.keys() # return a list of all existing keys (slow!) | 
| Guido van Rossum | cc6764c | 1995-02-09 17:18:10 +0000 | [diff] [blame] | 30 |  | 
 | 31 | Future versions may change the order in which implementations are | 
| Éric Araujo | d6dcf82 | 2011-05-01 02:02:30 +0200 | [diff] [blame] | 32 | tested for existence, and add interfaces to other dbm-like | 
| Guido van Rossum | a5c0998 | 1998-04-28 15:19:34 +0000 | [diff] [blame] | 33 | implementations. | 
| Guido van Rossum | cc6764c | 1995-02-09 17:18:10 +0000 | [diff] [blame] | 34 | """ | 
| Guido van Rossum | a48061a | 1995-01-10 00:31:14 +0000 | [diff] [blame] | 35 |  | 
| Skip Montanaro | c99475e | 2002-03-18 03:07:20 +0000 | [diff] [blame] | 36 | class error(Exception): | 
 | 37 |     pass | 
| Guido van Rossum | a5c0998 | 1998-04-28 15:19:34 +0000 | [diff] [blame] | 38 |  | 
| Guido van Rossum | 4ac0050 | 1995-08-10 19:24:30 +0000 | [diff] [blame] | 39 | _names = ['dbhash', 'gdbm', 'dbm', 'dumbdbm'] | 
| Guido van Rossum | a5c0998 | 1998-04-28 15:19:34 +0000 | [diff] [blame] | 40 | _errors = [error] | 
 | 41 | _defaultmod = None | 
| Guido van Rossum | 4ac0050 | 1995-08-10 19:24:30 +0000 | [diff] [blame] | 42 |  | 
 | 43 | for _name in _names: | 
| Tim Peters | 146965a | 2001-01-14 18:09:23 +0000 | [diff] [blame] | 44 |     try: | 
 | 45 |         _mod = __import__(_name) | 
 | 46 |     except ImportError: | 
 | 47 |         continue | 
 | 48 |     if not _defaultmod: | 
 | 49 |         _defaultmod = _mod | 
 | 50 |     _errors.append(_mod.error) | 
| Guido van Rossum | a5c0998 | 1998-04-28 15:19:34 +0000 | [diff] [blame] | 51 |  | 
 | 52 | if not _defaultmod: | 
| Tim Peters | 146965a | 2001-01-14 18:09:23 +0000 | [diff] [blame] | 53 |     raise ImportError, "no dbm clone found; tried %s" % _names | 
| Guido van Rossum | 0182c06 | 1996-01-25 18:26:57 +0000 | [diff] [blame] | 54 |  | 
| Guido van Rossum | a5c0998 | 1998-04-28 15:19:34 +0000 | [diff] [blame] | 55 | error = tuple(_errors) | 
| Guido van Rossum | 0182c06 | 1996-01-25 18:26:57 +0000 | [diff] [blame] | 56 |  | 
| Éric Araujo | d6dcf82 | 2011-05-01 02:02:30 +0200 | [diff] [blame] | 57 | def open(file, flag='r', mode=0666): | 
 | 58 |     """Open or create database at path given by *file*. | 
 | 59 |  | 
 | 60 |     Optional argument *flag* can be 'r' (default) for read-only access, 'w' | 
 | 61 |     for read-write access of an existing database, 'c' for read-write access | 
 | 62 |     to a new or existing database, and 'n' for read-write access to a new | 
 | 63 |     database. | 
 | 64 |  | 
 | 65 |     Note: 'r' and 'w' fail if the database doesn't exist; 'c' creates it | 
 | 66 |     only if it doesn't exist; and 'n' always creates a new database. | 
 | 67 |     """ | 
 | 68 |  | 
| Tim Peters | 146965a | 2001-01-14 18:09:23 +0000 | [diff] [blame] | 69 |     # guess the type of an existing database | 
 | 70 |     from whichdb import whichdb | 
 | 71 |     result=whichdb(file) | 
 | 72 |     if result is None: | 
 | 73 |         # db doesn't exist | 
 | 74 |         if 'c' in flag or 'n' in flag: | 
 | 75 |             # file doesn't exist and the new | 
 | 76 |             # flag was used so use default type | 
 | 77 |             mod = _defaultmod | 
 | 78 |         else: | 
 | 79 |             raise error, "need 'c' or 'n' flag to open new db" | 
 | 80 |     elif result == "": | 
 | 81 |         # db type cannot be determined | 
 | 82 |         raise error, "db type could not be determined" | 
 | 83 |     else: | 
 | 84 |         mod = __import__(result) | 
 | 85 |     return mod.open(file, flag, mode) |