ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/Net-SNMP-EV/EV.pm
Revision: 1.4
Committed: Fri Apr 10 06:49:34 2009 UTC (15 years, 5 months ago) by root
Branch: MAIN
CVS Tags: rel-0_12, HEAD
Changes since 1.3: +1 -1 lines
Log Message:
0.12

File Contents

# User Rev Content
1 root 1.1 =head1 NAME
2    
3     Net::SNMP::EV - adaptor to integrate Net::SNMP into the EV event loop.
4    
5     =head1 SYNOPSIS
6    
7     use EV;
8     use Net::SNMP;
9     use Net::SNMP::EV;
10    
11     # just use Net::SNMP and EV as you like:
12    
13     ... start non-blocking snmp request(s)...
14    
15     EV::loop;
16    
17     =head1 DESCRIPTION
18    
19     This module coerces the Net::SNMP scheduler to use the EV high performance
20     event loop as underlying event loop, i.e. EV will be used by Net::SNMP for
21     all events.
22    
23     This integrates Net::SNMP into EV: You can make non-blocking Net::SNMP
24     calls and as long as your main program uses the EV event loop, they will
25     run in parallel to anything else that uses EV or AnyEvent.
26    
27     This module does not export anything and does not require you to do
28     anything special apart from loading it.
29    
30 root 1.2 The module is quite short, you can use it as example to implement a
31     similar integration into e.g. Event or other event loops.
32 root 1.1
33     =cut
34    
35     package Net::SNMP::EV;
36    
37     no warnings;
38     use strict;
39    
40     use Net::SNMP ();
41     use EV ();
42    
43 root 1.4 our $VERSION = '0.12';
44 root 1.1
45     our @W;
46     our $DISPATCHER = $Net::SNMP::DISPATCHER;
47    
48     # handle as many snmp events as possible
49     sub drain {
50     while () {
51     $DISPATCHER->one_event;
52    
53     my $next = $DISPATCHER->{_event_queue_h}
54     or return;
55    
56     return $next
57     if !$next->[Net::SNMP::Dispatcher::_ACTIVE]
58     || $next->[Net::SNMP::Dispatcher::_TIME] > EV::now;
59     }
60     }
61    
62     our $PREPARE = EV::prepare sub {
63     # has any events?
64     if ($DISPATCHER->{_event_queue_h}) {
65     # do some work
66     my $next = drain
67     or return;
68    
69     # register io watchers for all fds and a single timout
70     @W = (
71     (map { EV::io $_, EV::READ, sub { } }
72     keys %{ $DISPATCHER->{_descriptors} }),
73    
74     (EV::timer +($next->[Net::SNMP::Dispatcher::_ACTIVE]
75     ? $next->[Net::SNMP::Dispatcher::_TIME] - EV::now
76     : 0),
77     0, sub { }),
78     );
79     }
80     };
81    
82     our $CHECK = EV::check sub {
83     # nuke the watchers again (usually their callbacks will not even be called)
84     @W = ();
85    
86     drain
87     if $DISPATCHER->{_event_queue_h};
88     };
89    
90     =head1 BUGS
91    
92     Net::SNMP has no (documented or otherwise) API to do what this module
93     does. As such, this module rummages around in the internals of Net::SNMP
94     in a rather inacceptable way, and as thus might be very sensitive to the
95     version of Net::SNMP used (it has been tested with some 5.x versions
96     only, YMMV).
97    
98     =head1 SEE ALSO
99    
100     L<EV>, L<Net::SNMP>, L<AnyEvent>, L<Glib::EV>.
101    
102     =head1 AUTHOR
103    
104     Marc Lehmann <schmorp@schmorp.de>
105     http://home.schmorp.de/
106    
107     =cut
108    
109     1
110