Annotation of parser3/src/sql/pa_sql_driver.h, revision 1.11

1.1       paf         1: /** @file
                      2:        Parser: sql driver interface.
                      3: 
                      4:        Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com)
                      5: 
                      6:        Author: Alexander Petrosyan <paf@design.ru> (http://design.ru/paf)
                      7: 
1.11    ! parser      8:        $Id: pa_sql_driver.h,v 1.10 2001/05/17 13:23:28 parser Exp $
1.1       paf         9: 
                     10: 
                     11:        driver dynamic library must look like this:
                     12:        @code
                     13:                class X_SQL_Driver : public SQL_Driver {
                     14:                public:
                     15: 
                     16:                        X_SQL_Driver() : SQL_driver() {}
                     17: 
                     18:                        int api_version() { return SQL_DRIVER_API_VERSION; }
                     19:                        
                     20:                        //...
                     21:                };
                     22: 
                     23:                extern "C" SQL_Driver *create() {
                     24:                        return new X_SQL_Driver();
                     25:                }       
                     26:        @endcode
                     27: */
                     28: 
                     29: #ifndef PA_SQL_DRIVER_H
                     30: #define PA_SQL_DRIVER_H
                     31: 
1.2       paf        32: #include <sys/types.h>
1.1       paf        33: 
                     34: /// service functions for SQL driver to use
1.7       paf        35: class SQL_Driver_services {
1.1       paf        36: public:
                     37:        /// allocates some bytes on pool
                     38:        virtual void *malloc(size_t size) =0;
                     39:        /// allocates some bytes clearing them with zeros
                     40:        virtual void *calloc(size_t size) =0;
                     41:        /// throw exception
                     42:        virtual void _throw(const char *comment) =0;
                     43: };
                     44: 
1.11    ! parser     45: #define SQL_DRIVER_API_VERSION 0x0302
        !            46: 
        !            47: /// events, occuring when SQL_Driver::query()-ing
        !            48: class SQL_Driver_query_event_handlers {
        !            49: public:
        !            50:        virtual void add_column(void *ptr, size_t size) =0;
        !            51:        virtual void before_rows() =0;
        !            52:        virtual void add_row() =0;
        !            53:        virtual void add_row_cell(void *ptr, size_t size) =0;
        !            54: };
1.1       paf        55: 
                     56: /// SQL driver API
                     57: class SQL_Driver {
                     58: public:
                     59: 
1.10      parser     60:        SQL_Driver() {}
1.1       paf        61:        /// get api version
                     62:        virtual int api_version() =0;
1.6       paf        63:        /// initialize driver by loading sql dynamic link library
                     64:        virtual const char *initialize(const char *dlopen_file_spec) =0;
1.9       parser     65:        /**     connect to sql database using 
                     66:                @param used_only_to_connect_url 
                     67:                        format is driver specific
                     68:                        WARNING: must be used only to connect, for buffer doesn't live long enough
                     69: 
                     70:                @returns true+'connection' on success. 'error' on failure
                     71:        */
1.10      parser     72:        virtual void connect(char *used_only_in_connect_url_cstr, 
                     73:                SQL_Driver_services& services, void **connection) =0;
                     74:        virtual void disconnect(
                     75:                SQL_Driver_services& services, void *connection) =0;
                     76:        virtual void commit(
                     77:                SQL_Driver_services& services, void *connection) =0;
                     78:        virtual void rollback(
                     79:                SQL_Driver_services& services, void *connection) =0;
1.3       paf        80:        /// @returns true to indicate that connection still alive 
1.10      parser     81:        virtual bool ping(
                     82:                SQL_Driver_services& services, void *connection) =0;
1.4       paf        83:        /// encodes the string in 'from' to an escaped SQL string
1.10      parser     84:        virtual unsigned int quote(
                     85:                SQL_Driver_services& services, void *connection,
1.4       paf        86:                char *to, const char *from, unsigned int length) =0;
1.10      parser     87:        virtual void query(
                     88:                SQL_Driver_services& services, void *connection,
1.3       paf        89:                const char *statement, unsigned long offset, unsigned long limit,
1.11    ! parser     90:                SQL_Driver_query_event_handlers& handlers) =0;
1.1       paf        91: };
                     92: 
                     93: typedef SQL_Driver *(*SQL_Driver_create_func)();
                     94: 
                     95: #endif

E-mail: