NAME
Reflex::Trait::Observed - Automatically watch Reflex objects.
VERSION
version 0.080
SYNOPSIS
# Not a complete program. This example comes from Reflex's main # synopsis.
has clock => (
isa => 'Reflex::Interval',
is => 'rw',
traits => [ 'Reflex::Trait::Observed' ],
setup => { interval => 1, auto_repeat => 1 },
);
DESCRIPTION
Reflex::Trait::Observed modifies a member to automatically observe any Reflex::Base object stored within it. In the SYNOPSIS, storing a Reflex::Interval in the clock() attribute allows the owner to watch the timer's events.
This trait is a bit of Moose-based syntactic sugar for Reflex::Base's more explict watch() and watch_role() methods.
setup
The "setup" option provides default constructor parameters for the attribute. In the above example, clock() will by default contain
Reflex::Interval->new(interval => 1, auto_repeat => 1);
In other words, it will emit the Reflex::Interval event ("tick") once per second until destroyed.
role
Attribute events are mapped to the owner's methods using Reflex's role-based callback convention. For example, Reflex will look for an on_clock_tick() method to handle "tick" events from an object with the 'clock" role.
The "role" option allows roles to be set or overridden. A watcher attribute's name is its default role.
Declarative Syntax
Reflex::Trait::Observed exports a declarative observes() function, which acts almost identically to Moose's has() but with a couple convenient defaults: The Observed trait is added, and the attribute is given "rw" access by default.
CAVEATS
The "setup" option is a work-around for unfortunate default timing. It will be deprecated if default can be made to work instead.
SEE ALSO
Reflex Reflex::Trait::EmitsOnChange
"ACKNOWLEDGEMENTS" in Reflex "ASSISTANCE" in Reflex "AUTHORS" in Reflex "BUGS" in Reflex "BUGS" in Reflex "CONTRIBUTORS" in Reflex "COPYRIGHT" in Reflex "LICENSE" in Reflex "TODO" in Reflex