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

Comparing EV/Makefile.PL (file contents):
Revision 1.53 by root, Tue Jan 15 21:49:38 2013 UTC vs.
Revision 1.62 by root, Thu Jul 11 08:51:48 2019 UTC

1use 5.008002;
2
3use strict qw(vars subs); 1use strict qw(vars subs);
2use Canary::Stability EV => 1, 5.008002;
4use Config; 3use Config;
5use ExtUtils::MakeMaker; 4use ExtUtils::MakeMaker;
6 5
6sub have_inc($) {
7 scalar grep -r "$_/$_[0]", $Config{usrinc}, split / /, $Config{incpth}
8}
9
10my $DEFINE;
11
7unless (-e "libev/ev_epoll.c") { 12unless (-e "libev/ev_linuxaio.c") {
8 print <<EOF; 13 print <<EOF;
9 14
10*** 15***
11*** ERROR: libev is missing or damaged. If you used a CVS check-out of EV, 16*** ERROR: libev is missing or damaged. If you used a CVS check-out of EV,
12*** you also have to check-out the "libev" module from the same CVS 17*** you also have to check-out the "libev" module from the same CVS
44will otherwise be autodetected at both compile- and runtime. (this setting 49will otherwise be autodetected at both compile- and runtime. (this setting
45currently affects the use of nanosleep over select as well). 50currently affects the use of nanosleep over select as well).
46 51
47EOF 52EOF
48 53
49my $DEFINE .= " -DEV_USE_MONOTONIC=" . (0 + (prompt ("Enable optional support for CLOCK_MONOTONIC (y/n)?", "y") =~ /[yY]/)); 54unless (prompt ("Enable optional support for CLOCK_MONOTONIC (y/n)?", "y") =~ /[yY]/) {
55 $DEFINE .= " -DEV_USE_MONOTONIC=0";
56}
50 57
51print <<EOF; 58print <<EOF;
52 59
53*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 60*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
54 61
93 100
94EOF 101EOF
95 102
96 if (prompt ("Force use of system fd_set for select backend (y/n)?", "n") =~ /[yY]/) { 103 if (prompt ("Force use of system fd_set for select backend (y/n)?", "n") =~ /[yY]/) {
97 $DEFINE .= " -DEV_SELECT_USE_FD_SET"; 104 $DEFINE .= " -DEV_SELECT_USE_FD_SET";
98 } 105 }
99} else { 106} else {
100 $DEFINE .= " -DEV_USE_SELECT=0"; 107 $DEFINE .= " -DEV_USE_SELECT=0";
101} 108}
102 109
103print <<EOF; 110print <<EOF;
104 111
105*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 112*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
106 113
110doesn't work), but works basically everywhere else. It is recommended to use 117doesn't work), but works basically everywhere else. It is recommended to use
111the default here unless you run into compile problems in ev_poll.c. 118the default here unless you run into compile problems in ev_poll.c.
112 119
113EOF 120EOF
114 121
115$DEFINE .= " -DEV_USE_POLL=" . (0 + (prompt ("Enable poll backend (y/n)?", (-e "/usr/include/poll.h") ? "y" : "n") =~ /[yY]/)); 122$DEFINE .= " -DEV_USE_POLL=" . (0 + (prompt ("Enable poll backend (y/n)?", (have_inc "poll.h") ? "y" : "n") =~ /[yY]/));
116 123
117print <<EOF; 124print <<EOF;
118 125
119*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 126*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
120 127
127fall back to using select when epoll isn't available. If unsure, accept 134fall back to using select when epoll isn't available. If unsure, accept
128the default. 135the default.
129 136
130EOF 137EOF
131 138
132my $can_epoll = -e "/usr/include/sys/epoll.h"; 139my $can_epoll = have_inc "sys/epoll.h";
133$can_epoll = $ENV{EV_EPOLL} if exists $ENV{EV_EPOLL}; 140$can_epoll = $ENV{EV_EPOLL} if exists $ENV{EV_EPOLL};
134$DEFINE .= " -DEV_USE_EPOLL=" . (0 + (prompt ("Enable epoll backend (y/n)?", $can_epoll ? "y" : "n") =~ /[yY]/)); 141$DEFINE .= " -DEV_USE_EPOLL=" . (0 + (prompt ("Enable epoll backend (y/n)?", $can_epoll ? "y" : "n") =~ /[yY]/));
142
143print <<EOF;
144
145*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
146
147
148Linux 4.18 introduced another event polling interface, this time using
149the Linux AIO API. While this API is far superior to epoll and almost
150rivals kqueue, it also suffers from the same issues as kqueue typically
151does: only a subset of file types are supported (as of 4.19, I have seen
152eventfd, pipes, sockets files and some devices, but no ttys). It also
153is subject arbitrary system-wide limits imposed on it. Therefore, this
154backend is not used by default, even when it is compiled in, and you have
155to request it explicitly, e.g. with LIBEV_FLAGS=64. If unsure, accept the
156default.
157
158EOF
159
160my $can_linuxaio = have_inc "linux/aio_abi.h";
161$can_linuxaio = $ENV{EV_LINUXAIO} if exists $ENV{EV_LINUXAIO};
162$can_linuxaio = 0 + (prompt ("Enable linux aio backend (y/n)?", $can_linuxaio ? "y" : "n") =~ /[yY]/);
163$DEFINE .= " -DEV_USE_LINUXAIO=$can_linuxaio";
164
165if ($can_linuxaio) {
166print <<EOF;
167
168*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
169
170
171The previously mentioned Linux AIO backend is experimental and will not
172be used unless requested explicitly. You can, howeer, choose to make ti a
173recommended basckend, which means it will be chosen if available even when
174not explicitly asked for, in preference to epoll on GNU/Linux. This option
175is likely temporary. When unsure, accept the default.
176
177EOF
178
179my $recommend_linuxaio = 0;
180$recommend_linuxaio = $ENV{EV_RECOMMEND_LINUXAIO} if exists $ENV{EV_RECOMMEND_LINUXAIO};
181$recommend_linuxaio = 0 + (prompt ("Treat linux aio as a recommended backend (y/n)?", $recommend_linuxaio ? "y" : "n") =~ /[yY]/);
182$DEFINE .= " -DEV_RECOMMEND_LINUXAIO=$recommend_linuxaio";
183}
135 184
136print <<EOF; 185print <<EOF;
137 186
138*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 187*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
139 188
155 (similar problems as on FreeBSD). 204 (similar problems as on FreeBSD).
156OS X: completely, utterly broken on at least <= 10.6. 205OS X: completely, utterly broken on at least <= 10.6.
157 206
158EOF 207EOF
159 208
160my $can_kqueue = -e "/usr/include/sys/event.h"; 209my $can_kqueue = have_inc "sys/event.h";
161$can_kqueue = $ENV{EV_KQUEUE} if exists $ENV{EV_KQUEUE}; 210$can_kqueue = $ENV{EV_KQUEUE} if exists $ENV{EV_KQUEUE};
162$DEFINE .= " -DEV_USE_KQUEUE=" . (0 + (prompt ("Enable kqueue backend (y/n)?", $can_kqueue ? "y" : "n") =~ /[yY]/)); 211$DEFINE .= " -DEV_USE_KQUEUE=" . (0 + (prompt ("Enable kqueue backend (y/n)?", $can_kqueue ? "y" : "n") =~ /[yY]/));
163 212
164print <<EOF; 213print <<EOF;
165 214
170solaris 10 event port interface. Support for event ports will be detected 219solaris 10 event port interface. Support for event ports will be detected
171at runtime, with a safe fallback to other methods when it cannot be used. 220at runtime, with a safe fallback to other methods when it cannot be used.
172 221
173EOF 222EOF
174 223
175$DEFINE .= " -DEV_USE_PORT=" . (0 + (prompt ("Enable event port backend (y/n)?", (-e "/usr/include/sys/port.h") ? "y" : "n") =~ /[yY]/)); 224$DEFINE .= " -DEV_USE_PORT=" . (0 + (prompt ("Enable event port backend (y/n)?", (have_inc "sys/port.h") ? "y" : "n") =~ /[yY]/));
176 225
177print <<EOF; 226print <<EOF;
178 227
179*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 228*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
180 229
206you have the include file and libc support for it, it is usually a good 255you have the include file and libc support for it, it is usually a good
207idea to enable it, as kernel availability is detected at runtime. 256idea to enable it, as kernel availability is detected at runtime.
208 257
209EOF 258EOF
210 259
211my $can_inotify = -e "/usr/include/sys/inotify.h"; 260my $can_inotify = have_inc "sys/inotify.h";
212$can_inotify = $ENV{EV_INOTIFY} if exists $ENV{EV_INOTIFY}; 261$can_inotify = $ENV{EV_INOTIFY} if exists $ENV{EV_INOTIFY};
213$DEFINE .= " -DEV_USE_INOTIFY=" . (0 + (prompt ("Enable inotify support (y/n)?", $can_inotify ? "y" : "n") =~ /[yY]/)); 262$DEFINE .= " -DEV_USE_INOTIFY=" . (0 + (prompt ("Enable inotify support (y/n)?", $can_inotify ? "y" : "n") =~ /[yY]/));
214 263
215print <<EOF; 264print <<EOF;
216 265
223your libc must contain the necessary wrapper. Glibc 2.7 and later should 272your libc must contain the necessary wrapper. Glibc 2.7 and later should
224have this wrapper. 273have this wrapper.
225 274
226EOF 275EOF
227 276
228my $can_eventfd = -e "/usr/include/sys/eventfd.h"; 277my $can_eventfd = have_inc "sys/eventfd.h";
229$can_eventfd = $ENV{EV_EVENTFD} if exists $ENV{EV_EVENTFD}; 278$can_eventfd = $ENV{EV_EVENTFD} if exists $ENV{EV_EVENTFD};
230$DEFINE .= " -DEV_USE_EVENTFD=" . (0 + (prompt ("Enable linux eventfd support (y/n)?", $can_eventfd ? "y" : "n") =~ /[yY]/)); 279$DEFINE .= " -DEV_USE_EVENTFD=" . (0 + (prompt ("Enable linux eventfd support (y/n)?", $can_eventfd ? "y" : "n") =~ /[yY]/));
231 280
232print <<EOF; 281print <<EOF;
233 282
239this will be probed at runtime, but your libc must contain the necessary 288this will be probed at runtime, but your libc must contain the necessary
240wrapper. Glibc 2.7 and later should have this wrapper. 289wrapper. Glibc 2.7 and later should have this wrapper.
241 290
242EOF 291EOF
243 292
244my $can_signalfd = -e "/usr/include/sys/signalfd.h"; 293my $can_signalfd = have_inc "sys/signalfd.h";
245$can_signalfd = $ENV{EV_SIGNALFD} if exists $ENV{EV_SIGNALFD}; 294$can_signalfd = $ENV{EV_SIGNALFD} if exists $ENV{EV_SIGNALFD};
246$DEFINE .= " -DEV_USE_SIGNALFD=" . (0 + (prompt ("Enable linux signalfd support (y/n)?", $can_signalfd ? "y" : "n") =~ /[yY]/)); 295$DEFINE .= " -DEV_USE_SIGNALFD=" . (0 + (prompt ("Enable linux signalfd support (y/n)?", $can_signalfd ? "y" : "n") =~ /[yY]/));
296
297print <<EOF;
298
299*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
300
301
302Libev contains numerous internal assert() invocations to check for
303consistency and user errors. These are normally enabled, but most
304perl builds disable this error reporting mechanism by default. You
305can re-enable these asserts here. Enabling them might help you catch
306programming bugs earlier, but might cause a small slowdown. Also, failures
307will be reported by aboritng your program, instead of throwing a perl
308exception.
309
310If unsure, enable this if you only use this perl installation for
311development, and leave it off for use in production environments.
312
313EOF
314
315my $enable_assertions = 0;
316$enable_assertions = 0 + (prompt ("Make sure assertions are enabled? (y/n)?", $enable_assertions ? "y" : "n") =~ /[yY]/);
317$DEFINE .= " -DEV_ENABLE_ASERTIONS=1" if $enable_assertions;
247 318
248print <<EOF; 319print <<EOF;
249 320
250*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** 321*** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
251 322
279 COMPRESS => 'gzip -9v', 350 COMPRESS => 'gzip -9v',
280 SUFFIX => '.gz', 351 SUFFIX => '.gz',
281 }, 352 },
282 depend => { 353 depend => {
283 "EV.c" => "EV/EVAPI.h " 354 "EV.c" => "EV/EVAPI.h "
284 . "libev/ev.c libev/ev.h libev/ev_epoll.c libev/ev_select.c libev/ev_kqueue.c libev/ev_poll.c " 355 . "libev/ev.c libev/ev.h libev/ev_epoll.c libev/ev_select.c libev/ev_kqueue.c libev/ev_poll.c libev/ev_linuxaio.c "
285 . "libev/ev_vars.h libev/ev_wrap.h", 356 . "libev/ev_vars.h libev/ev_wrap.h",
286 }, 357 },
287 INC => "-Ilibev", 358 INC => "-Ilibev",
288 DEFINE => "$DEFINE", 359 DEFINE => "$DEFINE",
289 NAME => "EV", 360 NAME => "EV",
290 LIBS => [$LIBS], 361 LIBS => [$LIBS],
291 PREREQ_PM => { 362 PREREQ_PM => {
292 @anyevent, 363 @anyevent,
293 "common::sense" => 0, 364 "common::sense" => 0,
294 }, 365 },
366 CONFIGURE_REQUIRES => { "ExtUtils::MakeMaker" => 6.52, "Canary::Stability" => 0 },
295 VERSION_FROM => "EV.pm", 367 VERSION_FROM => "EV.pm",
296 PM => { 368 PM => {
297 'EV.pm' => '$(INST_LIBDIR)/EV.pm', 369 'EV.pm' => '$(INST_LIB)/EV.pm',
298 'EV/EVAPI.h' => '$(INST_LIBDIR)/EV/EVAPI.h', 370 'EV/EVAPI.h' => '$(INST_LIB)/EV/EVAPI.h',
299 'EV/MakeMaker.pm' => '$(INST_LIBDIR)/EV/MakeMaker.pm', 371 'EV/MakeMaker.pm' => '$(INST_LIB)/EV/MakeMaker.pm',
300 'libev/ev.h' => '$(INST_LIBDIR)/EV/ev.h', 372 'libev/ev.h' => '$(INST_LIB)/EV/ev.h',
301 'libev/ev.pod' => '$(INST_LIBDIR)/EV/libev.pod', 373 'libev/ev.pod' => '$(INST_LIB)/EV/libev.pod',
302 }, 374 },
303 MAN3PODS => { 375 MAN3PODS => {
304 'EV.pm' => '$(INST_MAN3DIR)/EV.$(MAN3EXT)', 376 'EV.pm' => '$(INST_MAN3DIR)/EV.$(MAN3EXT)',
305 'EV/MakeMaker.pm' => '$(INST_MAN3DIR)/EV::MakeMaker.$(MAN3EXT)', 377 'EV/MakeMaker.pm' => '$(INST_MAN3DIR)/EV::MakeMaker.$(MAN3EXT)',
306 'libev/ev.pod' => '$(INST_MAN3DIR)/EV::libev.$(MAN3EXT)', 378 'libev/ev.pod' => '$(INST_MAN3DIR)/EV::libev.$(MAN3EXT)',
307 }, 379 },
308); 380);
309 381
310

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines