class rsm_client {
protected:
- std::string primary;
- std::vector<std::string> known_mems;
- std::mutex rsm_client_mutex;
+ string primary;
+ vector<string> known_mems;
+ mutex rsm_client_mutex;
void primary_failure(lock & rsm_client_mutex_lock);
bool init_members(lock & rsm_client_mutex_lock);
public:
- rsm_client(std::string dst);
- rsm_protocol::status invoke(unsigned int proc, std::string &rep, const std::string &req);
+ rsm_client(string dst);
+ rsm_protocol::status invoke(unsigned int proc, string &rep, const string &req);
template<class R, class ...Args>
int call(unsigned int proc, R & r, const Args & ...a1);
template<class R>
int rsm_client::call_m(unsigned int proc, R & r, const marshall & req) {
- std::string rep;
- std::string res;
- int intret = invoke(proc, rep, req.cstr());
+ string rep;
+ string res;
+ int intret = invoke(proc, rep, req);
VERIFY( intret == rsm_client_protocol::OK );
- unmarshall u(rep);
+ unmarshall u(rep, false);
u >> intret;
if (intret < 0) return intret;
u >> res;
VERIFY(0);
return rpc_const::unmarshal_reply_failure;
}
- unmarshall u1(res);
+ unmarshall u1(res, false);
u1 >> r;
if(!u1.okdone()) {
cerr << "rsm_client::call_m: failed to unmarshall the reply." << endl;