ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/EV/Makefile.PL
Revision: 1.26
Committed: Wed Nov 28 17:57:54 2007 UTC (16 years, 5 months ago) by root
Content type: text/plain
Branch: MAIN
CVS Tags: rel-1_5
Changes since 1.25: +3 -3 lines
Log Message:
*** empty log message ***

File Contents

# User Rev Content
1 root 1.4 use 5.006;
2    
3 root 1.7 use Config;
4 root 1.1 use ExtUtils::MakeMaker;
5    
6 root 1.10 unless (-e "libev/ev_epoll.c") {
7     print <<EOF;
8    
9     ***
10     *** ERROR: libev is missing or damaged. If you used a CVS check-out of EV,
11     *** you also have to check-out the "libev" module from the same CVS
12     *** repository into the EV dir (i.e. EV/libev from outside).
13     ***
14    
15     EOF
16     exit 1;
17     }
18    
19 root 1.11 print <<EOF;
20    
21 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
22 root 1.11
23    
24     Welcome to EV configuration. If you are in a hurry, just press return here
25     and hope for the best. The defaults should usually do.
26    
27     EOF
28    
29     if (prompt ("Skip further questions and use defaults (y/n)?", "y") =~ /[yY]/) {
30     $ENV{PERL_MM_USE_DEFAULT} = 1;
31     }
32    
33     print <<EOF;
34    
35 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
36 root 1.11
37    
38 root 1.14 POSIX optionally offers support for a monotonic clock source. EV
39     can take advantage of this clock source to detect time jumps
40     reliably. Unfortunately, some systems are bound to be broken, so you can
41     disable this here: you can completely disable the detection and use of
42     the monotonic clock by answering 'n' here. Support for this clock type
43     will otherwise be autodetected at both compile- and runtime.
44 root 1.11
45     EOF
46    
47 root 1.22 $DEFINE .= " -DEV_USE_MONOTONIC=" . (0 + (prompt ("Enable optional support for CLOCK_MONOTONIC (y/n)?", "y") =~ /[yY]/));
48 root 1.11
49     print <<EOF;
50    
51 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
52 root 1.11
53    
54     POSIX optionally offers support for a (potentially) high-resolution
55     realtime clock interface. In a good implementation, using it is faster
56     than the normal method of using gettimeofday. Unfortunately, this option
57     is also bound to be broken on some systems, so you can disable use and
58     probing of this feature altogether here. Otherwise support for this clock
59     type will be autodetected at compiletime.
60    
61     EOF
62    
63 root 1.22 $DEFINE .= " -DEV_USE_REALTIME=" . (0 + (prompt ("Prefer clock_gettime (CLOCK_REALTIME) over gettimeofday (y/n)?", "y") =~ /[yY]/));
64 root 1.11
65     print <<EOF;
66    
67 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
68 root 1.11
69    
70 root 1.19 EV can use various backends with various portability issue. The select
71     backend is the most portable and makes for a good fallback, but it can be
72 root 1.22 limited to a low number of file descriptors and/or might not compile. If
73     you have problems with compiling ev_select.c, you might try to play around
74 root 1.19 with disabling it here, or forcing it to use the fd_set provided by your
75     OS, via the next question. I highly recommend keeping it in.
76    
77     EOF
78    
79     if (prompt ("Enable select backend (y/n)?", "y") =~ /[yY]/) {
80 root 1.22 $DEFINE .= " -DEV_USE_SELECT=1";
81 root 1.19
82     print <<EOF;
83    
84 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
85 root 1.19
86    
87     The select backend can operate in two modes. One uses the system-provided
88     fd_set and is usually limited to 1024 file descriptors (64 on windows),
89     the other requires your header files to define NFDBITS and declare a
90     suitable fd_mask type. If you run into problems compiling ev_select.c, you
91     can try forcing the use of the system fd_set here.
92    
93     EOF
94    
95     if (prompt ("Force use of system fd_set for select backend (y/n)?", "n") =~ /[yY]/) {
96     $DEFINE .= " -DEV_SELECT_USE_FD_SET";
97     }
98 root 1.22 } else {
99     $DEFINE .= " -DEV_USE_SELECT=0";
100 root 1.19 }
101    
102     print <<EOF;
103    
104 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
105 root 1.19
106    
107     The second very portable backend is poll(2). It does not exist on windows
108     and various versions of Mac OS X (and on the other versions it simply
109     doesn't work), but works basically everywhere else. It is recommended to use
110     the default here unless you run into compile problems in ev_poll.c.
111    
112     EOF
113    
114 root 1.22 $DEFINE .= " -DEV_USE_POLL=" . (0 + (prompt ("Enable poll backend (y/n)?", (-e "/usr/include/poll.h") ? "y" : "n") =~ /[yY]/));
115 root 1.19
116     print <<EOF;
117    
118 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
119 root 1.19
120    
121 root 1.24 Select and poll make it hard to write efficient servers, especially if the
122     number of active connections is much lower than the watched ones. GNU/Linux
123     systems have a more scalable method called "epoll", which EV can use. For
124     this to work, both your kernel and glibc have to support epoll, but if you
125     can compile it, the detection will be done at runtime, and EV will safely
126     fall back to using select when epoll isn't available. If unsure, accept
127     the default.
128 root 1.11
129     EOF
130    
131 root 1.22 $DEFINE .= " -DEV_USE_EPOLL=" . (0 + (prompt ("Enable epoll backend (y/n)?", (-e "/usr/include/sys/epoll.h") ? "y" : "n") =~ /[yY]/));
132 root 1.15
133     print <<EOF;
134    
135 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
136 root 1.15
137    
138 root 1.23 Similarly to the epoll backend above, EV can take advantage of kqueue on
139     many BSD systems. Support for kqueue will be detected at runtime, with a
140     safe fallback to other methods when it cannot be used.
141    
142     Note that kqueue is broken on most operating systems, so it defaults to
143 root 1.24 'n' on everything but netbsd. Here is what we know:
144 root 1.23
145 root 1.24 NetBSD: working in at least 3.1. Yeah! :)
146     FreeBSD: broken on at least 6.2-STABLE,
147 root 1.23 sockets and pipes *might* work, ptys definitely don't.
148     OpenBSD: reports indicate that it likely doesn't work
149     (similar problems as on FreeBSD).
150 root 1.24 OS X: completely, utterly broken on at least <= 10.5.
151 root 1.11
152 root 1.15 EOF
153    
154 root 1.23 my $can_kqueue = $^O =~ /netbsd/i && -e "/usr/include/sys/event.h";
155    
156     $DEFINE .= " -DEV_USE_KQUEUE=" . (0 + (prompt ("Enable kqueue backend (y/n)?", $can_kqueue ? "y" : "n") =~ /[yY]/));
157 root 1.11
158     print <<EOF;
159    
160 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
161 root 1.11
162    
163 root 1.21 Similarly to the kqueue backend above, EV can take advantage of the
164 root 1.26 solaris 10 event port interface. Support for event ports will be detected
165     at runtime, with a safe fallback to other methods when it cannot be used.
166 root 1.21
167     EOF
168    
169 root 1.26 $DEFINE .= " -DEV_USE_PORT=" . (0 + (prompt ("Enable event port backend (y/n)?", (-e "/usr/include/sys/port.h") ? "y" : "n") =~ /[yY]/));
170 root 1.21
171     print <<EOF;
172    
173 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
174 root 1.21
175    
176 root 1.11 EV needs the functions pthread_atfork and clock_gettime. On most systems
177 root 1.15 you need some special libraries for this (such as -lrt and -lpthread). You
178 root 1.23 can specify additional libraries to provide these calls (and any other
179     required by EV) now, or accept the default.
180 root 1.11
181     EOF
182    
183 root 1.23 $SOLARIS_LIBS = $^O =~ /solaris/ ? " -lsocket -lnsl" : "";
184    
185     $LIBS = prompt "Extra libraries for pthread_atfork and clock_gettime?", "-lpthread -lrt$SOLARIS_LIBS";
186 root 1.15
187 root 1.11
188     print <<EOF;
189    
190 root 1.22 *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
191 root 1.11
192    
193 root 1.25 A backend of a different kind is the Linux inotify(7) interface, which can
194     be used to speed up (and reduce resource consumption) of stat watchers. If
195     you have it, it is usually a good idea to enable it.
196    
197     EOF
198    
199     my $can_inotify = -e "/usr/include/sys/inotify.h";
200    
201     $DEFINE .= " -DEV_USE_INOTIFY=" . (0 + (prompt ("Enable inotify support (y/n)?", $can_inotify ? "y" : "n") =~ /[yY]/));
202    
203     print <<EOF;
204    
205     *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** *** ***
206    
207    
208 root 1.11 EOF
209    
210 root 1.20 my @anyevent = eval { require AnyEvent; $AnyEvent::VERSION < 2.6 } ? (AnyEvent => 2.6) : ();
211    
212 root 1.1 WriteMakefile(
213     dist => {
214 root 1.2 PREOP => 'pod2text EV.pm | tee README >$(DISTVNAME)/README; chmod -R u=rwX,go=rX . ;',
215 root 1.1 COMPRESS => 'gzip -9v',
216     SUFFIX => '.gz',
217     },
218 root 1.10 depend => {
219 root 1.13 "EV.c" => "EV/EVAPI.h "
220 root 1.17 . "libev/ev.c libev/ev.h libev/ev_epoll.c libev/ev_select.c libev/ev_kqueue.c libev/ev_poll.c "
221 root 1.18 . "libev/event.h libev/event.c evdns.h evdns.c libev/ev_vars.h libev/ev_wrap.h",
222 root 1.10 },
223 root 1.8 INC => "-Ilibev",
224 root 1.11 DEFINE => "$DEFINE",
225 root 1.2 NAME => "EV",
226 root 1.11 LIBS => [$LIBS],
227 root 1.20 PREREQ_PM => {
228     @anyevent,
229     },
230 root 1.2 VERSION_FROM => "EV.pm",
231 root 1.5 PM => {
232     'EV.pm' => '$(INST_LIBDIR)/EV.pm',
233 root 1.12 'EV/DNS.pm' => '$(INST_LIBDIR)/EV/DNS.pm',
234 root 1.5 'EV/EVAPI.h' => '$(INST_LIBDIR)/EV/EVAPI.h',
235     'EV/MakeMaker.pm' => '$(INST_LIBDIR)/EV/MakeMaker.pm',
236 root 1.8 'libev/ev.h' => '$(INST_LIBDIR)/EV/ev.h',
237 root 1.5 },
238 root 1.1 );
239    
240 root 1.6