X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=libtest%2Fcmdline.h;h=44fd17f92ff4f75ec484fa8e05575e114ef59373;hb=33b1be807f69d8ed539f0346d6446a48335b4295;hp=d1019d548a6b65a98d54bd495e929e8e274a3553;hpb=751e342e158ae65052ce098ccd64aa54e39312db;p=m6w6%2Flibmemcached diff --git a/libtest/cmdline.h b/libtest/cmdline.h index d1019d54..44fd17f9 100644 --- a/libtest/cmdline.h +++ b/libtest/cmdline.h @@ -39,27 +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]; }; @@ -70,8 +71,9 @@ public: void add_option(const std::string&); void add_option(const std::string&, const std::string&); + void add_long_option(const std::string& option_name, const std::string& option_value); error_t run(const char *args[]= NULL); - error_t wait(); + error_t wait(bool nohang= true); libtest::vchar_t stdout_result() const { @@ -88,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(); @@ -95,15 +102,52 @@ public: std::string print(); + void use_valgrind(bool arg= true) + { + _use_valgrind= arg; + } + + bool check() const; + + bool slurp(); + void murder(); + + void use_gdb(bool arg= true) + { + _use_gdb= arg; + } + + void use_ptrcheck(bool arg= true) + { + _use_ptrcheck= arg; + } + + std::string arguments(); + + std::string gdb_filename() + { + return _gdb_filename; + } + + pid_t pid() const + { + return _pid; + } + private: void create_argv(const char *args[]); void delete_argv(); private: const bool _use_libtool; + bool _use_valgrind; + bool _use_gdb; + bool _use_ptrcheck; size_t _argc; + std::string _exectuble_name; std::string _exectuble; std::string _exectuble_with_path; + std::string _gdb_filename; Options _options; Pipe stdin_fd; Pipe stdout_fd; @@ -129,6 +173,9 @@ static inline std::ostream& operator<<(std::ostream& output, const enum Applicat case Application::INVALID: output << "127"; break; + + default: + output << "EXIT_UNKNOWN"; } return output;