Perl Object Environment

Perl Object Environment

: "For the Mach variant, see Mach kernel"

The Perl Object Environment or POE is a library of Perl modules written in the Perl programming language by Rocco Caputo et alia.

From CPAN::"POE originally was developed as the core of a persistent object server and runtime environment. It has evolved into a general purpose multitasking and networking framework, encompassing and providing a consistent interface to other event loops such as Event and the Tk and Gtk toolkits."

POE Architecture: Layers of Abstraction

POE, The Perl Object Environment can be thought of as a tiny modular operating system. One or more POE programs or instances can be run concurrently and are generally well suited for cooperative multitasking. The POE package consists of namespaces and abstractions that guide future development of POE in an open-ended CPAN-style convention.

The event layer

The informal architecture consists of a set of layers with a kernel on the bottom. This tiny kernel represents the events layer which operates as the main loop of each running POE instance. The first call is to the "event dispatcher" - POE::Kernel.

The POE::Kernel namespace contains a suite of functions which are plugged-in to the kernel itself. These loop abstractions are designed after POE's standardized event loop bridge interface - POE::Loop. These can be mixed and matched as needed to provide runtime services and a lean facility for interprocess communication. The basic functions are POE::Loop::Event, POE::Loop::Poll and POE::Loop::Select. Also available are POE::Loop::Tk and POE::Loop::Gtk that offer hooks into other loop bridges in the external environment. If that isn't enough, the POE::Loop kernel abstraction provides reusable signal callbacks, time or alarm callbacks, and filehandle activity callbacks as well as administrative functions such as initializing, executing, and finalizing event loops.

There is also a higher level packaging framework - POE::Macro and a debugging utility for testing them called POE::Preprocessor. This framework has yielded POE::Macro::UseBytes.

:NOTE: As the Perl tradition mandates, POE is also a moving target.

