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: