Merge remote-tracking branch 'upstream/edge' into upstreamedge
[clinton/Smoothieware.git] / src / libs / Module.h
index 56b5a2b..8a9134b 100644 (file)
@@ -8,51 +8,49 @@
 #ifndef MODULE_H
 #define MODULE_H
 
-#include <string>
-using std::string;
-
 // See : http://smoothieware.org/listofevents
+// When adding a new event the virtual method needs to be defined in class Module and the method pointer need to be defined in
+// Module.cpp:16 in the same order
 enum _EVENT_ENUM {
     ON_MAIN_LOOP,
     ON_CONSOLE_LINE_RECEIVED,
     ON_GCODE_RECEIVED,
-    ON_STEPPER_WAKE_UP,
-    ON_GCODE_EXECUTE,
-    ON_SPEED_CHANGE,
-    ON_BLOCK_BEGIN,
-    ON_BLOCK_END,
-    ON_CONFIG_RELOAD,
-    ON_PLAY,
-    ON_PAUSE,
     ON_IDLE,
-    ON_CONFIG_VALUE,
-    ON_CONFIG_COMPLETE,
+    ON_SECOND_TICK,
+    ON_GET_PUBLIC_DATA,
+    ON_SET_PUBLIC_DATA,
+    ON_HALT,
+    ON_ENABLE,
     NUMBER_OF_DEFINED_EVENTS
 };
 
+class Module;
+typedef void (Module::*ModuleCallback)(void *argument);
+extern const ModuleCallback kernel_callback_functions[NUMBER_OF_DEFINED_EVENTS];
+
 // Module base class
 // All modules must extend this class, see http://smoothieware.org/moduleexample
-class Kernel;
-class Module {
-    public:
-        Module();
-        virtual void on_module_loaded();
-        virtual void register_for_event(        _EVENT_ENUM event_id);
-        virtual void on_main_loop(              void * argument);
-        virtual void on_console_line_received(  void * argument);
-        virtual void on_gcode_received(         void * argument);
-        virtual void on_stepper_wake_up(        void * argument);
-        virtual void on_gcode_execute(          void * argument);
-        virtual void on_speed_change(           void * argument);
-        virtual void on_block_begin(            void * argument);
-        virtual void on_block_end(              void * argument);
-        virtual void on_config_reload(          void * argument);
-        virtual void on_play(                   void * argument);
-        virtual void on_pause(                  void * argument);
-        virtual void on_idle(                   void * argument);
-        virtual void on_config_value(           void * argument);
-        virtual void on_config_complete(        void * argument);
-        Kernel * kernel;
+class Module
+{
+public:
+    Module();
+    virtual ~Module();
+    virtual void on_module_loaded() {};
+
+    void register_for_event(_EVENT_ENUM event_id);
+
+    // event callbacks, not every module will implement all of these
+    // there should be one for each _EVENT_ENUM
+    virtual void on_main_loop(void *) {};
+    virtual void on_console_line_received(void *) {};
+    virtual void on_gcode_received(void *) {};
+    virtual void on_idle(void *) {};
+    virtual void on_second_tick(void *) {};
+    virtual void on_get_public_data(void *) {};
+    virtual void on_set_public_data(void *) {};
+    virtual void on_halt(void *) {};
+    virtual void on_enable(void *) {};
+
 };
 
 #endif