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

class Carousel(Axon.Component.component)

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: componentFactory -- function that takes a single argument and returns a component make1stRequest -- if True, Carousel will send an initial "NEXT" request. (default=False)

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

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.


Feedback

Got a problem with the documentation? Something unclear, could be clearer? Want to help with improving? Constructive criticism, preferably in the form of suggested rewording is very welcome.

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

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.


    (C) 2006 Kamaelia Contributors, including the British Broadcasting Corporation, All Rights Reserved, This is an ongoing community based development site. As a result the contents of this page is the opinions of the contributors of the pages involved not the organisations involved. Specificially, this page may contain personal views which are not the views of the BBC.