--- parser3/src/include/pa_pool.h 2001/11/16 11:51:32 1.71 +++ 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.71 2001/11/16 11:51:32 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,7 +37,6 @@ class Pool { public: Pool(void *astorage); - ~Pool(); ///{@ statistics size_t total_allocated() { return ftotal_allocated; } @@ -60,16 +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; - const String *charset; + Charset *source_charset; + Charset *client_charset; private: @@ -101,29 +123,6 @@ 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; @@ -169,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 //} };