line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
=head1 NAME |
2
|
|
|
|
|
|
|
|
3
|
|
|
|
|
|
|
AnyEvent::IO - the DBI of asynchronous I/O implementations |
4
|
|
|
|
|
|
|
|
5
|
|
|
|
|
|
|
=head1 SYNOPSIS |
6
|
|
|
|
|
|
|
|
7
|
|
|
|
|
|
|
use AnyEvent::IO; |
8
|
|
|
|
|
|
|
|
9
|
|
|
|
|
|
|
# load /etc/passwd, call callback with the file data when done. |
10
|
|
|
|
|
|
|
aio_load "/etc/passwd", sub { |
11
|
|
|
|
|
|
|
my ($data) = @_ |
12
|
|
|
|
|
|
|
or return AE::log error => "/etc/passwd: $!"; |
13
|
|
|
|
|
|
|
|
14
|
|
|
|
|
|
|
warn "/etc/passwd contains ", ($data =~ y/://) , " colons.\n"; |
15
|
|
|
|
|
|
|
}; |
16
|
|
|
|
|
|
|
|
17
|
|
|
|
|
|
|
# the rest of the SYNOPSIS does the same, but with individual I/O calls |
18
|
|
|
|
|
|
|
|
19
|
|
|
|
|
|
|
# also import O_XXX flags |
20
|
|
|
|
|
|
|
use AnyEvent::IO qw(:DEFAULT :flags); |
21
|
|
|
|
|
|
|
|
22
|
|
|
|
|
|
|
my $filedata = AE::cv; |
23
|
|
|
|
|
|
|
|
24
|
|
|
|
|
|
|
# first open the file |
25
|
|
|
|
|
|
|
aio_open "/etc/passwd", O_RDONLY, 0, sub { |
26
|
|
|
|
|
|
|
my ($fh) = @_ |
27
|
|
|
|
|
|
|
or return AE::log error => "/etc/passwd: $!"; |
28
|
|
|
|
|
|
|
|
29
|
|
|
|
|
|
|
# now stat the file to get the size |
30
|
|
|
|
|
|
|
aio_stat $fh, sub { |
31
|
|
|
|
|
|
|
@_ |
32
|
|
|
|
|
|
|
or return AE::log error => "/etc/passwd: $!"; |
33
|
|
|
|
|
|
|
|
34
|
|
|
|
|
|
|
my $size = -s _; |
35
|
|
|
|
|
|
|
|
36
|
|
|
|
|
|
|
# now read all the file data |
37
|
|
|
|
|
|
|
aio_read $fh, $size, sub { |
38
|
|
|
|
|
|
|
my ($data) = @_ |
39
|
|
|
|
|
|
|
or return AE::log error => "/etc/passwd: $!"; |
40
|
|
|
|
|
|
|
|
41
|
|
|
|
|
|
|
$size == length $data |
42
|
|
|
|
|
|
|
or return AE::log error => "/etc/passwd: short read, file changed?"; |
43
|
|
|
|
|
|
|
|
44
|
|
|
|
|
|
|
# mostly the same as aio_load, above - $data contains |
45
|
|
|
|
|
|
|
# the file contents now. |
46
|
|
|
|
|
|
|
$filedata->($data); |
47
|
|
|
|
|
|
|
}; |
48
|
|
|
|
|
|
|
}; |
49
|
|
|
|
|
|
|
}; |
50
|
|
|
|
|
|
|
|
51
|
|
|
|
|
|
|
my $passwd = $filedata->recv; |
52
|
|
|
|
|
|
|
warn length $passwd, " octets.\n"; |
53
|
|
|
|
|
|
|
|
54
|
|
|
|
|
|
|
=head1 DESCRIPTION |
55
|
|
|
|
|
|
|
|
56
|
|
|
|
|
|
|
This module provides functions that do I/O in an asynchronous fashion. It |
57
|
|
|
|
|
|
|
is to I/O the same as L is to event libraries - it only |
58
|
|
|
|
|
|
|
I to other implementations or to a portable pure-perl |
59
|
|
|
|
|
|
|
implementation (which does not, however, do asynchronous I/O). |
60
|
|
|
|
|
|
|
|
61
|
|
|
|
|
|
|
The only other implementation that is supported (or even known to the |
62
|
|
|
|
|
|
|
author) is L, which is used automatically when it can be loaded |
63
|
|
|
|
|
|
|
(via L, which also needs to be installed). If it is not |
64
|
|
|
|
|
|
|
available, then L falls back to its synchronous pure-perl |
65
|
|
|
|
|
|
|
implementation. |
66
|
|
|
|
|
|
|
|
67
|
|
|
|
|
|
|
Unlike L, which model to use is currently decided at module load |
68
|
|
|
|
|
|
|
time, not at first use. Future releases might change this. |
69
|
|
|
|
|
|
|
|
70
|
|
|
|
|
|
|
=head2 RATIONALE |
71
|
|
|
|
|
|
|
|
72
|
|
|
|
|
|
|
While disk I/O often seems "instant" compared to, say, socket I/O, there |
73
|
|
|
|
|
|
|
are many situations where your program can block for extended time periods |
74
|
|
|
|
|
|
|
when doing disk I/O. For example, you access a disk on an NFS server and |
75
|
|
|
|
|
|
|
it is gone - can take ages to respond again, if ever. Or your system is |
76
|
|
|
|
|
|
|
extremely busy because it creates or restores a backup - reading data from |
77
|
|
|
|
|
|
|
disk can then take seconds. Or you use Linux, which for so many years has |
78
|
|
|
|
|
|
|
a close-to-broken VM/IO subsystem that can often induce minutes or more of |
79
|
|
|
|
|
|
|
delay for disk I/O, even under what I would consider light I/O loads. |
80
|
|
|
|
|
|
|
|
81
|
|
|
|
|
|
|
Whatever the situation, some programs just can't afford to block for long |
82
|
|
|
|
|
|
|
times (say, half a second or more), because they need to respond as fast |
83
|
|
|
|
|
|
|
as possible. |
84
|
|
|
|
|
|
|
|
85
|
|
|
|
|
|
|
For those cases, you need asynchronous I/O. |
86
|
|
|
|
|
|
|
|
87
|
|
|
|
|
|
|
The problem is, AnyEvent itself sometimes reads disk files (for example, |
88
|
|
|
|
|
|
|
when looking at F), and under the above situations, this can |
89
|
|
|
|
|
|
|
bring your program to a complete halt even if your program otherwise |
90
|
|
|
|
|
|
|
takes care to only use asynchronous I/O for everything (e.g. by using |
91
|
|
|
|
|
|
|
L). |
92
|
|
|
|
|
|
|
|
93
|
|
|
|
|
|
|
On the other hand, requiring L for AnyEvent is clearly |
94
|
|
|
|
|
|
|
impossible, as AnyEvent promises to stay pure-perl, and the overhead of |
95
|
|
|
|
|
|
|
IO::AIO for small programs would be immense, especially when asynchronous |
96
|
|
|
|
|
|
|
I/O isn't even needed. |
97
|
|
|
|
|
|
|
|
98
|
|
|
|
|
|
|
Clearly, this calls for an abstraction layer, and that is what you are |
99
|
|
|
|
|
|
|
looking at right now :-) |
100
|
|
|
|
|
|
|
|
101
|
|
|
|
|
|
|
=head2 ASYNCHRONOUS VS. NON-BLOCKING |
102
|
|
|
|
|
|
|
|
103
|
|
|
|
|
|
|
Many people are continuously confused on what the difference is between |
104
|
|
|
|
|
|
|
asynchronous I/O and non-blocking I/O. In fact, those two terms are |
105
|
|
|
|
|
|
|
not well defined, which often makes it hard to even talk about the |
106
|
|
|
|
|
|
|
difference. Here is a short guideline that should leave you less |
107
|
|
|
|
|
|
|
confused. It only talks about read operations, but the reasoning works |
108
|
|
|
|
|
|
|
with other I/O operations as well. |
109
|
|
|
|
|
|
|
|
110
|
|
|
|
|
|
|
Non-blocking I/O means that data is delivered by some external means, |
111
|
|
|
|
|
|
|
automatically - that is, something I data towards your file |
112
|
|
|
|
|
|
|
handle, without you having to do anything. Non-blocking means that if |
113
|
|
|
|
|
|
|
your operating system currently has no data (or EOF, or some error) |
114
|
|
|
|
|
|
|
available for you, it will not wait ("block") as it would normally do, |
115
|
|
|
|
|
|
|
but immediately return with an error (e.g. C - "I would have |
116
|
|
|
|
|
|
|
blocked, but you forbid it"). |
117
|
|
|
|
|
|
|
|
118
|
|
|
|
|
|
|
Your program can then wait for data to arrive by other means, for example, |
119
|
|
|
|
|
|
|
an I/O watcher which tells you when to re-attempt the read, after which it |
120
|
|
|
|
|
|
|
can try to read again, and so on. |
121
|
|
|
|
|
|
|
|
122
|
|
|
|
|
|
|
Often, you would expect this to work for disk files as well - if the data |
123
|
|
|
|
|
|
|
isn't already in memory, one might want to wait for it and then re-attempt |
124
|
|
|
|
|
|
|
the read for example. While this is sound reasoning, the POSIX API does |
125
|
|
|
|
|
|
|
not support this, because disk drives and file systems do not send data |
126
|
|
|
|
|
|
|
"on their own", and more so, the OS already knows that data is there, it |
127
|
|
|
|
|
|
|
doesn't need to "wait" until it arrives from some external entity, it only |
128
|
|
|
|
|
|
|
needs to transfer the data from disk to your memory buffer. |
129
|
|
|
|
|
|
|
|
130
|
|
|
|
|
|
|
So basically, while the concept is sound, the existing OS APIs do not |
131
|
|
|
|
|
|
|
support this. Therefore, it makes no sense to switch a disk file handle |
132
|
|
|
|
|
|
|
into non-blocking mode - it will behave exactly the same as in blocking |
133
|
|
|
|
|
|
|
mode, namely it will block until the data has been read from the disk. |
134
|
|
|
|
|
|
|
|
135
|
|
|
|
|
|
|
The alternative to non-blocking I/O that actually works with disk files |
136
|
|
|
|
|
|
|
is usually called I. Asynchronous, because the actual |
137
|
|
|
|
|
|
|
I/O is done while your program does something else: there is no need to |
138
|
|
|
|
|
|
|
call the read function to see if data is there, you only order the read |
139
|
|
|
|
|
|
|
once, and it will notify you when the read has finished and the data is |
140
|
|
|
|
|
|
|
your buffer - all the work is done in the background. |
141
|
|
|
|
|
|
|
|
142
|
|
|
|
|
|
|
This works with disk files, and even with sockets and other sources. It |
143
|
|
|
|
|
|
|
is, however, not very efficient when used with sources that could be |
144
|
|
|
|
|
|
|
driven in a non-blocking way, because it usually has higher overhead |
145
|
|
|
|
|
|
|
in the OS than non-blocking I/O, because it ties memory buffers for a |
146
|
|
|
|
|
|
|
potentially unlimited time and often only a limited number of operations |
147
|
|
|
|
|
|
|
can be done in parallel. |
148
|
|
|
|
|
|
|
|
149
|
|
|
|
|
|
|
That's why asynchronous I/O makes most sense when confronted with disk |
150
|
|
|
|
|
|
|
files, and non-blocking I/O only makes sense with sockets, pipes and |
151
|
|
|
|
|
|
|
similar streaming sources. |
152
|
|
|
|
|
|
|
|
153
|
|
|
|
|
|
|
=head1 IMPORT TAGS |
154
|
|
|
|
|
|
|
|
155
|
|
|
|
|
|
|
By default, this module exports all Cxxx functions. In addition, |
156
|
|
|
|
|
|
|
the following import tags can be used: |
157
|
|
|
|
|
|
|
|
158
|
|
|
|
|
|
|
:aio all aio_* functions, same as :DEFAULT |
159
|
|
|
|
|
|
|
:flags the fcntl open flags (O_CREAT, O_RDONLY, ...) |
160
|
|
|
|
|
|
|
|
161
|
|
|
|
|
|
|
=head1 API NOTES |
162
|
|
|
|
|
|
|
|
163
|
|
|
|
|
|
|
The functions in this module are not meant to be the most versatile or |
164
|
|
|
|
|
|
|
the highest-performers (they are not very slow either, of course). They |
165
|
|
|
|
|
|
|
are primarily meant to give users of your code the option to do the I/O |
166
|
|
|
|
|
|
|
asynchronously (by installing L and L), |
167
|
|
|
|
|
|
|
without adding a dependency on those modules. |
168
|
|
|
|
|
|
|
|
169
|
|
|
|
|
|
|
=head2 NAMING |
170
|
|
|
|
|
|
|
|
171
|
|
|
|
|
|
|
All the functions in this module implement an I/O operation, usually with |
172
|
|
|
|
|
|
|
the same or similar name as the Perl built-in that they mimic, but with |
173
|
|
|
|
|
|
|
an C prefix. If you like you can think of the Cxxx functions as |
174
|
|
|
|
|
|
|
"AnyEvent I/O" or "Asynchronous I/O" variants of Perl built-ins. |
175
|
|
|
|
|
|
|
|
176
|
|
|
|
|
|
|
=head2 CALLING CONVENTIONS AND ERROR REPORTING |
177
|
|
|
|
|
|
|
|
178
|
|
|
|
|
|
|
Each function expects a callback as their last argument. The callback is |
179
|
|
|
|
|
|
|
usually called with the result data or result code. An error is usually |
180
|
|
|
|
|
|
|
signalled by passing no arguments to the callback, which is then free to |
181
|
|
|
|
|
|
|
look at C<$!> for the error code. |
182
|
|
|
|
|
|
|
|
183
|
|
|
|
|
|
|
This makes all of the following forms of error checking valid: |
184
|
|
|
|
|
|
|
|
185
|
|
|
|
|
|
|
aio_open ...., sub { |
186
|
|
|
|
|
|
|
my $fh = shift # scalar assignment - will assign undef on error |
187
|
|
|
|
|
|
|
or return AE::log error => "..."; |
188
|
|
|
|
|
|
|
|
189
|
|
|
|
|
|
|
my ($fh) = @_ # list assignment - will be 0 elements on error |
190
|
|
|
|
|
|
|
or return AE::log error => "..."; |
191
|
|
|
|
|
|
|
|
192
|
|
|
|
|
|
|
@_ # check the number of elements directly |
193
|
|
|
|
|
|
|
or return AE::log error => "..."; |
194
|
|
|
|
|
|
|
|
195
|
|
|
|
|
|
|
=head2 CAVEAT: RELATIVE PATHS |
196
|
|
|
|
|
|
|
|
197
|
|
|
|
|
|
|
When a path is specified, this path I path, unless |
198
|
|
|
|
|
|
|
you make certain that nothing in your process calls C or an |
199
|
|
|
|
|
|
|
equivalent function while the request executes. |
200
|
|
|
|
|
|
|
|
201
|
|
|
|
|
|
|
=head2 CAVEAT: OTHER SHARED STATE |
202
|
|
|
|
|
|
|
|
203
|
|
|
|
|
|
|
Changing the C while any requests execute that create files (or |
204
|
|
|
|
|
|
|
otherwise rely on the current umask) results in undefined behaviour - |
205
|
|
|
|
|
|
|
likewise changing anything else that would change the outcome, such as |
206
|
|
|
|
|
|
|
your effective user or group ID. |
207
|
|
|
|
|
|
|
|
208
|
|
|
|
|
|
|
=head2 CALLBACKS MIGHT BE CALLED BEFORE FUNCTION RETURNS TO CALLER |
209
|
|
|
|
|
|
|
|
210
|
|
|
|
|
|
|
Unlike other functions in the AnyEvent module family, these functions |
211
|
|
|
|
|
|
|
I call your callback instantly, before returning. This should not be |
212
|
|
|
|
|
|
|
a real problem, as these functions never return anything useful. |
213
|
|
|
|
|
|
|
|
214
|
|
|
|
|
|
|
=head2 BEHAVIOUR AT PROGRAM EXIT |
215
|
|
|
|
|
|
|
|
216
|
|
|
|
|
|
|
Both L and L implementations |
217
|
|
|
|
|
|
|
make sure that operations that have started will be finished on a clean |
218
|
|
|
|
|
|
|
programs exit. That makes programs work that start some I/O operations and |
219
|
|
|
|
|
|
|
then exit. For example this complete program: |
220
|
|
|
|
|
|
|
|
221
|
|
|
|
|
|
|
use AnyEvent::IO; |
222
|
|
|
|
|
|
|
|
223
|
|
|
|
|
|
|
aio_stat "path1", sub { |
224
|
|
|
|
|
|
|
aio_stat "path2", sub { |
225
|
|
|
|
|
|
|
warn "both stats done\n"; |
226
|
|
|
|
|
|
|
}; |
227
|
|
|
|
|
|
|
}; |
228
|
|
|
|
|
|
|
|
229
|
|
|
|
|
|
|
Starts a C operation and then exits by "falling off the end" of |
230
|
|
|
|
|
|
|
the program. Nevertheless, I C operations will be executed, |
231
|
|
|
|
|
|
|
as AnyEvent::IO waits for all outstanding requests to finish and you can |
232
|
|
|
|
|
|
|
start new requests from request callbacks. |
233
|
|
|
|
|
|
|
|
234
|
|
|
|
|
|
|
In fact, since L is currently synchronous, the |
235
|
|
|
|
|
|
|
program will do both stats before falling off the end, but with |
236
|
|
|
|
|
|
|
L, the program first falls of the end, then the stats |
237
|
|
|
|
|
|
|
are executed. |
238
|
|
|
|
|
|
|
|
239
|
|
|
|
|
|
|
While not guaranteed, this behaviour will be present in future versions, |
240
|
|
|
|
|
|
|
if reasonably possible (which is extreemly likely :). |
241
|
|
|
|
|
|
|
|
242
|
|
|
|
|
|
|
=cut |
243
|
|
|
|
|
|
|
|
244
|
|
|
|
|
|
|
package AnyEvent::IO; |
245
|
|
|
|
|
|
|
|
246
|
4
|
|
|
4
|
|
1506
|
use AnyEvent (); BEGIN { AnyEvent::common_sense } |
|
4
|
|
|
4
|
|
10
|
|
|
4
|
|
|
|
|
103
|
|
|
4
|
|
|
|
|
19
|
|
247
|
|
|
|
|
|
|
|
248
|
4
|
|
|
4
|
|
20
|
use base "Exporter"; |
|
4
|
|
|
|
|
8
|
|
|
4
|
|
|
|
|
2051
|
|
249
|
|
|
|
|
|
|
|
250
|
|
|
|
|
|
|
our @AIO_REQ = qw( |
251
|
|
|
|
|
|
|
aio_load aio_open aio_close aio_seek aio_read aio_write aio_truncate |
252
|
|
|
|
|
|
|
aio_utime aio_chown aio_chmod aio_stat aio_lstat |
253
|
|
|
|
|
|
|
aio_link aio_symlink aio_readlink aio_rename aio_unlink |
254
|
|
|
|
|
|
|
aio_mkdir aio_rmdir aio_readdir |
255
|
|
|
|
|
|
|
); |
256
|
|
|
|
|
|
|
*EXPORT = \@AIO_REQ; |
257
|
|
|
|
|
|
|
our @FLAGS = qw(O_RDONLY O_WRONLY O_RDWR O_CREAT O_EXCL O_TRUNC O_APPEND); |
258
|
|
|
|
|
|
|
*EXPORT_OK = \@FLAGS; |
259
|
|
|
|
|
|
|
our %EXPORT_TAGS = (flags => \@FLAGS, aio => \@AIO_REQ); |
260
|
|
|
|
|
|
|
|
261
|
|
|
|
|
|
|
our $MODEL; |
262
|
|
|
|
|
|
|
|
263
|
|
|
|
|
|
|
if ($MODEL) { |
264
|
|
|
|
|
|
|
AE::log 7 => "Found preloaded IO model '$MODEL', using it."; |
265
|
|
|
|
|
|
|
} else { |
266
|
|
|
|
|
|
|
if ($ENV{PERL_ANYEVENT_IO_MODEL} =~ /^([a-zA-Z0-9:]+)$/) { |
267
|
|
|
|
|
|
|
if (eval { require "AnyEvent/IO/$ENV{PERL_ANYEVENT_IO_MODEL}.pm" }) { |
268
|
|
|
|
|
|
|
AE::log 7 => "Loaded IO model '$MODEL' (forced by \$ENV{PERL_ANYEVENT_IO_MODEL}), using it."; |
269
|
|
|
|
|
|
|
} else { |
270
|
|
|
|
|
|
|
undef $MODEL; |
271
|
|
|
|
|
|
|
AE::log 4 => "Unable to load IO model '$ENV{PERL_ANYEVENT_IO_MODEL}' (from \$ENV{PERL_ANYEVENT_IO_MODEL}):\n$@"; |
272
|
|
|
|
|
|
|
} |
273
|
|
|
|
|
|
|
} |
274
|
|
|
|
|
|
|
|
275
|
|
|
|
|
|
|
unless ($MODEL) { |
276
|
|
|
|
|
|
|
if (eval { require IO::AIO; require AnyEvent::AIO; require AnyEvent::IO::IOAIO }) { |
277
|
|
|
|
|
|
|
AE::log 7 => "Autoloaded IO model 'IOAIO', using it."; |
278
|
|
|
|
|
|
|
} else { |
279
|
|
|
|
|
|
|
require AnyEvent::IO::Perl; |
280
|
|
|
|
|
|
|
AE::log 7 => "Autoloaded IO model 'Perl', using it."; |
281
|
|
|
|
|
|
|
} |
282
|
|
|
|
|
|
|
} |
283
|
|
|
|
|
|
|
} |
284
|
|
|
|
|
|
|
|
285
|
|
|
|
|
|
|
=head1 GLOBAL VARIABLES AND FUNCTIONS |
286
|
|
|
|
|
|
|
|
287
|
|
|
|
|
|
|
=over 4 |
288
|
|
|
|
|
|
|
|
289
|
|
|
|
|
|
|
=item $AnyEvent::IO::MODEL |
290
|
|
|
|
|
|
|
|
291
|
|
|
|
|
|
|
Contains the package name of the backend I/O model in use - at the moment, |
292
|
|
|
|
|
|
|
this is usually C or C. |
293
|
|
|
|
|
|
|
|
294
|
|
|
|
|
|
|
=item aio_load $path, $cb->($data) |
295
|
|
|
|
|
|
|
|
296
|
|
|
|
|
|
|
Tries to open C<$path> and read its contents into memory (obviously, |
297
|
|
|
|
|
|
|
should only be used on files that are "small enough"), then passes them to |
298
|
|
|
|
|
|
|
the callback as a string. |
299
|
|
|
|
|
|
|
|
300
|
|
|
|
|
|
|
Example: load F. |
301
|
|
|
|
|
|
|
|
302
|
|
|
|
|
|
|
aio_load "/etc/hosts", sub { |
303
|
|
|
|
|
|
|
my ($hosts) = @_ |
304
|
|
|
|
|
|
|
or return AE::log error => "/etc/hosts: $!"; |
305
|
|
|
|
|
|
|
|
306
|
|
|
|
|
|
|
AE::log info => "/etc/hosts contains ", ($hosts =~ y/\n/), " lines\n"; |
307
|
|
|
|
|
|
|
}; |
308
|
|
|
|
|
|
|
|
309
|
|
|
|
|
|
|
=item aio_open $path, $flags, $mode, $cb->($fh) |
310
|
|
|
|
|
|
|
|
311
|
|
|
|
|
|
|
Tries to open the file specified by C<$path> with the O_XXX-flags |
312
|
|
|
|
|
|
|
C<$flags> (from the Fcntl module, or see below) and the mode C<$mode> (a |
313
|
|
|
|
|
|
|
good value is 0666 for C, and C<0> otherwise). |
314
|
|
|
|
|
|
|
|
315
|
|
|
|
|
|
|
The (normal, standard, perl) file handle associated with the opened file |
316
|
|
|
|
|
|
|
is then passed to the callback. |
317
|
|
|
|
|
|
|
|
318
|
|
|
|
|
|
|
This works very much like Perl's C function. |
319
|
|
|
|
|
|
|
|
320
|
|
|
|
|
|
|
Changing the C while this request executes results in undefined |
321
|
|
|
|
|
|
|
behaviour - likewise changing anything else that would change the outcome, |
322
|
|
|
|
|
|
|
such as your effective user or group ID. |
323
|
|
|
|
|
|
|
|
324
|
|
|
|
|
|
|
To avoid having to load L, this module provides constants |
325
|
|
|
|
|
|
|
for C, C, C, C, C, |
326
|
|
|
|
|
|
|
C and C - you can either access them directly |
327
|
|
|
|
|
|
|
(C) or import them by specifying the C<:flags> |
328
|
|
|
|
|
|
|
import tag (see SYNOPSIS). |
329
|
|
|
|
|
|
|
|
330
|
|
|
|
|
|
|
Example: securely open a file in F, fail if it exists or is a symlink. |
331
|
|
|
|
|
|
|
|
332
|
|
|
|
|
|
|
use AnyEvent::IO qw(:flags); |
333
|
|
|
|
|
|
|
|
334
|
|
|
|
|
|
|
aio_open "/var/tmp/mytmp$$", O_CREAT | O_EXCL | O_RDWR, 0600, sub { |
335
|
|
|
|
|
|
|
my ($fh) = @_ |
336
|
|
|
|
|
|
|
or return AE::log error => "$! - denial of service attack?"; |
337
|
|
|
|
|
|
|
|
338
|
|
|
|
|
|
|
# now we have $fh |
339
|
|
|
|
|
|
|
}; |
340
|
|
|
|
|
|
|
|
341
|
|
|
|
|
|
|
=item aio_close $fh, $cb->($success) |
342
|
|
|
|
|
|
|
|
343
|
|
|
|
|
|
|
Closes the file handle (yes, close can block your process indefinitely) |
344
|
|
|
|
|
|
|
and passes a true value to the callback on success. |
345
|
|
|
|
|
|
|
|
346
|
|
|
|
|
|
|
Due to idiosyncrasies in perl, instead of calling C, the file |
347
|
|
|
|
|
|
|
handle might get closed by C'ing another file descriptor over |
348
|
|
|
|
|
|
|
it, that is, the C<$fh> might still be open, but can be closed safely |
349
|
|
|
|
|
|
|
afterwards and must not be used for anything. |
350
|
|
|
|
|
|
|
|
351
|
|
|
|
|
|
|
Example: close a file handle, and dirty as we are, do not even bother |
352
|
|
|
|
|
|
|
to check for errors. |
353
|
|
|
|
|
|
|
|
354
|
|
|
|
|
|
|
aio_close $fh, sub { }; |
355
|
|
|
|
|
|
|
|
356
|
|
|
|
|
|
|
=item aio_read $fh, $length, $cb->($data) |
357
|
|
|
|
|
|
|
|
358
|
|
|
|
|
|
|
Tries to read C<$length> octets from the current position from C<$fh> and |
359
|
|
|
|
|
|
|
passes these bytes to C<$cb>. Otherwise the semantics are very much like |
360
|
|
|
|
|
|
|
those of Perl's C. |
361
|
|
|
|
|
|
|
|
362
|
|
|
|
|
|
|
If less than C<$length> octets have been read, C<$data> will contain |
363
|
|
|
|
|
|
|
only those bytes actually read. At EOF, C<$data> will be a zero-length |
364
|
|
|
|
|
|
|
string. If an error occurs, then nothing is passed to the callback. |
365
|
|
|
|
|
|
|
|
366
|
|
|
|
|
|
|
Obviously, multiple C's or C's at the same time on file |
367
|
|
|
|
|
|
|
handles sharing the underlying open file description results in undefined |
368
|
|
|
|
|
|
|
behaviour, due to sharing of the current file offset (and less obviously |
369
|
|
|
|
|
|
|
so, because OS X is not thread safe and corrupts data when you try). |
370
|
|
|
|
|
|
|
|
371
|
|
|
|
|
|
|
Example: read 128 octets from a file. |
372
|
|
|
|
|
|
|
|
373
|
|
|
|
|
|
|
aio_read $fh, 128, sub { |
374
|
|
|
|
|
|
|
my ($data) = @_ |
375
|
|
|
|
|
|
|
or return AE::log error "read from fh: $!"; |
376
|
|
|
|
|
|
|
|
377
|
|
|
|
|
|
|
if (length $data) { |
378
|
|
|
|
|
|
|
print "read ", length $data, " octets.\n"; |
379
|
|
|
|
|
|
|
} else { |
380
|
|
|
|
|
|
|
print "EOF\n"; |
381
|
|
|
|
|
|
|
} |
382
|
|
|
|
|
|
|
}; |
383
|
|
|
|
|
|
|
|
384
|
|
|
|
|
|
|
=item aio_seek $fh, $offset, $whence, $callback->($offs) |
385
|
|
|
|
|
|
|
|
386
|
|
|
|
|
|
|
Seeks the filehandle to the new C<$offset>, similarly to Perl's |
387
|
|
|
|
|
|
|
C. The C<$whence> are the traditional values (C<0> to count from |
388
|
|
|
|
|
|
|
start, C<1> to count from the current position and C<2> to count from the |
389
|
|
|
|
|
|
|
end). |
390
|
|
|
|
|
|
|
|
391
|
|
|
|
|
|
|
The resulting absolute offset will be passed to the callback on success. |
392
|
|
|
|
|
|
|
|
393
|
|
|
|
|
|
|
Example: measure the size of the file in the old-fashioned way using seek. |
394
|
|
|
|
|
|
|
|
395
|
|
|
|
|
|
|
aio_seek $fh, 0, 2, sub { |
396
|
|
|
|
|
|
|
my ($size) = @_ |
397
|
|
|
|
|
|
|
or return AE::log error => "seek to end failed: $!"; |
398
|
|
|
|
|
|
|
|
399
|
|
|
|
|
|
|
# maybe we need to seek to the beginning again? |
400
|
|
|
|
|
|
|
aio_seek $fh, 0, 0, sub { |
401
|
|
|
|
|
|
|
# now we are hopefully at the beginning |
402
|
|
|
|
|
|
|
}; |
403
|
|
|
|
|
|
|
}; |
404
|
|
|
|
|
|
|
|
405
|
|
|
|
|
|
|
=item aio_write $fh, $data, $cb->($length) |
406
|
|
|
|
|
|
|
|
407
|
|
|
|
|
|
|
Tries to write the octets in C<$data> to the current position of C<$fh> |
408
|
|
|
|
|
|
|
and passes the actual number of bytes written to the C<$cb>. Otherwise the |
409
|
|
|
|
|
|
|
semantics are very much like those of Perl's C. |
410
|
|
|
|
|
|
|
|
411
|
|
|
|
|
|
|
If less than C octets have been written, C<$length> will |
412
|
|
|
|
|
|
|
reflect that. If an error occurs, then nothing is passed to the callback. |
413
|
|
|
|
|
|
|
|
414
|
|
|
|
|
|
|
Obviously, multiple C's or C's at the same time on file |
415
|
|
|
|
|
|
|
handles sharing the underlying open file description results in undefined |
416
|
|
|
|
|
|
|
behaviour, due to sharing of the current file offset (and less obviously |
417
|
|
|
|
|
|
|
so, because OS X is not thread safe and corrupts data when you try). |
418
|
|
|
|
|
|
|
|
419
|
|
|
|
|
|
|
=item aio_truncate $fh_or_path, $new_length, $cb->($success) |
420
|
|
|
|
|
|
|
|
421
|
|
|
|
|
|
|
Calls C on the path or perl file handle and passes a true value |
422
|
|
|
|
|
|
|
to the callback on success. |
423
|
|
|
|
|
|
|
|
424
|
|
|
|
|
|
|
Example: truncate F to zero length - this only works on |
425
|
|
|
|
|
|
|
systems that support C, should not be tried out for obvious |
426
|
|
|
|
|
|
|
reasons and debian will probably open yte another security bug about this |
427
|
|
|
|
|
|
|
example. |
428
|
|
|
|
|
|
|
|
429
|
|
|
|
|
|
|
aio_truncate "/etc/passwd", sub { |
430
|
|
|
|
|
|
|
@_ |
431
|
|
|
|
|
|
|
or return AE::log error => "/etc/passwd: $! - are you root enough?"; |
432
|
|
|
|
|
|
|
}; |
433
|
|
|
|
|
|
|
|
434
|
|
|
|
|
|
|
=item aio_utime $fh_or_path, $atime, $mtime, $cb->($success) |
435
|
|
|
|
|
|
|
|
436
|
|
|
|
|
|
|
Calls C on the path or perl file handle and passes a true value to |
437
|
|
|
|
|
|
|
the callback on success. |
438
|
|
|
|
|
|
|
|
439
|
|
|
|
|
|
|
The special case of both C<$atime> and C<$mtime> being C sets the |
440
|
|
|
|
|
|
|
times to the current time, on systems that support this. |
441
|
|
|
|
|
|
|
|
442
|
|
|
|
|
|
|
Example: try to touch F. |
443
|
|
|
|
|
|
|
|
444
|
|
|
|
|
|
|
aio_utime "file", undef, undef, sub { }; |
445
|
|
|
|
|
|
|
|
446
|
|
|
|
|
|
|
=item aio_chown $fh_or_path, $uid, $gid, $cb->($success) |
447
|
|
|
|
|
|
|
|
448
|
|
|
|
|
|
|
Calls C on the path or perl file handle and passes a true value to |
449
|
|
|
|
|
|
|
the callback on success. |
450
|
|
|
|
|
|
|
|
451
|
|
|
|
|
|
|
If C<$uid> or C<$gid> can be specified as C, in which case the |
452
|
|
|
|
|
|
|
uid or gid of the file is not changed. This differs from Perl's C |
453
|
|
|
|
|
|
|
built-in, which wants C<-1> for this. |
454
|
|
|
|
|
|
|
|
455
|
|
|
|
|
|
|
Example: update the group of F to 0 (root), but leave the owner alone. |
456
|
|
|
|
|
|
|
|
457
|
|
|
|
|
|
|
aio_chown "file", undef, 0, sub { |
458
|
|
|
|
|
|
|
@_ |
459
|
|
|
|
|
|
|
or return AE::log error => "chown 'file': $!"; |
460
|
|
|
|
|
|
|
}; |
461
|
|
|
|
|
|
|
|
462
|
|
|
|
|
|
|
=item aio_chmod $fh_or_path, $perms, $cb->($success) |
463
|
|
|
|
|
|
|
|
464
|
|
|
|
|
|
|
Calls C on the path or perl file handle and passes a true value to |
465
|
|
|
|
|
|
|
the callback on success. |
466
|
|
|
|
|
|
|
|
467
|
|
|
|
|
|
|
Example: change F to be user/group/world-readable, but leave the other flags |
468
|
|
|
|
|
|
|
alone. |
469
|
|
|
|
|
|
|
|
470
|
|
|
|
|
|
|
aio_stat "file", sub { |
471
|
|
|
|
|
|
|
@_ |
472
|
|
|
|
|
|
|
or return AE::log error => "file: $!"; |
473
|
|
|
|
|
|
|
|
474
|
|
|
|
|
|
|
aio_chmod "file", (stat _)[2] & 07777 | 00444, sub { }; |
475
|
|
|
|
|
|
|
}; |
476
|
|
|
|
|
|
|
|
477
|
|
|
|
|
|
|
=item aio_stat $fh_or_path, $cb->($success) |
478
|
|
|
|
|
|
|
|
479
|
|
|
|
|
|
|
=item aio_lstat $path, $cb->($success) |
480
|
|
|
|
|
|
|
|
481
|
|
|
|
|
|
|
Calls C or C on the path or perl file handle and passes a |
482
|
|
|
|
|
|
|
true value to the callback on success. |
483
|
|
|
|
|
|
|
|
484
|
|
|
|
|
|
|
The stat data will be available by C'ing the C<_> file handle |
485
|
|
|
|
|
|
|
(e.g. C<-x _>, C and so on). |
486
|
|
|
|
|
|
|
|
487
|
|
|
|
|
|
|
Example: see if we can find the number of subdirectories of F. |
488
|
|
|
|
|
|
|
|
489
|
|
|
|
|
|
|
aio_stat "/etc", sub { |
490
|
|
|
|
|
|
|
@_ |
491
|
|
|
|
|
|
|
or return AE::log error => "/etc: $!"; |
492
|
|
|
|
|
|
|
|
493
|
|
|
|
|
|
|
(stat _)[3] >= 2 |
494
|
|
|
|
|
|
|
or return AE::log warn => "/etc has low link count - non-POSIX filesystem?"; |
495
|
|
|
|
|
|
|
|
496
|
|
|
|
|
|
|
print "/etc has ", (stat _)[3] - 2, " subdirectories.\n"; |
497
|
|
|
|
|
|
|
}; |
498
|
|
|
|
|
|
|
|
499
|
|
|
|
|
|
|
=item aio_link $oldpath, $newpath, $cb->($success) |
500
|
|
|
|
|
|
|
|
501
|
|
|
|
|
|
|
Calls C on the paths and passes a true value to the callback on |
502
|
|
|
|
|
|
|
success. |
503
|
|
|
|
|
|
|
|
504
|
|
|
|
|
|
|
Example: link "F to F, then rename F over F, |
505
|
|
|
|
|
|
|
to atomically replace it. |
506
|
|
|
|
|
|
|
|
507
|
|
|
|
|
|
|
aio_link "file", "file.bak", sub { |
508
|
|
|
|
|
|
|
@_ |
509
|
|
|
|
|
|
|
or return AE::log error => "file: $!"; |
510
|
|
|
|
|
|
|
|
511
|
|
|
|
|
|
|
aio_rename "file.new", "file", sub { |
512
|
|
|
|
|
|
|
@_ |
513
|
|
|
|
|
|
|
or return AE::log error => "file.new: $!"; |
514
|
|
|
|
|
|
|
|
515
|
|
|
|
|
|
|
print "file atomically replaced by file.new, backup file.bak\n"; |
516
|
|
|
|
|
|
|
}; |
517
|
|
|
|
|
|
|
}; |
518
|
|
|
|
|
|
|
|
519
|
|
|
|
|
|
|
=item aio_symlink $oldpath, $newpath, $cb->($success) |
520
|
|
|
|
|
|
|
|
521
|
|
|
|
|
|
|
Calls C on the paths and passes a true value to the callback on |
522
|
|
|
|
|
|
|
success. |
523
|
|
|
|
|
|
|
|
524
|
|
|
|
|
|
|
Example: create a symlink "F containing "random data". |
525
|
|
|
|
|
|
|
|
526
|
|
|
|
|
|
|
aio_symlink "random data", "slink", sub { |
527
|
|
|
|
|
|
|
@_ |
528
|
|
|
|
|
|
|
or return AE::log error => "slink: $!"; |
529
|
|
|
|
|
|
|
}; |
530
|
|
|
|
|
|
|
|
531
|
|
|
|
|
|
|
=item aio_readlink $path, $cb->($target) |
532
|
|
|
|
|
|
|
|
533
|
|
|
|
|
|
|
Calls C on the paths and passes the link target string to the |
534
|
|
|
|
|
|
|
callback. |
535
|
|
|
|
|
|
|
|
536
|
|
|
|
|
|
|
Example: read the symlink called Fyslink> and verify that it contains "random data". |
537
|
|
|
|
|
|
|
|
538
|
|
|
|
|
|
|
aio_readlink "slink", sub { |
539
|
|
|
|
|
|
|
my ($target) = @_ |
540
|
|
|
|
|
|
|
or return AE::log error => "slink: $!"; |
541
|
|
|
|
|
|
|
|
542
|
|
|
|
|
|
|
$target eq "random data" |
543
|
|
|
|
|
|
|
or AE::log critical => "omg, the world will end!"; |
544
|
|
|
|
|
|
|
}; |
545
|
|
|
|
|
|
|
|
546
|
|
|
|
|
|
|
=item aio_rename $oldpath, $newpath, $cb->($success) |
547
|
|
|
|
|
|
|
|
548
|
|
|
|
|
|
|
Calls C on the paths and passes a true value to the callback on |
549
|
|
|
|
|
|
|
success. |
550
|
|
|
|
|
|
|
|
551
|
|
|
|
|
|
|
See C for an example. |
552
|
|
|
|
|
|
|
|
553
|
|
|
|
|
|
|
=item aio_unlink $path, $cb->($success) |
554
|
|
|
|
|
|
|
|
555
|
|
|
|
|
|
|
Tries to unlink the object at C<$path> and passes a true value to the |
556
|
|
|
|
|
|
|
callback on success. |
557
|
|
|
|
|
|
|
|
558
|
|
|
|
|
|
|
Example: try to delete the file F. |
559
|
|
|
|
|
|
|
|
560
|
|
|
|
|
|
|
aio_unlink "tmpfile.dat~", sub { }; |
561
|
|
|
|
|
|
|
|
562
|
|
|
|
|
|
|
=item aio_mkdir $path, $perms, $cb->($success) |
563
|
|
|
|
|
|
|
|
564
|
|
|
|
|
|
|
Calls C on the path with the given permissions C<$perms> (when in |
565
|
|
|
|
|
|
|
doubt, C<0777> is a good value) and passes a true value to the callback on |
566
|
|
|
|
|
|
|
success. |
567
|
|
|
|
|
|
|
|
568
|
|
|
|
|
|
|
Example: try to create the directory F and leave it to whoeveer |
569
|
|
|
|
|
|
|
comes after us to check whether it worked. |
570
|
|
|
|
|
|
|
|
571
|
|
|
|
|
|
|
aio_mkdir "subdir", 0777, sub { }; |
572
|
|
|
|
|
|
|
|
573
|
|
|
|
|
|
|
=item aio_rmdir $path, $cb->($success) |
574
|
|
|
|
|
|
|
|
575
|
|
|
|
|
|
|
Tries to remove the directory at C<$path> and passes a true value to the |
576
|
|
|
|
|
|
|
callback on success. |
577
|
|
|
|
|
|
|
|
578
|
|
|
|
|
|
|
Example: try to remove the directory F and don't give a damn if |
579
|
|
|
|
|
|
|
that fails. |
580
|
|
|
|
|
|
|
|
581
|
|
|
|
|
|
|
aio_rmdir "subdir", sub { }; |
582
|
|
|
|
|
|
|
|
583
|
|
|
|
|
|
|
=item aio_readdir $path, $cb->(\@names) |
584
|
|
|
|
|
|
|
|
585
|
|
|
|
|
|
|
Reads all filenames from the directory specified by C<$path> and passes |
586
|
|
|
|
|
|
|
them to the callback, as an array reference with the names (without a path |
587
|
|
|
|
|
|
|
prefix). The F<.> and F<..> names will be filtered out first. |
588
|
|
|
|
|
|
|
|
589
|
|
|
|
|
|
|
The ordering of the file names is undefined - backends that are capable |
590
|
|
|
|
|
|
|
of it (e.g. L) will return the ordering that most likely is |
591
|
|
|
|
|
|
|
fastest to C through, and furthermore put entries that likely are |
592
|
|
|
|
|
|
|
directories first in the array. |
593
|
|
|
|
|
|
|
|
594
|
|
|
|
|
|
|
If you need best performance in recursive directory traversal or when |
595
|
|
|
|
|
|
|
looking at really big directories, you are advised to use L |
596
|
|
|
|
|
|
|
directly, specifically the C and C functions, |
597
|
|
|
|
|
|
|
which have more options to tune performance. |
598
|
|
|
|
|
|
|
|
599
|
|
|
|
|
|
|
Example: recursively scan a directory hierarchy, silently skip diretcories |
600
|
|
|
|
|
|
|
we couldn't read and print all others. |
601
|
|
|
|
|
|
|
|
602
|
|
|
|
|
|
|
sub scan($); # visibility-in-next statement is not so useful these days |
603
|
|
|
|
|
|
|
sub scan($) { |
604
|
|
|
|
|
|
|
my ($path) = @_; |
605
|
|
|
|
|
|
|
|
606
|
|
|
|
|
|
|
aio_readdir $path, sub { |
607
|
|
|
|
|
|
|
my ($names) = @_ |
608
|
|
|
|
|
|
|
or return; |
609
|
|
|
|
|
|
|
|
610
|
|
|
|
|
|
|
print "$path\n"; |
611
|
|
|
|
|
|
|
|
612
|
|
|
|
|
|
|
for my $name (@$names) { |
613
|
|
|
|
|
|
|
aio_lstat "$path/$name", sub { |
614
|
|
|
|
|
|
|
scan "$path/$name" |
615
|
|
|
|
|
|
|
if -d _; |
616
|
|
|
|
|
|
|
}; |
617
|
|
|
|
|
|
|
} |
618
|
|
|
|
|
|
|
}; |
619
|
|
|
|
|
|
|
} |
620
|
|
|
|
|
|
|
|
621
|
|
|
|
|
|
|
scan "/etc"; |
622
|
|
|
|
|
|
|
|
623
|
|
|
|
|
|
|
=back |
624
|
|
|
|
|
|
|
|
625
|
|
|
|
|
|
|
=head1 ENVIRONMENT VARIABLES |
626
|
|
|
|
|
|
|
|
627
|
|
|
|
|
|
|
See the description of C in the L |
628
|
|
|
|
|
|
|
manpage. |
629
|
|
|
|
|
|
|
|
630
|
|
|
|
|
|
|
=head1 AUTHOR |
631
|
|
|
|
|
|
|
|
632
|
|
|
|
|
|
|
Marc Lehmann |
633
|
|
|
|
|
|
|
http://anyevent.schmorp.de |
634
|
|
|
|
|
|
|
|
635
|
|
|
|
|
|
|
=cut |
636
|
|
|
|
|
|
|
|
637
|
|
|
|
|
|
|
1 |
638
|
|
|
|
|
|
|
|