NAME
Cocoa::EventLoop - perl interface for Cocoa event loop.
SYNOPSIS
use Cocoa::EventLoop;
# on-shot timer
my $timer = Cocoa::EventLoop->timer(
after => 10,
cb => sub {
# do something
},
);
# repeatable timer
my $timer = Cocoa::EventLoop->timer(
after => 10,
interval => 10,
cb => sub {
# do something
},
);
# stop or cancel timers
undef $timer;
# I/O Watcher
my $io = Cocoa::EventLoop->io(
fh => *STDIN,
poll => 'r',
cb => sub {
warn 'read: ', <STDIN>;
},
);
# run main loop
Cocoa::EventLoop->run;
# run main loop for specified period.
Cocoa::EventLoop->run_while($secs);
DESCRIPTION
This module provides perl interface for Cocoa's event loop, NSRunLoop.
And also provides some timers and io watchers within the loop.
If you want to use or write some modules that depends Cocoa event loop,
using this module is easiest way. For example, Cocoa::Growl is possible
to handle click event when it runs with this module:
use Cocoa::EventLoop;
use Cocoa::Growl;
my $done = 0;
growl_notify(
name => 'Notification Name',
title => 'Hello',
description => 'Cocoa World!',
on_click => sub {
$done++;
},
on_timeout => sub {
$done++;
},
);
Cocoa::EventLoop->run_while(0.1) while !$done;
If you write more complicated script, consider using
AnyEvent::Impl::NSRunLoop instead of using this module directly.
AnyEvent::Impl::NSRunLoop is a wrapper for Cocoa::EventLoop and
AnyEvent. If you use AnyEvent::Impl::NSRunLoop, you can use any AnyEvent
based modules in Cocoa's event loop.
CLASS METHODS
Cocoa::EventLoop->timer(%parameters)
$timer = Cocoa::EventLoop->timer(after => <seconds>, cb => <callback>);
$timer = Cocoa::EventLoop->timer(
after => <fractional_seconds>,
interval => <fractional_seconds>,
cb => <callback>,
);
Create one-shot or repeat timer.
Available parameters are:
* after => 'Number'
How many seconds (fractional values are supported) the callback
should be invoked. When this value does not specified, use 0 by
default.
* interval => 'Number'
Callback will be invoked regularly at this interval (in fractional
seconds) after the first invocation. If this value does not
specified, use 0 by default (== act as non repeat, on-shot timer);
* cb => 'CodeRef'
Callbacks that will be invoked when timer is fire. This parameter is
required.
Cocoa::EventLoop->io(%parameters)
$io = Cocoa::EventLoop->io(
fh => <filehandle_or_fileno>,
poll => <"r" or "w">,
cb => <callback>,
);
Create I/O watcher. Available parameters are:
* fh => 'FileHandle' or fileno
Perl file handle (or a naked file descriptor) to watch for events.
(Required)
* poll => 'r' or 'w'
Type for watching event. 'r' is for readable, 'w' is for writable.
(Required)
* cb => 'CodeRef'
callback to invoke each time the file handle becomes ready.
(Required)
Cocoa::EventLoop->run
Start Cocoa main loop.
This method exits immediately when no input sources or timers are
attached to the loop, but Mac OS X can install and remove additional
input sources as needed, and those sources could therefore prevent the
run loop from exiting.
If you want the run loop to terminate, you shouldn't use this method.
Instead, use one of the other run methods and also check other arbitrary
conditions of your own, in a loop. A simple example would be:
my $should_keep_running = 0; # global
Cocoa::EventLoop->run_while(0.1) while $should_keep_running;
Cocoa::EventLoop->run_while($secs)
Run Cocoa main loop only while specified seconds.
AUTHOR
Daisuke Murase <typester@cpan.org>
COPYRIGHT AND LICENSE
Copyright (c) 2009 by KAYAC Inc.
This program is free software; you can redistribute it and/or modify it
under the same terms as Perl itself.
The full text of the license can be found in the LICENSE file included
with this module.