X-Git-Url: http://developer.intra2net.com/git/?p=libt2n;a=blobdiff_plain;f=src%2Fcontainer.hxx;h=020194ba1ee2b1b3b1add9a4a7c253ccae2dbc35;hp=2bf576bdfb1f8230c77985eabe68a35814c6c710;hb=c72238fb7fc6eb081c2a0bc95fff369c760343f4;hpb=a7170401dd90dc79cc7d7a808cfe18a06c7e983b diff --git a/src/container.hxx b/src/container.hxx index 2bf576b..020194b 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,24 +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); } + bool has_result() + { return (result_type==regular); } }; -/** @brief contains a command +/** @brief contains a libt2n::command */ class command_container { @@ -79,9 +98,12 @@ class command_container public: command_container() - { cmd=0; } + : cmd(NULL) + {} + command_container(command *_cmd) - { cmd=_cmd; } + : cmd(_cmd) + {} ~command_container(); @@ -95,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