X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fcontainer.hxx;h=560df1c99cbb9073eb7428af64a5128925291d5d;hp=710a07e73b9fd8bef18e623c4a43b4ae44c10476;hb=9e76c81586915f9ff6f413d9fefec9b7be7cad31;hpb=01a464637ed95b0aacd58eb74bdd17df4a7851ab diff --git a/src/container.hxx b/src/container.hxx index 710a07e..560df1c 100644 --- a/src/container.hxx +++ b/src/container.hxx @@ -33,7 +33,7 @@ namespace libt2n { -/** @brief contains the result (return value or exception) of a executed command +/** @brief contains the result (return value as libt2n::result or an libt2n::t2n_exception) of a executed command */ class result_container { @@ -49,29 +49,43 @@ class result_container public: result_container() - { res=0; ex=0; } + : res(NULL) + , ex(NULL) + , result_type(regular) + { + } result_container(result *_res) - { set_result(_res); } + : res(_res) + , ex(NULL) + , result_type(regular) + { + } + result_container(t2n_exception *_ex) - { set_exception(_ex); } + : res(NULL) + , ex(_ex) + , result_type(exception) + { + } ~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; } result* get_result(void); bool has_exception() - { return (result_type==exception); } + { return (result_type==exception && ex != NULL); } bool has_result() - { return (result_type==regular); } + { return (result_type==regular && res != NULL); } }; -/** @brief contains a command +/** @brief contains a libt2n::command */ class command_container { @@ -84,9 +98,12 @@ class command_container public: command_container() - { cmd=0; } + : cmd(NULL) + {} + command_container(command *_cmd) - { cmd=_cmd; } + : cmd(_cmd) + {} ~command_container(); @@ -100,5 +117,7 @@ class command_container BOOST_CLASS_TRACKING(libt2n::result_container, boost::serialization::track_never) BOOST_CLASS_TRACKING(libt2n::command_container, boost::serialization::track_never) +#include "container.tcc" + #endif