Merge branch 'edge' into onboot
[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/Pauser.h"
17 #include "modules/communication/SerialConsole.h"
18 #include "modules/communication/GcodeDispatch.h"
19 #include "modules/robot/Planner.h"
20 #include "modules/robot/Robot.h"
21 #include "modules/robot/Stepper.h"
22 #include <array>
23
24 //Module manager
25 class Module;
26 class Conveyor;
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 Conveyor* conveyor;
46 Pauser* pauser;
47
48 int debug;
49 SlowTicker* slow_ticker;
50 StepTicker* step_ticker;
51 Adc* adc;
52
53 private:
54 std::array<std::vector<Module*>, NUMBER_OF_DEFINED_EVENTS> hooks; // When a module asks to be called for a specific event ( a hook ), this is where that request is remembered
55
56 };
57
58 #endif