InfiniSQL  v0.1.2-alpha
Massive Scale Transaction Processing
 All Classes Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
TopologyMgr.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2013 Mark Travis <mtravis15432+src@gmail.com>
3  * All rights reserved. No warranty, explicit or implicit, provided.
4  *
5  * This file is part of InfiniSQL(tm).
6 
7  * InfiniSQL is free software: you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License version 3
9  * as published by the Free Software Foundation.
10  *
11  * InfiniSQL is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with InfiniSQL. If not, see <http://www.gnu.org/licenses/>.
18  */
19 
33 #ifndef INFINISQLTOPOLOGYMGR_H
34 #define INFINISQLTOPOLOGYMGR_H
35 
36 #include "gch.h"
37 #include "cfgenum.h"
38 
46 void *topologyMgr(void *identity);
47 
54 {
55 public:
57  TopologyMgr(const TopologyMgr &orig);
58  virtual ~TopologyMgr();
59 private:
68  void updateLocalConfig(msgpack::unpacker &pac, msgpack::unpacked &result);
77  void updateGlobalConfig(msgpack::unpacker &pac, msgpack::unpacked &result);
82  void broadcastConfig();
83 
85  class Mboxes mboxes;
87 };
88 
89 #endif /* INFINISQLTOPOLOGYMGR_H */