openbsd-ports/devel/protobuf-c/patches/patch-src_google_protobuf-c_protobuf-c-dispatch_c

73 lines
2.1 KiB
Plaintext
Raw Normal View History

$OpenBSD: patch-src_google_protobuf-c_protobuf-c-dispatch_c,v 1.1.1.1 2011/07/08 08:58:02 dcoppa Exp $
malloc.h is obsolete
clear_changes isn't necessary because n_changes is cleared in
dispatch_dispatch (upstream svn revision r286)
--- src/google/protobuf-c/protobuf-c-dispatch.c.orig Thu Mar 10 20:02:48 2011
+++ src/google/protobuf-c/protobuf-c-dispatch.c Thu Jul 7 12:50:09 2011
@@ -10,11 +10,7 @@
#include "protobuf-c-config.h"
#endif
#include <assert.h>
-#if HAVE_ALLOCA_H
-# include <alloca.h>
-#elif HAVE_MALLOC_H
-# include <malloc.h>
-#endif
+#include <stdlib.h>
#include <sys/time.h>
#include <unistd.h>
#include <string.h>
@@ -98,6 +94,7 @@ struct _RealDispatch
FDMapNode *fd_map_tree; /* map indexed by fd */
#endif
+ protobuf_c_boolean is_dispatching;
ProtobufCDispatchTimer *timer_tree;
ProtobufCAllocator *allocator;
@@ -193,8 +190,10 @@ ProtobufCDispatch *protobuf_c_dispatch_new (ProtobufCA
rv->allocator = allocator;
rv->timer_tree = NULL;
rv->first_idle = rv->last_idle = NULL;
+ rv->base.has_idle = 0;
rv->recycled_idles = NULL;
rv->recycled_timeouts = NULL;
+ rv->is_dispatching = 0;
/* need to handle SIGPIPE more gracefully than default */
signal (SIGPIPE, SIG_IGN);
@@ -531,6 +530,12 @@ protobuf_c_dispatch_dispatch (ProtobufCDispatch *dispa
unsigned i;
FDMap *fd_map = d->fd_map;
struct timeval tv;
+
+ /* Re-entrancy guard. If this is triggerred, then
+ you are calling protobuf_c_dispatch_dispatch (or _run)
+ from a callback function. That's not allowed. */
+ d->is_dispatching = 1;
+
fd_max = 0;
for (i = 0; i < n_notifies; i++)
if (fd_max < (unsigned) notifies[i].fd)
@@ -604,6 +609,9 @@ protobuf_c_dispatch_dispatch (ProtobufCDispatch *dispa
}
if (d->timer_tree == NULL)
d->base.has_timeout = 0;
+
+ /* Finish reentrance guard. */
+ d->is_dispatching = 0;
}
void
@@ -717,7 +725,6 @@ protobuf_c_dispatch_run (ProtobufCDispatch *dispatch)
if (events[n_events].events != 0)
n_events++;
}
- protobuf_c_dispatch_clear_changes (dispatch);
protobuf_c_dispatch_dispatch (dispatch, n_events, events);
if (to_free)
FREE (to_free);