Commit f8b9ca5f authored by Pieter Hintjens's avatar Pieter Hintjens

Problem: zmq timers API is not CLASS conformant

If we're going to add CLASS-like APIs we should use the proper
syntax; specifically 'destroy' instead of 'close', which is a
hangover from the 'ZeroMQ is like sockets' model we're slowly
moving away from.

Solution: change zmq_timers_close(p) to zmq_timers_destroy(&p)
parent 62780956
...@@ -457,8 +457,8 @@ ZMQ_EXPORT int zmq_poller_remove_fd (void *poller, int fd); ...@@ -457,8 +457,8 @@ ZMQ_EXPORT int zmq_poller_remove_fd (void *poller, int fd);
typedef void (zmq_timer_fn)(int timer_id, void *arg); typedef void (zmq_timer_fn)(int timer_id, void *arg);
ZMQ_EXPORT void *zmq_timers_new (); ZMQ_EXPORT void *zmq_timers_new (void);
ZMQ_EXPORT int zmq_timers_close (void *timers); ZMQ_EXPORT int zmq_timers_destroy (void **timers);
ZMQ_EXPORT int zmq_timers_add (void *timers, size_t interval, zmq_timer_fn handler, void *arg); ZMQ_EXPORT int zmq_timers_add (void *timers, size_t interval, zmq_timer_fn handler, void *arg);
ZMQ_EXPORT int zmq_timers_cancel (void *timers, int timer_id); ZMQ_EXPORT int zmq_timers_cancel (void *timers, int timer_id);
ZMQ_EXPORT int zmq_timers_set_interval (void *timers, int timer_id, size_t interval); ZMQ_EXPORT int zmq_timers_set_interval (void *timers, int timer_id, size_t interval);
......
...@@ -1185,14 +1185,15 @@ void *zmq_timers_new () ...@@ -1185,14 +1185,15 @@ void *zmq_timers_new ()
return timers; return timers;
} }
int zmq_timers_close (void *timers_) int zmq_timers_destroy (void **timers_p_)
{ {
if (!timers_ || !((zmq::timers_t*)timers_)->check_tag ()) { void *timers = *timers_p_;
if (!timers || !((zmq::timers_t *) timers)->check_tag ()) {
errno = EFAULT; errno = EFAULT;
return -1; return -1;
} }
delete ((zmq::timers_t *) timers);
delete ((zmq::timers_t*)timers_); *timers_p_ = NULL;
return 0; return 0;
} }
......
...@@ -119,7 +119,7 @@ int main (void) ...@@ -119,7 +119,7 @@ int main (void)
assert (rc == 0); assert (rc == 0);
assert (!timer_invoked); assert (!timer_invoked);
rc = zmq_timers_close (timers); rc = zmq_timers_destroy (&timers);
assert (rc == 0); assert (rc == 0);
return 0; return 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment