ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/EV/EV/MakeMaker.pm
Revision: 1.7
Committed: Mon Apr 7 13:27:55 2008 UTC (16 years, 1 month ago) by root
Branch: MAIN
Changes since 1.6: +1 -1 lines
Log Message:
*** empty log message ***

File Contents

# Content
1 package EV::MakeMaker;
2
3 BEGIN { eval { require warnings } && warnings->unimport ("uninitialized") }
4
5 use Config;
6 use base 'Exporter';
7
8 @EXPORT_OK = qw(&ev_args $installsitearch);
9
10 my %opt;
11
12 for my $opt (split /:+/, $ENV{PERL_MM_OPT}) {
13 my ($k,$v) = split /=/, $opt;
14 $opt{$k} = $v;
15 }
16
17 my $extra = $Config{sitearch};
18
19 $extra =~ s/$Config{prefix}/$opt{PREFIX}/ if
20 exists $opt{PREFIX};
21
22 for my $d ($extra, @INC) {
23 if (-e "$d/EV/EVAPI.h") {
24 $installsitearch = $d;
25 last;
26 }
27 }
28
29 sub ev_args {
30 my %arg = @_;
31 $arg{INC} .= " -I$installsitearch/EV -I$installsitearch";
32 %arg;
33 }
34
35 1;
36 __END__
37
38 =head1 NAME
39
40 EV::MakeMaker - MakeMaker glue for the C-level EV API
41
42 =head1 SYNOPSIS
43
44 This allows you to access some libevent functionality from other perl
45 modules.
46
47 =head1 DESCRIPTION
48
49 For optimal performance, hook into EV at the C-level. You'll need
50 to make changes to your C<Makefile.PL> and add code to your C<xs> /
51 C<c> file(s).
52
53 =head1 HOW TO
54
55 =head2 Makefile.PL
56
57 use EV::MakeMaker qw(ev_args);
58
59 # ... set up %args ...
60
61 WriteMakefile (ev_args (%args));
62
63 =head2 XS
64
65 #include "EVAPI.h"
66
67 BOOT:
68 I_EV_API ("YourModule");
69
70 =head1 API
71
72 See the L<EVAPI.h|http://cvs.schmorp.de/EV/EV/EVAPI.h> header.
73
74 In short, all the functions and macros from F<ev.h> should work, except
75 that the trailing underscore macros (C<EV_A_>, C<EV_DEFAULT_>) are not
76 available (except C<EV_P_> :).
77
78 Multiplicity is enabled.
79
80 The C<data> member in each watcher is of type C<SV *> and not C<void *>
81 (this might change at some point).
82
83 =head1 EXAMPLE
84
85 The L<EV::Glib>, L<EV::ADNS> and L<Glib::EV> all give nice examples on how
86 to use this module.
87
88 Here are some F<.xs> fragments taken from EV::ADNS that should get you
89 going:
90
91 #include "EVAPI.h"
92
93 static ev_prepare pw;
94 static ev_idle iw;
95
96 static void
97 idle_cb (EV_P_ ev_idle *w, int revents)
98 {
99 ev_idle_stop (EV_A, w);
100 }
101
102 MODULE = ...
103
104 BOOT:
105 {
106 I_EV_API ("EV::ADNS");
107 ev_prepare_init (&pw, prepare_cb);
108 ev_init (&iw, idle_cb); ev_set_priority (&iw, EV_MINPRI);
109 ev_idle_start (EV_DEFAULT, &iw);
110 }
111
112 =cut
113