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.37 by root, Thu Oct 30 04:01:46 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/ ? " -lsocket -lnsl" : "";
188
189$LIBS = prompt "Extra libraries for pthread_atfork and clock_gettime?", "-lpthread -lrt$SOLARIS_LIBS"; 191my $LIBS = prompt "Extra libraries for pthread_atfork and clock_gettime?", "-lpthread -lrt$solaris_libs";
190 192
191 193
192print <<EOF; 194print <<EOF;
193 195
194*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 196*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
199you have it, it is usually a good idea to enable it. 201you have it, it is usually a good idea to enable it.
200 202
201EOF 203EOF
202 204
203my $can_inotify = -e "/usr/include/sys/inotify.h"; 205my $can_inotify = -e "/usr/include/sys/inotify.h";
204 206$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]/)); 207$DEFINE .= " -DEV_USE_INOTIFY=" . (0 + (prompt ("Enable inotify support (y/n)?", $can_inotify ? "y" : "n") =~ /[yY]/));
208
209print <<EOF;
210
211*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
212
213
214Another useful bit of functionality is the Linux eventfd, which is useful
215for faster signal handling (don't care) and intra-thread communications
216(more relevant). Kernel support for this will be probed at runtime, but
217your libc must contain the necessary wrapper. Glibc 2.7 and later should
218have this wrapper.
219
220EOF
221
222my $can_eventfd = -e "/usr/include/sys/eventfd.h";
223$can_eventfd = $ENV{EV_EVENTFD} if exists $ENV{EV_EVENTFD};
224$DEFINE .= " -DEV_USE_EVENTFD=" . (0 + (prompt ("Enable linux eventfd support (y/n)?", $can_eventfd ? "y" : "n") =~ /[yY]/));
206 225
207print <<EOF; 226print <<EOF;
208 227
209*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 228*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
210 229
235 PM => { 254 PM => {
236 'EV.pm' => '$(INST_LIBDIR)/EV.pm', 255 'EV.pm' => '$(INST_LIBDIR)/EV.pm',
237 'EV/EVAPI.h' => '$(INST_LIBDIR)/EV/EVAPI.h', 256 'EV/EVAPI.h' => '$(INST_LIBDIR)/EV/EVAPI.h',
238 'EV/MakeMaker.pm' => '$(INST_LIBDIR)/EV/MakeMaker.pm', 257 'EV/MakeMaker.pm' => '$(INST_LIBDIR)/EV/MakeMaker.pm',
239 'libev/ev.h' => '$(INST_LIBDIR)/EV/ev.h', 258 'libev/ev.h' => '$(INST_LIBDIR)/EV/ev.h',
259 'libev/ev.pod' => '$(INST_LIBDIR)/EV/libev.pod',
240 }, 260 },
261 MAN3PODS => {
262 'EV.pm' => '$(INST_MAN3DIR)/EV.$(MAN3EXT)',
263 'EV/MakeMaker.pm' => '$(INST_MAN3DIR)/EV::MakeMaker.$(MAN3EXT)',
264 'libev/ev.pod' => '$(INST_MAN3DIR)/EV::libev.$(MAN3EXT)',
265 },
241); 266);
242 267
243 268

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines