From 220e2281e47ef13d99668685e26bbd8e45db18d5 Mon Sep 17 00:00:00 2001 From: Brett Kiefer Date: Wed, 15 Jun 2011 11:07:23 -0400 Subject: [PATCH] Fix issue 915 (Failed to find kqueue on FreeBSD) with the relevant portion of a patch submitted to node.js dev (http://groups.google.com/group/nodejs-dev/browse_thread/thread/3aaf7fe2ca390fdc) by Davie Siegel. The issue is that event.h requires types.h on FreeBSD. This rearranges some of the logic but looks like it should still be valid for Darwin. --- deps/libev/wscript | 17 +++++++++++------ 1 file changed, 11 insertions(+), 6 deletions(-) diff --git a/deps/libev/wscript b/deps/libev/wscript index 4f6c9a882de..aaa57e114d1 100644 --- a/deps/libev/wscript +++ b/deps/libev/wscript @@ -28,12 +28,17 @@ def configure(conf): if conf.check_cc(header_name="poll.h"): conf.check_cc(header_name="poll.h", function_name="poll") - conf.check_cc(header_name="sys/event.h") - conf.check_cc(header_name="sys/queue.h") - if PLATFORM_IS_DARWIN: - conf.check_cc(header_name="sys/event.h", function_name="kqueue") - else: - conf.check_cc(header_name="sys/queue.h", function_name="kqueue") + kqueue_headers = [] + # On FreeBSD event.h is not selfcontained and requires types.h + event_headers = ["sys/types.h", "sys/event.h"] + if conf.check_cc(header_name=event_headers, define_name="HAVE_SYS_EVENT_H"): + kqueue_headers += event_headers + + if conf.check_cc(header_name="sys/queue.h"): + kqueue_headers.append("sys/queue.h") + + if kqueue_headers: + conf.check_cc(header_name=kqueue_headers, function_name="kqueue") if PLATFORM_IS_WIN32: # Windows has sys/select.h and select but this config line doesn't detect it properly