#include <db_cxx.h>
extern "C" {
    typedef int (*bt_compress_fcn_type)(DB *db, const DBT *prevKey, 
        const DBT *prevData, const DBT *key, const DBT *data, DBT *dest);
    typedef int (*bt_decompress_fcn_typ)(DB *db, const DBT *prevKey, 
        const DBT *prevData, DBT *compressed, DBT *destKey, 
        DBT *destData);
};
int
Db::set_bt_compress(bt_compress_fcn_type bt_compress_fcn, 
    bt_decompress_fcn_type bt_decompress_fcn);
      Set the Btree compression and decompression functions. The compression function is called whenever a key/data pair is added to the tree and the decompression function is called whenever data is requested from the tree.
If NULL function pointers are specified, then default compression and decompression functions are used. Berkeley DB's default compression function performs prefix compression on all keys and prefix compression on data values for duplicate keys. If using default compression, both the default compression and decompression functions must be used.
        The Db::set_bt_compress() method
        configures operations performed using the specified Db  handle, not all operations
        performed on the underlying database.
   
        The Db::set_bt_compress() method may not be called after the 
        Db::open()  method is called. If
        the database already exists when Db::open()  
        is called, the information specified to Db::set_bt_compress() must be the same as
        that historically used to create the database or corruption can occur.
   
        The Db::set_bt_compress() 
            
            
                method either returns a non-zero error value or throws an
                exception that encapsulates a non-zero error value on
                failure, and returns 0 on success.
            
        
   
The bt_compress_fcn function is the application-specified Btree compression function. The compression function takes six parameters:
                               db
                           
The db parameter is the enclosing database handle.
                               prevKey
                            
The prevKey parameter is the Dbt representing the key immediately preceding the application supplied key.
                               prevData
                            
The prevData parameter is the Dbt representing the data associated with prevKey.
                               key
                           
The key parameter is the Dbt representing the application supplied key.
                               data
                           
The data parameter is the Dbt representing the application supplied data.
                               dest
                           
The dest parameter is the Dbt representing the data stored in the tree, where the function should write the compressed data.
                   The bt_compress_fcn
                   function must return 0 on success and a non-zero value
                   on failure.  If the compressed data cannot fit in
                    
                   dest->set_data() 
                   (the size of which is
                   
                   
                        returned by
                        dest->get_ulen()),
                    
                   the function should identify the required buffer size in 
                    
                   dest->set_size() 
                   and return DB_BUFFER_SMALL.
           
The bt_decompress_fcn function is the application-specified Btree decompression function. The decompression function takes six parameters:
                               db
                           
The db parameter is the enclosing database handle.
                               prevKey
                            
The prevKey parameter is the Dbt representing the key immediately preceding the key being decompressed.
                               prevData
                            
The prevData parameter is the Dbt representing the data associated with prevKey.
                               compressed
                           
The compressed parameter is the Dbt representing the data stored in the tree, that is, the compressed data.
                               key
                           
The key parameter is the Dbt where the decompression function should store the decompressed key.
                               data
                           
The data parameter is the Dbt where the decompression function should store the decompressed key.
                   The bt_decompress_fcn
                   function must return 0 on success and a non-zero value
                   on failure.
                   If the decompressed data cannot fit in
                    
                   key->set_data() 
                   or
                    
                   data->set_data() 
                   (the size of which is
                   
                   
                       returned by the Dbt's
                        get_ulen() method),
                    
                   the function should identify the required buffer size 
                   
                   
                       using the Dbt's
                        set_size() 
                        method
                    
                   and return DB_BUFFER_SMALL.
           
                        The Db::set_bt_compress() 
            
            
                method may fail and throw a DbException 
                exception, encapsulating one of the following non-zero errors, or return one
                of the following non-zero errors:
            
        
                   
If the method was called after Db::open() was called; or if an invalid flag value or parameter was specified.