Always check CPAN to see what new goodies the community has placed in the archive. (...and remember Perl's Motto: "There's more than one way to do it" per Larry)

The Running Kernel operates through primordial finite state machines constructed from another set of abstractions ruled by the POE::Session architecture. A POE::Session is almost trivially defined as a map of events to the functions, class methods, and/or object methods that handle them. POE::Session objects also contain a storage space shared by all its event handlers, called a heap. Any way you slice them the states are solidly identified and clearly defined.

A more featureful event handler is a POE::Session subclass called POE::NFA - an event-driven Nondeterministic Finite Automaton (a "smarter" finite state machine). This event handler moves from one strictly defined state to another as events, polls, user selections, or other external events require. This state machine acts to encapsulate a wide range of generic event driven threads allowing much tight tracking along the execution path than the relatively informal POE::Session.

The I/O Layer

The Kernel's next requirement is for Input-Output handlers that exist in a single I/O layer called "Wheels". Wheels initiate actions, handle their resulting low-level events, and produce higher-level events for the sessions that use them. Wheels, like Sessions and Loops are built from a uniform set of abstractions - POE::Wheel - that sit on top of the Kernel. There are seven highly specialized and well-defined Wheels in POE's base distribution:
*POE::Wheel::Run - Creates and interacts with child processes using pipe(), fork(), and sometimes exec(). Interaction is done through the child's standard input and output.
*POE::Wheel::SocketFactory - A way to create client and server sockets without blocking to wait for their establishment.
*POE::Wheel::Curses - A handler for non-blocking input from the Curses text interface library. CPAN components such as Curses::UI::POE and Term::Visual build upon it.
*POE::Wheel::FollowTail - Tracks an ever-growing file, such as a log or a collaborative document, by keeping a handle on its tail.
*POE::Wheel::ListenAccept - A subset of POE::Wheel::SocketFactory used for listening on existing server sockets and accepting connections from remote clients.
*POE::Wheel::ReadLine - A non-blocking, event driven analogue to Term::ReadLine.
*POE::Wheel::ReadWrite - A high-performance NBIO file handler for POE that uses POE's "drivers" and "filters" to perform buffered read and write on filehandles which draws on the next layer - POE's own little file system.

The file layers

Drivers do the actual work of reading and writing filehandles. They are built according to the less abstract definitions contained in the POE::Driver module. The main driver implemented at the time of this writing is POE::Driver::SysRW - a universal filehandle reader/writer designed especially for POE::Wheel::ReadWrite.

The next layer, built from POE::Filter and probably the focus of most Perl Obfuscation Efficianados (see POE #POE humor below), is the POE::Filter set: "Filters translate between raw streams and cooked chunks of tasty dada." per `sungo'
*POE::Filter::Block - parses input as fixed-length blocks. On the output side, it merely passes data through unscathed.
*POE::Filter::HTTPD - parses input as HTTP requests and translates them into "HTTP::Request" objects. On the output side, it takes "HTTP::Response" objects and turns them into something suitable to be sent to a web client/user-agent.
*POE::Filter::Line - parses incoming streams into lines and turns outgoing lines into streams. It used to be very basic, but recent improvements have added interesting features like newline autodetection.
*POE::Filter::Reference - used to send Perl structures between POE programs or between POE and other Perl programs. On the input side, frozen data (via Storable, FreezeThaw, YAML, or some other serialization mechanism) is thawed into Perl data structures. On output, references given to the filter are frozen. Data may also be compressed on request if Compress::Zlib is installed.
*POE::Filter::Stream - does nothing. It merely passes data through without any change.

see [http://search.cpan.org/~rcaputo/POE/lib/POE.pm POE at CPAN] for the complete list

POE Components

Several larger packages have been written in POE according to the POE::Component documentation. These are event-driven modules, many of which act as little daemons that provide services to larger packages to which they belong. Some of them facilitate higher-level communications between modules, especially stand-alone applications that need to remain independent from the main distribution of Perl.

In general, POE Components are ready-made high level procedures that perform specific large tasks. A few examples:

*Component::Server::TCP - a special-purpose TCP servlet
*Component::Client::TCP - a POE-aware TCP client
*POE::Component::IRC - a nearly full-featured IRC client.
*POE::Component::Server::IRC - an RFC 2810 to RFC 2813 compliant IRC server (under development)
*POE::Component::UserBase - a user authentication and data persistence servlet. "POE Components tend to be highly reusable libraries that handle tedious tasks, freeing programmers to focus on more interesting things. This should be true for any library, though."

POE Humor

* The [http://search.cpan.org/perldoc?Acme%3A%3APOE%3A%3AKnee Acme::POE::Knee] module on the CPAN.
* A number of silly acronym expansions at the end of [http://poe.perl.org/?What_POE_IS What POE Is] .

ee also

* event-driven programming
* Twisted, a comparable framework for the Python programming language

External links

* [http://poe.perl.org/ POE Home Page] (a Wiki site)
* [http://poe.perl.org/?POE_Cookbook The POE_Cookbook]
* [http://search.cpan.org/~rcaputo/POE/ POE at CPAN]
* [http://search.cpan.org/search?m=module&q=POE%3A%3AComponent POE Component classes at CPAN]
* [http://www.perl.com/pub/a/2001/01/poe.html A Beginner's Introduction to POE]
* [http://poe.perl.org/?Evolution_of_a_POE_Server Evolution_of_a_POE_Server]
* [http://www.stonehenge.com/merlyn/LinuxMag/col41.html merlyn (stonehenge) article]


Wikimedia Foundation. 2010.

Игры ⚽ Поможем сделать НИР

Look at other dictionaries:

  • Perl — Desarrollador(es) Larry Wall www.perl.org Información general Paradigma multiparadigma, funcional, im …   Wikipedia Español

  • Perl — This article is about the programming language. For other uses, see Perl (disambiguation). Perl Paradig …   Wikipedia

  • Object-oriented programming — Programming paradigms Agent oriented Automata based Component based Flow based Pipelined Concatenative Concurrent computing …   Wikipedia

  • Object database — Example of an object oriented model.[1] An object database (also object oriented database management system) is a database management system in which information is represented in the form of objects as used in object oriented programming. Object …   Wikipedia

  • GNU Network Object Model Environment — GNOME GNOME 2.22 Basisdaten …   Deutsch Wikipedia

  • Integrated development environment — Anjuta, a C and C++ IDE for the GNOME environment An integrated development environment (IDE) (also known as integrated design environment, integrated debugging environment or interactive development environment) is a software application that… …   Wikipedia

  • Common Object Request Broker Architecture — The Common Object Request Broker Architecture (CORBA) is a standard defined by the Object Management Group (OMG) that enables software components written in multiple computer languages and running on multiple computers to work together (i.e., it… …   Wikipedia

  • Phoenix Object Basic — is an object oriented RAD tool for Linux. It has object oriented features such as inheritance and polymorphism as found in languages such as Python and Perl. It also features a similar design environment and compatible syntax to Visual Basic… …   Wikipedia

  • Z Object Publishing Environment — Zope (Z Object Publishing Environment) ist ein objektorientierter, in der Programmiersprache Python geschriebener, freier Webanwendungs Server mit offenem Quelltext. Zope stellt eine Plattform für die Realisierung von Webanwendungen dar und… …   Deutsch Wikipedia

  • Событийно-ориентированное программирование — Парадигмы программирования Агентно ориентированная Компонентно ориентированная Конкатенативная Декларативная (контрастирует с Императивной) Ограничениями Функциональная Потоком данных Таблично ориентированная (электронные таблицы) Реактивная …   Википедия

Share the article and excerpts

Direct link
Do a right-click on the link above
and select “Copy Link”