LogService
libdadi: utility tools for distributed applications
StateManager.hh
1 /****************************************************************************/
2 /* Header for the StateManager class */
3 /* */
4 /* Author(s): */
5 /* - Georg Hoesch (hoesch@in.tum.de) */
6 /* - Cyrille Pontvieux (cyrille.pontvieux@edu.univ-fcomte.fr) */
7 /* */
8 /* This file is part of DIET . */
9 /* */
10 /* Copyright (C) 2000-2003 ENS Lyon, LIFC, INSA, INRIA and SysFera (2000) */
11 /* */
12 /* - Frederic.Desprez@ens-lyon.fr (Project Manager) */
13 /* - Eddy.Caron@ens-lyon.fr (Technical Manager) */
14 /* - Tech@sysfera.com (Maintainer and Technical Support) */
15 /* */
16 /* This software is a computer program whose purpose is to provide an */
17 /* distributed logging services. */
18 /* */
19 /* */
20 /* This software is governed by the CeCILL license under French law and */
21 /* abiding by the rules of distribution of free software. You can use, */
22 /* modify and/ or redistribute the software under the terms of the CeCILL */
23 /* license as circulated by CEA, CNRS and INRIA at the following URL */
24 /* "http://www.cecill.info". */
25 /* */
26 /* As a counterpart to the access to the source code and rights to copy, */
27 /* modify and redistribute granted by the license, users are provided */
28 /* only with a limited warranty and the software's author, the holder */
29 /* of the economic rights, and the successive licensors have only */
30 /* limited liability. */
31 /* */
32 /* In this respect, the user's attention is drawn to the risks */
33 /* associated with loading, using, modifying and/or developing or */
34 /* reproducing the software by the user in light of its specific status */
35 /* of free software, that may mean that it is complicated to */
36 /* manipulate, and that also therefore means that it is reserved for */
37 /* developers and experienced professionals having in-depth computer */
38 /* knowledge. Users are therefore encouraged to load and test the */
39 /* software's suitability as regards their requirements in conditions */
40 /* enabling the security of their systems and/or data to be ensured and, */
41 /* more generally, to use and operate it in the same conditions as */
42 /* regards security. */
43 /* */
44 /* The fact that you are presently reading this means that you have had */
45 /* knowledge of the CeCILL license and that you accept its terms. */
46 /* */
47 /****************************************************************************/
48 /* $Id$
49  * $Log$
50  * Revision 1.1 2004/01/09 11:07:12 ghoesch
51  * Restructured the whole LogService source tree.
52  * Added autotools make process. Cleaned up code.
53  * Removed some testers. Ready to release.
54  *
55  ***************************************************************************/
56 
57 #ifndef _STATEMANAGER_HH_
58 #define _STATEMANAGER_HH_
59 
60 #include <cstdio>
61 #include "LogTypes.hh"
62 #include "ReadConfig.hh"
63 #include "ToolList.hh"
64 #include "FullLinkedList.hh"
65 
67 
68 class StateManager {
69 public:
76  StateManager(ReadConfig* readConfig, bool* success);
77 
78  ~StateManager();
79 
86  bool
87  check(log_msg_t* msg);
88 
94  void
95  askForSystemState(OutBuffer* outBuffer);
96 
97 private:
98  tag_list_t* dynamicTagsList;
99  tag_list_t* dynamicStarts;
100  tag_list_t* dynamicStops;
101  tag_list_t* staticTagsList;
102  tag_list_t* uniqueTagsList;
103  char* start;
104  char* stop;
105  ToolList* toolList;
106  StateList* stateList;
107 };
108 
109 #endif
110 
void askForSystemState(OutBuffer *outBuffer)
Definition: StateManager.hh:68
Definition: LogTypes.hh:77
Definition: LogTypes.hh:221
Definition: ReadConfig.hh:67
StateManager(ReadConfig *readConfig, bool *success)
bool check(log_msg_t *msg)