1 |
root |
1.1 |
BEGIN { $| = 1; print "1..3002\n"; } |
2 |
|
|
|
3 |
|
|
use EV; |
4 |
|
|
|
5 |
|
|
my $id = 1; |
6 |
|
|
my @timer; |
7 |
|
|
|
8 |
|
|
my $base = EV::now; |
9 |
|
|
my $prev = EV::now; |
10 |
|
|
|
11 |
|
|
for (1..1000) { |
12 |
|
|
my $t = $_ * $_ * 1.735435336; $t -= int $t; |
13 |
|
|
push @timer, EV::timer $t, 0, sub { |
14 |
root |
1.2 |
print EV::now >= $prev ? "" : "not ", "ok ", ++$id, " # a ", EV::now, " >= ", $prev, "\n"; |
15 |
|
|
print EV::now >= $base + $t ? "" : "not ", "ok ", ++$id, " # b ", EV::now, " >= ", $base + $t, "\n"; |
16 |
|
|
|
17 |
|
|
$prev = EV::now; |
18 |
root |
1.1 |
|
19 |
|
|
unless ($id % 3) { |
20 |
|
|
$_[0]->set ($t * 0.0625); |
21 |
|
|
$t *= 1.0625; |
22 |
|
|
$_[0]->start; |
23 |
|
|
} |
24 |
|
|
}; |
25 |
|
|
} |
26 |
|
|
|
27 |
|
|
print "ok 1\n"; |
28 |
|
|
EV::loop; |
29 |
|
|
print "ok 3002\n"; |
30 |
|
|
|