Merge branch 'feature/on_second_tick_event' into edge
[clinton/Smoothieware.git] / src / libs / Kernel.h
1 /*
2 This file is part of Smoothie (http://smoothieware.org/). The motion control part is heavily based on Grbl (https://github.com/simen/grbl).
3 Smoothie is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
4 Smoothie is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
5 You should have received a copy of the GNU General Public License along with Smoothie. If not, see <http://www.gnu.org/licenses/>.
6 */
7
8 #ifndef KERNEL_H
9 #define KERNEL_H
10 #include "libs/Module.h"
11 #include "libs/Config.h"
12 #include "libs/SlowTicker.h"
13 #include "libs/StreamOutputPool.h"
14 #include "libs/StepTicker.h"
15 #include "libs/Adc.h"
16 #include "libs/Digipot.h"
17 #include "libs/Pauser.h"
18 #include "modules/communication/SerialConsole.h"
19 #include "modules/communication/GcodeDispatch.h"
20 #include "modules/robot/Planner.h"
21 #include "modules/robot/Robot.h"
22 #include "modules/robot/Stepper.h"
23
24 //Module manager
25 class Module;
26 class Player;
27 class SlowTicker;
28 class Kernel {
29 public:
30 Kernel();
31 void add_module(Module* module);
32 void register_for_event(_EVENT_ENUM id_event, Module* module);
33 void call_event(_EVENT_ENUM id_event);
34 void call_event(_EVENT_ENUM id_event, void * argument);
35
36 // These modules are aviable to all other modules
37 SerialConsole* serial;
38 StreamOutputPool* streams;
39
40 GcodeDispatch* gcode_dispatch;
41 Robot* robot;
42 Stepper* stepper;
43 Planner* planner;
44 Config* config;
45 Player* player;
46 Pauser* pauser;
47
48 int debug;
49 SlowTicker* slow_ticker;
50 StepTicker* step_ticker;
51 Adc* adc;
52 Digipot* digipot;
53
54 private:
55 Module* hooks[NUMBER_OF_DEFINED_EVENTS][32]; // When a module asks to be called for a specific event ( a hook ), this is where that request is remembered
56
57 };
58
59 #endif