--- parser3/src/include/pa_sql_connection.h 2003/12/10 14:17:45 1.34 +++ parser3/src/include/pa_sql_connection.h 2004/02/11 15:33:14 1.38 @@ -1,14 +1,14 @@ /** @file Parser: sql fconnection decl. - Copyright (c) 2001-2003 ArtLebedev Group (http://www.artlebedev.com) + Copyright (c) 2001-2004 ArtLebedev Group (http://www.artlebedev.com) Author: Alexandr Petrosian (http://paf.design.ru) */ #ifndef PA_SQL_CONNECTION_H #define PA_SQL_CONNECTION_H -static const char * const IDENT_SQL_CONNECTION_H="$Date: 2003/12/10 14:17:45 $"; +static const char * const IDENT_SQL_CONNECTION_H="$Date: 2004/02/11 15:33:14 $"; #include "pa_sql_driver.h" @@ -18,9 +18,12 @@ static const char * const IDENT_SQL_CONN /// @see SQL_Driver_services_impl::_throw #ifdef PA_WITH_SJLJ_EXCEPTIONS - #define SQL_CONNECTION_SERVICED_FUNC_GUARDED(actions) actions + #define SQL_CONNECTION_SERVICED_FUNC_GUARDED(actions) \ + use(); \ + actions #else #define SQL_CONNECTION_SERVICED_FUNC_GUARDED(actions) \ + use(); \ if(!setjmp(fservices.mark)) { \ actions; \ } else \ @@ -31,14 +34,22 @@ static const char * const IDENT_SQL_CONN class SQL_Driver_services_impl: public SQL_Driver_services { const String* furl; Exception fexception; + const char* frequest_charset; public: - SQL_Driver_services_impl(): furl(0) {} + SQL_Driver_services_impl(const char* arequest_charset): furl(0), frequest_charset(arequest_charset) {} void set_url(const String& aurl) { furl=&aurl;} const String& url_without_login() const; - override void *malloc(size_t size) { return pa_malloc(size); } - override void *malloc_atomic(size_t size) { return pa_malloc_atomic(size); } - override void *realloc(void *ptr, size_t size) { return pa_realloc(ptr, size); } + override void* malloc(size_t size) { return pa_malloc(size); } + override void* malloc_atomic(size_t size) { return pa_malloc_atomic(size); } + override void* realloc(void *ptr, size_t size) { return pa_realloc(ptr, size); } + + override const char* request_charset() { return frequest_charset; } + override void transcode(const char* src, size_t src_length, + const char*& dst, size_t& dst_length, + const char* charset_from_name, + const char* charset_to_name + ); /** normally we can't 'throw' from dynamic library, so @@ -80,16 +91,15 @@ class SQL_Connection: public PA_Object { SQL_Driver_services_impl fservices; void *fconnection; time_t time_used; - bool marked_to_rollback; public: - SQL_Connection(const String& aurl, SQL_Driver& adriver): + SQL_Connection(const String& aurl, SQL_Driver& adriver, const char* arequest_charset): furl(aurl), fdriver(adriver), + fservices(arequest_charset), fconnection(0), - time_used(0), - marked_to_rollback(false) { + time_used(0) { } SQL_Driver_services_impl& services() { return fservices; } @@ -103,7 +113,7 @@ public: time_used=time(0); // they started to use at this time } bool expired(time_t older_dies) { - return /*!freferences && */time_usedclose_connection(furl, this); } };