August'24: Kamaelia is in maintenance mode and will recieve periodic updates, about twice a year, primarily targeted around Python 3 and ecosystem compatibility. PRs are always welcome. Latest Release: 1.14.32 (2024/3/24)

Kamaelia.Chassis.Carousel.Carousel

Here we go again, and again,...

Descripton

Inboxes:

  • inbox - passthrough to child
  • next - where we receive requests to replace the child component
  • control - where we recieve shutdown requests from outside
  • _control - Expect 'producerFinished' or 'shutdownMicroprocess' from child

Outboxes:

  • outbox - passthrough from child
  • signal -
  • _signal - For sending 'shutdownMicroprocess' to child
  • requestNext - For requesting new child component

This chassis component is for making a carousel of components. It gets its name from a broadcast carousel - where a programme (or set of programmes) is broadcast one after another, often on a loop. Alternatively, think of public information screens which display a looping carousel of slides of information.

If this makes no sense, suppose you want to read data from a sequence of files - one after another. Provide a carousel with a filereader component and a source of filenames, and it will make a new filereader for each file in turn, outputting their data one after another. The carousel automatically asks the filename source for a new item when its current child signals that it has finished.

You gain reusability from things that are not directly reusable and normally come to a halt.

Examples

Reading from a sequence of files

1. Write a factory function that takes a single argument and returns a new component for the carousel:

2. Make the carousel giving it the factory function:

3. Make a source of instructions for the carousel: (in this case, a source of filenames)

4. Wire the source and carousel together:

5. Activate:

How does it work?

The carousel chassis creates and encapsulates (as a child) the component you want it to, and lets it get on with it.

Anything sent to the carousel's "inbox" inbox is passed onto the child component. Anything the child sends out appears at the carousel's "outbox" and "signal" outboxes.

If the child sends an Axon.Ipc.shutdownMicroprocess or Axon.Ipc.producerFinished message then the carousel gets rid of that component and sends a "NEXT" message to its "requestNext" outbox.

Another component, such as a Chooser, should respond to this message by sending the new set of arguments (for the factory function) to the carousel's "next" inbox. The carousel then uses your factory function to create a new child component. And so the cycle repeats.

If the argument source needs to receive a "NEXT" message before sending its first set of arguments, then set the argument make1stRequest=True when creating the carousel.

You can send new orders to the next inbox at any time. The carousel will immediately unwire that child (and create the new one) and ask the old child to shut down by sending an Axon.Ipc.shutdownMicroprocess message to its control inbox.

The carousel will shutdown in response to an Axon.Ipc.shutdownMicroprocess or Axon.Ipc.producerFinished message. It will also terminate any child component in the same way as described above.

Pydoc Style Docs

Kamaelia.Chassis.Carousel.Carousel

For examples and more explanations, see the module level docs.


Carousel(componentFactory,[make1stRequest]) -> new Carousel component

Create a Carousel component that makes child components one at a time (in carousel fashion) using the supplied factory function.

Keyword arguments:

Inboxes

Outboxes

Methods defined here

Warning!

You should be using the inbox/outbox interface, not these methods (except construction). This documentation is designed as a roadmap as to their functionalilty for maintainers and new component developers.

__init__(self, componentFactory[, make1stRequest])

x.__init__(...) initializes x; see x.__class__.__doc__ for signature

checkControl(self)

handleChildTerminations(self)

Unplugs any children that have terminated

instantiateNewChild(self, args)

main(self)

requestNext(self)

Sends 'next' out the 'requestNext' outbox

shutdownChild(self, shutdownMsg)

Feedback

Got a problem with the documentation? Something unclear that could be clearer? Want to help improve it? Constructive criticism is very welcome - especially if you can suggest a better rewording!

Please leave you feedback here in reply to the documentation thread in the Kamaelia blog.

-- Automatic documentation generator, 05 Jun 2009 at 03:01:38 UTC/GMT

class Carousel(Axon.Component.component)

A carousel component that makes child components one at a time and lets them do their stuff. Replacing them when they terminate or if requested to do so.

Inboxes:

Outboxes:

requestNext - for requesting new child component

All methods, except __init__ are private implementation details of the component

__init__(self, componentFactory, make1stRequest=False)

handleFinishedChild(self)

Unplugs the child if a shutdownMicroprocess or producerFinished message is received from it. Also sends a "NEXT" request if one has not already been sent.

handleNewChild(self)

If data received on "next" inbox, removes any existing child and creates and wires in a new one.

Received data is passed as an argument to the factory function (supplied at initialisation) that creates the new child.

main(self)

Main loop

requestNext(self)

Sends 'next' out the 'requestNext' outbox

shutdown(self)

Returns True if a shutdownMicroprocess or producerFinished message was received.

unplugChildren(self)

Sends 'shutdownMicroprocess' to children and unwires and disowns them.