X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;ds=sidebyside;f=libtest%2Fcmdline.h;h=44fd17f92ff4f75ec484fa8e05575e114ef59373;hb=refs%2Ftags%2F1.0.6;hp=7b0afc5ffc27310374ac7e3457d1c5e7d8df7536;hpb=675ac17fddca229e391d80eb610959d9c53db6e5;p=m6w6%2Flibmemcached diff --git a/libtest/cmdline.h b/libtest/cmdline.h index 7b0afc5f..44fd17f9 100644 --- a/libtest/cmdline.h +++ b/libtest/cmdline.h @@ -39,29 +39,28 @@ public: class Pipe { public: - Pipe(); + Pipe(int); ~Pipe(); - int* fd() - { - return _fd; - } + int fd(); enum close_t { - READ, - WRITE + READ= 0, + WRITE= 1 }; void reset(); void close(const close_t& arg); void dup_for_spawn(const close_t& arg, - posix_spawn_file_actions_t& file_actions, - const int newfildes); + posix_spawn_file_actions_t& file_actions); void nonblock(); + void cloexec(); + bool read(libtest::vchar_t&); private: - int _fd[2]; + const int _std_fd; + int _pipe_fd[2]; bool _open[2]; }; @@ -91,6 +90,11 @@ public: return _stderr_buffer; } + const char* stderr_c_str() const + { + return &_stderr_buffer[0]; + } + size_t stderr_result_length() const { return _stderr_buffer.size(); @@ -113,6 +117,11 @@ public: _use_gdb= arg; } + void use_ptrcheck(bool arg= true) + { + _use_ptrcheck= arg; + } + std::string arguments(); std::string gdb_filename() @@ -133,6 +142,7 @@ private: const bool _use_libtool; bool _use_valgrind; bool _use_gdb; + bool _use_ptrcheck; size_t _argc; std::string _exectuble_name; std::string _exectuble;