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:

    def makeFileReader(filename):
    return ReadFileAdapter(filename = filename, ...other args... )

2. Make the carousel giving it the factory function:

     carousel = Carousel( componentFactory = makeFileReader )

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

    filenames = Chooser( ["file1","file2","file3", ... ] )

4. Wire the source and carousel together:

    filecarousel = JoinChooserToCarousel( chooser = filenames, carousel = carousel ) 

5. Activate:

    filecarousel.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 docs : Kamaelia.Chassis.Carousel.Carousel

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:

  • componentFactory -- function that takes a single argument and returns a component
  • make1stRequest -- if True, Carousel will send an initial "NEXT" request. (default=False)

Inboxes

  • control :
  • inbox : child's inbox
  • next : requests to replace child

Outboxes

  • outbox : child's outbox
  • signal :
  • _signal : internal use: for sending 'shutdownMicroprocess' to child
  • requestNext : for requesting new child component

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

handleChildTerminations(self)

Unplugs any children that have terminated

requestNext(self)

Sends 'next' out the 'requestNext' outbox

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, 21 Nov 2008 at 04:01:30 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:

  • inbox - passthrough to child's inbox "inbox"
  • next - where we recieve requests to replace the child component
  • control - where we recieve shutdown requests from outside
  • _control - internal use : to recieve 'producerFinished' or 'shutdownMicroprocess' from child

Outboxes:

  • outbox - passthrough from child's outbox "outbox"
  • signal -
  • _signal - internal use: for sending 'shutdownMicroprocess' to child
  • requestNext - for requesting new child component
  • All methods, except __init__ are private implementation details of the component

    __init__(self, componentFactory, make1stRequest=False)

    • __init__(componentFactory)
    • __init__(componentFactory,make1stRequest=True)
    • componentFactory(argument) -> new component
      factory function for creating a new child according to specified arguments
    • make1stRequest = True
      Carousel will, immediately after activation, send a "NEXT" message to its "requestNext" outbox. Otherwise the carousel just waits.

    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.

     

    Kamaelia is an open source project originated from and guided by BBC Research. For more information browse the site or get in contact.

    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. (the site is powered by a wiki engine)

    (C) Copyright 2008 Kamaelia Contributors, including the British Broadcasting Corporation, All Rights Reserved

    This web site is powered by the same code created for the bicker manor project. For more details, contact Michael Sparks at BBC Research directly (cf contact)