ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/EV/Makefile.PL
(Generate patch)

Comparing EV/Makefile.PL (file contents):
Revision 1.31 by root, Thu Jan 31 19:59:23 2008 UTC vs.
Revision 1.38 by root, Thu Nov 20 00:35:16 2008 UTC

1use 5.006; 1use 5.006;
2 2
3use strict qw(vars subs);
3use Config; 4use Config;
4use ExtUtils::MakeMaker; 5use ExtUtils::MakeMaker;
5 6
6unless (-e "libev/ev_epoll.c") { 7unless (-e "libev/ev_epoll.c") {
7 print <<EOF; 8 print <<EOF;
43will otherwise be autodetected at both compile- and runtime. (this setting 44will otherwise be autodetected at both compile- and runtime. (this setting
44currently affects the use of nanosleep over select as well). 45currently affects the use of nanosleep over select as well).
45 46
46EOF 47EOF
47 48
48$DEFINE .= " -DEV_USE_MONOTONIC=" . (0 + (prompt ("Enable optional support for CLOCK_MONOTONIC (y/n)?", "y") =~ /[yY]/)); 49my $DEFINE .= " -DEV_USE_MONOTONIC=" . (0 + (prompt ("Enable optional support for CLOCK_MONOTONIC (y/n)?", "y") =~ /[yY]/));
49 50
50print <<EOF; 51print <<EOF;
51 52
52*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 53*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
53 54
127fall back to using select when epoll isn't available. If unsure, accept 128fall back to using select when epoll isn't available. If unsure, accept
128the default. 129the default.
129 130
130EOF 131EOF
131 132
133my $can_epoll = -e "/usr/include/sys/epoll.h";
134$can_epoll = $ENV{EV_EPOLL} if exists $ENV{EV_EPOLL};
132$DEFINE .= " -DEV_USE_EPOLL=" . (0 + (prompt ("Enable epoll backend (y/n)?", (-e "/usr/include/sys/epoll.h") ? "y" : "n") =~ /[yY]/)); 135$DEFINE .= " -DEV_USE_EPOLL=" . (0 + (prompt ("Enable epoll backend (y/n)?", $can_epoll ? "y" : "n") =~ /[yY]/));
133 136
134print <<EOF; 137print <<EOF;
135 138
136*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 139*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
137 140
140many BSD systems. Support for kqueue will be detected at runtime, with a 143many BSD systems. Support for kqueue will be detected at runtime, with a
141safe fallback to other methods when it cannot be used. 144safe fallback to other methods when it cannot be used.
142 145
143Note that kqueue is broken on most operating systems, so by default it 146Note that kqueue is broken on most operating systems, so by default it
144won't be used on many platforms, but you can still create your own event 147won't be used on many platforms, but you can still create your own event
145loop with qkueue backend. 148loop with kqueue backend.
146 149
147Here is what we know: 150Here is what we know:
148 151
149NetBSD: partially working in at least 3.1. Yeah! :) 152NetBSD: partially working in at least 3.1. Yeah! :)
150FreeBSD: broken on at least 6.2-STABLE, 153FreeBSD: broken on at least 6.2-STABLE,
154OS X: completely, utterly broken on at least < 10.5. 157OS X: completely, utterly broken on at least < 10.5.
155 158
156EOF 159EOF
157 160
158my $can_kqueue = -e "/usr/include/sys/event.h"; 161my $can_kqueue = -e "/usr/include/sys/event.h";
159 162$can_kqueue = $ENV{EV_KQUEUE} if exists $ENV{EV_KQUEUE};
160$DEFINE .= " -DEV_USE_KQUEUE=" . (0 + (prompt ("Enable kqueue backend (y/n)?", $can_kqueue ? "y" : "n") =~ /[yY]/)); 163$DEFINE .= " -DEV_USE_KQUEUE=" . (0 + (prompt ("Enable kqueue backend (y/n)?", $can_kqueue ? "y" : "n") =~ /[yY]/));
161 164
162print <<EOF; 165print <<EOF;
163 166
164*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 167*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
182can specify additional libraries to provide these calls (and any other 185can specify additional libraries to provide these calls (and any other
183required by EV) now, or accept the default. 186required by EV) now, or accept the default.
184 187
185EOF 188EOF
186 189
187$SOLARIS_LIBS = $^O =~ /solaris/ ? " -lsocket -lnsl" : ""; 190my $solaris_libs = $^O =~ /solaris/i ? "-lsocket -lnsl" : "";
188 191my $librt = $^O =~ /linux/i ? "-lpthread" : "-lpthread -lrt";
189$LIBS = prompt "Extra libraries for pthread_atfork and clock_gettime?", "-lpthread -lrt$SOLARIS_LIBS"; 192my $LIBS = prompt "Extra libraries for pthread_atfork and clock_gettime?", "$librt $solaris_libs";
190 193
191 194
192print <<EOF; 195print <<EOF;
193 196
194*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 197*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
199you have it, it is usually a good idea to enable it. 202you have it, it is usually a good idea to enable it.
200 203
201EOF 204EOF
202 205
203my $can_inotify = -e "/usr/include/sys/inotify.h"; 206my $can_inotify = -e "/usr/include/sys/inotify.h";
204 207$can_inotify = $ENV{EV_INOTIFY} if exists $ENV{EV_INOTIFY};
205$DEFINE .= " -DEV_USE_INOTIFY=" . (0 + (prompt ("Enable inotify support (y/n)?", $can_inotify ? "y" : "n") =~ /[yY]/)); 208$DEFINE .= " -DEV_USE_INOTIFY=" . (0 + (prompt ("Enable inotify support (y/n)?", $can_inotify ? "y" : "n") =~ /[yY]/));
209
210print <<EOF;
211
212*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
213
214
215Another useful bit of functionality is the Linux eventfd, which is useful
216for faster signal handling (don't care) and intra-thread communications
217(more relevant). Kernel support for this will be probed at runtime, but
218your libc must contain the necessary wrapper. Glibc 2.7 and later should
219have this wrapper.
220
221EOF
222
223my $can_eventfd = -e "/usr/include/sys/eventfd.h";
224$can_eventfd = $ENV{EV_EVENTFD} if exists $ENV{EV_EVENTFD};
225$DEFINE .= " -DEV_USE_EVENTFD=" . (0 + (prompt ("Enable linux eventfd support (y/n)?", $can_eventfd ? "y" : "n") =~ /[yY]/));
206 226
207print <<EOF; 227print <<EOF;
208 228
209*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 229*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
210 230
235 PM => { 255 PM => {
236 'EV.pm' => '$(INST_LIBDIR)/EV.pm', 256 'EV.pm' => '$(INST_LIBDIR)/EV.pm',
237 'EV/EVAPI.h' => '$(INST_LIBDIR)/EV/EVAPI.h', 257 'EV/EVAPI.h' => '$(INST_LIBDIR)/EV/EVAPI.h',
238 'EV/MakeMaker.pm' => '$(INST_LIBDIR)/EV/MakeMaker.pm', 258 'EV/MakeMaker.pm' => '$(INST_LIBDIR)/EV/MakeMaker.pm',
239 'libev/ev.h' => '$(INST_LIBDIR)/EV/ev.h', 259 'libev/ev.h' => '$(INST_LIBDIR)/EV/ev.h',
260 'libev/ev.pod' => '$(INST_LIBDIR)/EV/libev.pod',
240 }, 261 },
262 MAN3PODS => {
263 'EV.pm' => '$(INST_MAN3DIR)/EV.$(MAN3EXT)',
264 'EV/MakeMaker.pm' => '$(INST_MAN3DIR)/EV::MakeMaker.$(MAN3EXT)',
265 'libev/ev.pod' => '$(INST_MAN3DIR)/EV::libev.$(MAN3EXT)',
266 },
241); 267);
242 268
243 269

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines