X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fcontainer.hxx;fp=src%2Fcontainer.hxx;h=2bf576bdfb1f8230c77985eabe68a35814c6c710;hp=8491926eab9bbd075fd059f9e9894ca67ab00ab2;hb=a7170401dd90dc79cc7d7a808cfe18a06c7e983b;hpb=d184c64894e6c4f3adb9467078acfc9e7446664a diff --git a/src/container.hxx b/src/container.hxx index 8491926..2bf576b 100644 --- a/src/container.hxx +++ b/src/container.hxx @@ -19,6 +19,12 @@ #ifndef __LIBT2N_CONTAINER #define __LIBT2N_CONTAINER +#include +#include +#include +#include +#include + #include "command.hxx" #include "t2n_exception.hxx" @@ -38,16 +44,8 @@ class result_container t2n_exception *ex; friend class boost::serialization::access; - // When the class Archive corresponds to an output archive, the - // & operator is defined similar to <<. Likewise, when the class Archive - // is a type of input archive the & operator is defined similar to >>. template - void serialize(Archive & ar, const unsigned int version) - { - ar & BOOST_SERIALIZATION_NVP(result_type); - ar & BOOST_SERIALIZATION_NVP(res); - ar & BOOST_SERIALIZATION_NVP(ex); - } + void serialize(Archive & ar, const unsigned int version); public: result_container() @@ -58,29 +56,14 @@ class result_container result_container(t2n_exception *_ex) { set_exception(_ex); } + ~result_container(); + void set_result(result *_res) { res=_res; ex=0; result_type=regular; } void set_exception(t2n_exception *_ex) { res=0; ex=_ex; result_type=exception; } - /** @brief returns the result or throw the carried exception. - ATTENTION: the result object is deleted in the destructor - */ - result* get_result(void) - { - if (result_type==exception) - ex->do_throw(); - return res; - } - - /// deletes the carried result or exception objects - ~result_container() - { - if (res) - delete res; - if (ex) - delete ex; - } + result* get_result(void); }; /** @brief contains a command @@ -92,11 +75,7 @@ class command_container friend class boost::serialization::access; template - void serialize(Archive & ar, const unsigned int version) - { - std::cerr << "ser: command_container" << std::endl; - ar & BOOST_SERIALIZATION_NVP(cmd); - } + void serialize(Archive & ar, const unsigned int version); public: command_container() @@ -104,15 +83,11 @@ class command_container command_container(command *_cmd) { cmd=_cmd; } + ~command_container(); + /// return the contained command command* get_command() { return cmd; } - - ~command_container() - { - if (cmd) - delete cmd; - } }; } // namespace libt2n