NAME
IOMux::Select - simplify use of select()
INHERITANCE
IOMux::Select
is an IOMux
SYNOPSIS
use IOMux::Select;
my $mux = IOMux::Select->new;
my $server = IOMux::Service::TCP->new(...);
$mux->add($server);
$mux->loop;
DESCRIPTION
Multiplexer implemented around the select()
system call. This select()
is usually less powerful and slower than the poll()
call (implemented in IOMux::Poll) however probably available on more systems.
Extends "DESCRIPTION" in IOMux.
METHODS
Extends "METHODS" in IOMux.
Constructors
Extends "Constructors" in IOMux.
- IOMux::Select->new(%options)
-
Inherited, see "Constructors" in IOMux
Accessors
Extends "Accessors" in IOMux.
User interface
Extends "User interface" in IOMux.
- $obj->add($handler|$bundle)
-
Inherited, see "User interface" in IOMux
- $obj->endLoop(BOOLEAN)
-
Inherited, see "User interface" in IOMux
- $obj->loop( [$heartbeat] )
-
Inherited, see "User interface" in IOMux
- $obj->open($mode, $params)
-
Inherited, see "User interface" in IOMux
- $obj->showFlags( [$flags|<$rdflags,$wrflags,$exflags>] )
-
Display the select $flags (one of the values received from selectFlags()) or all of these flags. You may also specify three sets of $flags explicitly.
When three sets of $flags are passed, it will result in three lines preceeded with labels. With only one set, no label will be used.
The flagged filenos are shown numerically (modulo 10) and positionally. For instance, if both filehandle 1 and 4 are flagged, the output string will be
-1--4
.example:
my ($rd, $wr, $er) = $client->selectFlags; print "read flags: ",$client->showFlags($rd); print $client->showFlags(rd, $wr, $er); print $client->showFlags; # saem result print $client->showFlags($client->waitFlags);
For internal use
Extends "For internal use" in IOMux.
- $obj->changeTimeout($fileno, $oldtimeout, $newtimeout)
-
Inherited, see "For internal use" in IOMux
- $obj->fdset($fileno, $state, $read, $write, $except)
-
Inherited, see "For internal use" in IOMux
- $obj->handler( $fileno, [$handler] )
-
Inherited, see "For internal use" in IOMux
- $obj->handlers()
-
Inherited, see "For internal use" in IOMux
- $obj->remove($fileno)
-
Inherited, see "For internal use" in IOMux
- $obj->selectFlags()
-
Returns a list of three: respectively the read, write and error flags which show the file numbers that the internal
select()
call has flagged as needing inspection.This method can, for instance, be used from within the heartbeat routine.
example:
$mux->loop(\&heartbeat); sub heartbeat($$$) { my ($mux, $numready, $timeleft) = @_; my ($rd, $rw, $ex) = $mux->selectFlags; if(vec($rd, $fileno, 1)==1) {...} }
- $obj->waitFlags()
-
Returns a list of three: respectively the read, write and error flags which show how the files are enlisted.
DETAILS
Extends "DETAILS" in IOMux.
Installation
Extends "Installation" in IOMux.
Event managers
Extends "Event managers" in IOMux.
File handles
Extends "File handles" in IOMux.
Implementation limitations
The select
system call is very powerful, however the (UNIX) standard specifies quite a weak subset of the features usually offered. The standard only requires sockets to be supported. The Windows/cygwin implementation limits itself to that. Modern UNIX dialects usually also support normal pipes and file handlers to be attached.
Please help extending the list of OS specific limitations below!
Limitations on Windows
The select()
system call is very limited: it only works on sockets, not on files or pipes. This means that the process will stall on each file access and pipe activity.
Limitations on UNIX/Linux
Be careful with the use of files. You should open files with the non-stdio version of open()
, with option O_NONBLOCK
. But even then, asynchronous support for reading and writing files and pipes may be lacking on your UNIX dialect.
SEE ALSO
This module is part of IOMux distribution version 1.01, built on January 15, 2020. Website: http://perl.overmeer.net/CPAN
LICENSE
Copyrights 2011-2020 by [Mark Overmeer <markov@cpan.org>]. For other contributors see ChangeLog.
This program is free software; you can redistribute it and/or modify it under the same terms as Perl itself. See http://dev.perl.org/licenses/