NAME

Class::Declarative::EventContext - base class implementing an event context in a declarative structure.

VERSION

Version 0.01

SYNOPSIS

Each node in a Class::Declarative structure that can respond to events can inherit from this class to get the proper machinery in place.

event_context_init()

Called during object creation to set up fields and such.

value($var), setvalue($var, $value)

Accesses the global application value named.

register_varhandler ($event, $handler)

Registers a variable handler in the event context. If there is a handler registered for a name, it will be called instead of the normal hash read and write. This means you can attach active content to a variable, then treat it just like any other variable in your code.

event_context()

Returns $self.

register_event($event, $closure), do ($event)

Registers and fires closures by name. This is the mechanism used by the 'on' tag in the core semantics. This is actually a command-line interface; fire runs the Text::ParseWords parse_line function on its input, and gives the event closure any list elements that come after the first word.

make_event

Given the name of a Class::Declarative event, finds the code referred to in its callable closure.

TODO: this is not covered by unit testing!

semantics()

Each event context can return a semantic handler. For example, a form knows that its core semantics are "wx"; a Word document knows that its core semantics are "ms-word", and so on. The semantic handlers are a good place to put common functionality for a given semantic domain, so they're useful in code snippets in a given context.

The default is to return the core semantics.

AUTHOR

Michael Roberts, <michael at vivtek.com>

BUGS

Please report any bugs or feature requests to bug-class-declarative at rt.cpan.org, or through the web interface at http://rt.cpan.org/NoAuth/ReportBug.html?Queue=Class-Declarative. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

LICENSE AND COPYRIGHT

Copyright 2010 Michael Roberts.

This program is free software; you can redistribute it and/or modify it under the terms of either: the GNU General Public License as published by the Free Software Foundation; or the Artistic License.

See http://dev.perl.org/licenses/ for more information.