Skip to content
This repository

HTTPS clone URL

Subversion checkout URL

You can clone with HTTPS or Subversion.

Download ZIP
Fetching contributors…

Octocat-spinner-32-eaf2f5

Cannot retrieve contributors at this time

file 81 lines (63 sloc) 1.956 kb
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80
#!/usr/bin/perl

use warnings;
use strict;
use vars qw($NUM_OF_EVENTS $USE_EVENT $USE_IO_POLL);

use Time::HiRes qw(gettimeofday tv_interval);

sub die_usage {
    my $usage = "\n";
    if(my $msg = shift) {
        $usage .= "ERROR: $msg\n\n";
    }
    $usage .= <<EOU;
Usage: $0 < --events=NUM > < --use-event > < --use-io-poll >
Options:
--help : this help text
--events=NUM : the number of events to run. defaults to 10000
--use-event : use Event.pm's internal event loop
--use-io-poll : use IO::Poll.pm's internal event loop

if --use-event or --use-io-poll are not chosen, POE's native event loop
will be used.
EOU
    my_die($usage);
}

sub my_die ($) {
    print STDERR $_[0]."\n";
    exit 1;
}

sub late_use ($) {
    my $module = shift;
    eval "use $module;";
    my_die($@) if ($@);
}

BEGIN {
    use Getopt::Long;
    $USE_EVENT = 0;
    $USE_IO_POLL = 0;
    my $help = 0;

    $NUM_OF_EVENTS = 10000;
    
    GetOptions( 'events=i' => \$NUM_OF_EVENTS,
                'use-event+' => \$USE_EVENT,
                'use-io-poll+' => \$USE_IO_POLL,
                'help+' => \$help,
                );
    die_usage() if $help;
    die_usage('Both use-event and use-io-poll are selected. Only one loop type may be chosen.') if($USE_EVENT + $USE_IO_POLL > 1);

    if($USE_EVENT) {
        late_use('Event');
    } elsif ($USE_IO_POLL) {
        late_use('IO::Poll');
    }

    late_use('POE');
}


my($tr_start, $tr_stop);
POE::Session->create(
    inline_states => {
        _start => sub { $tr_start = [gettimeofday]; $_[KERNEL]->yield('iterate', 0) },
        _stop => sub { $tr_stop = [gettimeofday] },

        iterate => sub { $_[KERNEL]->yield('iterate', ++$_[ARG0]) unless $_[ARG0] > $NUM_OF_EVENTS; }
    }
);

$POE::Kernel::poe_kernel->run();

my $elapsed = tv_interval($tr_start, $tr_stop);
my $event_avg = int($NUM_OF_EVENTS/$elapsed);
print "Events per second: $event_avg\n";

Something went wrong with that request. Please try again.