aboutsummaryrefslogtreecommitdiff
path: root/src/programchain.h
blob: 34f64f81f765d7013da1f6ff9e2a7453e48b489b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
#ifndef PROGRAMCHAIN_H
#define PROGRAMCHAIN_H

#include "linkedlist.h"
#include "multilog.h"
#include "programlink.h"

/** The Program Chain links together program "chunks" to more easily facilitate
  * a generalized program loop with modular extensions.
  *@author Mike Buland
  */
class ProgramChain
{
public:
	/**
	 * Construct an empty chain.
	 */
	ProgramChain();

	/**
	 * Destroy your chain.
	 */
	~ProgramChain();

	/** Adds a link to the end of the chain.
	  *@param pLink A pointer to the link to add to the chain.
	  *@returns True if adding the link was successful, otherwise false
	  *@author Mike Buland
	  */
	bool addLink( ProgramLink *pLink );

	/** Gets a link by name.
	  *@param lpName The name of the link you're looking for.  Every link has a
	  * name, apparently.
	  *@returns A pointer to the specified ProgramLink, or NULL if none were found
	  * matching your criteria.
	  *@author Mike Buland
	  */
	class ProgramLink *getLink( const char *lpName );

	/** Gets the very first link in the chain.
	  *@returns A pointer to the first link in the chain.
	  *@author Mike Buland
	  */
	class ProgramLink *getBaseLink();

	/** Runs through the chain once.  Useful if you want to have more control over
	  * the operation of the chain.
	  *@returns true if every link returned true.  If at least one link returns false,
	  * then returns false.
	  *@author Mike Buland
	  */
	bool execChainOnce();

	/** Enters the master chain loop, looping over the entire chain and executing
	  * every link's TimeSlice routine in order, over and over, until a link returns
	  * a false value.
	  *@returns False, always.  It returns true unless a link returned false, but loops
	  * until a link does return false.
	  *@author Mike Buland
	  **/
	bool enterChainLoop();

	/** Broadcasts an Immediate Response Message to all active links, save the
	  * sender.  Whatever link first responds with a non-null response message
	  * will have it's messages sent back to the broadcasting link as the returns
	  * of this function call.  Therefore it is very important that all message
	  * processing code is handled in a fairly timely fasion.
	  *@param pMsgOut The message to broadcast in hopes of a response.
	  *@param pSender The message that sent out the message and doesn't want to
	  * receive it's own message.  This should always just be "this".
	  *@returns The message that was returned by the first link to return a
	  * non-null response.  If all messages return null responses then this also
	  * returns null.  Please note that whoever calls this will be responsible
	  * for deleting the message returned by it, if non-null.
	  */
	class LinkMessage *broadcastIRM( LinkMessage *pMsgOut, ProgramLink *pSender );

private:
	/**
	 * Shuts down all operation no matter what point in the operation we were.
	 */
	void emergencyShutdown();
	MultiLog *pLog;	/**< A pointer to a log. */
	LinkedList lLink; /**< The linked list that contains all of the links. */
};

#endif