--- parser3/src/include/pa_pool.h 2001/11/05 11:46:24 1.69 +++ parser3/src/include/pa_pool.h 2002/02/08 08:30:13 1.78 @@ -1,11 +1,11 @@ /** @file Parser: pool class decl. - Copyright (c) 2001 ArtLebedev Group (http://www.artlebedev.com) + Copyright (c) 2001, 2002 ArtLebedev Group (http://www.artlebedev.com) - Author: Alexander Petrosyan (http://paf.design.ru) + Author: Alexandr Petrosian (http://paf.design.ru) - $Id: pa_pool.h,v 1.69 2001/11/05 11:46:24 paf Exp $ + $Id: pa_pool.h,v 1.78 2002/02/08 08:30:13 paf Exp $ */ #ifndef PA_POOL_H @@ -14,15 +14,17 @@ #include "pa_config_includes.h" #ifdef XML -#include -#include -#include +# include "gdome.h" +// for xmlChar +# include "libxml/tree.h" #endif // forwards class Exception; class String; +class Charset; +class GdomeDOMString_auto_ptr; /** Pool mechanizm allows users not to free up allocated memory, @@ -35,14 +37,15 @@ class Pool { public: Pool(void *astorage); - ~Pool(); + + ///{@ statistics + size_t total_allocated() { return ftotal_allocated; } + unsigned int total_times() { return ftotal_times; } + ///}@ void set_context(void *acontext) { fcontext=acontext; } void *get_context() { return fcontext; } - void set_tag(void *atag) { ftag=atag; } - void *tag() { return ftag; } - /// allocates some bytes on pool void *malloc(size_t size, int place=0) { return check(real_malloc(size, place), size); @@ -58,17 +61,37 @@ public: fail_register_cleanup(); } - /// resets transcoder if they change charset - void set_charset(const String &charset); - /// returns current charset - const String& get_charset() { return *charset; } + ///{@ source charset + void set_source_charset(Charset& acharset); + Charset& get_source_charset(); + ///}@ + + ///{@ client charset + void set_client_charset(Charset& charset); + Charset& get_client_charset(); + ///}@ + +#ifdef XML + + /// @see Charset::transcode_cstr(xmlChar *s); + const char *transcode_cstr(xmlChar *s); + /// @see Charset::transcode(xmlChar *s); + String& transcode(xmlChar *s); + /// @see Charset::transcode_cstr(GdomeDOMString *s); + const char *transcode_cstr(GdomeDOMString *s); + /// @see Charset::transcode(GdomeDOMString *s); + String& transcode(GdomeDOMString *s); + /// @see Charset::transcode(const String& s) + GdomeDOMString_auto_ptr transcode(const String& s); + +#endif private: void *fstorage; void *fcontext; - void *ftag; - const String *charset; + Charset *source_charset; + Charset *client_charset; private: @@ -83,8 +106,11 @@ private: /// checks whether mem allocated OK. throws exception otherwise void *check(void *ptr, size_t size) { - if(ptr) + if(ptr) { + ftotal_allocated+=size; + ftotal_times++; return ptr; + } fail_alloc(size); @@ -97,28 +123,10 @@ private: /// throws register cleanup exception void fail_register_cleanup() const; -#ifdef XML - -public: - /// converts Xalan string to char * - const char *transcode_cstr(const XalanDOMString& s); - /// converts Xalan string to parser String - String& transcode(const XalanDOMString& s); - /// converts char * to Xalan string - std::auto_ptr transcode_buf(const char *buf, size_t buf_size); - /// converts parser String to Xalan string - std::auto_ptr transcode(const String& s); - -private: - - void set_charset(const char *new_scharset); - void update_transcoder(); - -private: - - XMLTranscoder *transcoder; - -#endif +private: // statistics + + size_t ftotal_allocated; + unsigned int ftotal_times; private: //disabled @@ -160,8 +168,10 @@ public: void *calloc(size_t size) const { return fpool->calloc(size); } void register_cleanup(void (*cleanup) (void *), void *data) { fpool->register_cleanup(cleanup, data); } #ifdef XML - const char *transcode_cstr(const XalanDOMString& s) { return fpool->transcode_cstr(s); } - String& transcode(const XalanDOMString& s) { return fpool->transcode(s); } + + const char *transcode_cstr(GdomeDOMString *s) { return fpool->transcode_cstr(s); } + String& transcode(GdomeDOMString *s) { return fpool->transcode(s); } + #endif //} };