#include <arpa/inet.h>
void lock_state::wait(lock & mutex_lock) {
- auto self = this_thread::get_id();
+ auto self = std::this_thread::get_id();
c[self].wait(mutex_lock);
c.erase(self);
}
c[who].notify_one();
}
-typedef map<lock_protocol::lockid_t, lock_state> lock_map;
-
in_port_t lock_client::last_port = 0;
lock_state & lock_client::get_lock_state(lock_protocol::lockid_t lid) {
srandom((uint32_t)time(NULL)^last_port);
rlock_port = ((random()%32000) | (0x1 << 10));
- id = "127.0.0.1:" + to_string(rlock_port);
+ id = "127.0.0.1:" + std::to_string(rlock_port);
last_port = rlock_port;
rlsrpc = unique_ptr<rpcs>(new rpcs(rlock_port));
rlsrpc->reg(rlock_protocol::revoke, &lock_client::revoke_handler, this);
lock_protocol::status lock_client::acquire(lock_protocol::lockid_t lid) {
lock_state & st = get_lock_state(lid);
lock sl(st.m);
- auto self = this_thread::get_id();
+ auto self = std::this_thread::get_id();
// check for reentrancy
VERIFY(st.state != lock_state::locked || st.held_by != self);
lock_protocol::status lock_client::release(lock_protocol::lockid_t lid) {
lock_state & st = get_lock_state(lid);
lock sl(st.m);
- auto self = this_thread::get_id();
+ auto self = std::this_thread::get_id();
VERIFY(st.state == lock_state::locked && st.held_by == self);
st.state = lock_state::free;
LOG << "Lock " << lid << ": free";