more cleaning of ToolManager
[clinton/Smoothieware.git] / src / modules / tools / toolmanager / ToolManager.cpp
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 #include "libs/Module.h"
9 #include "libs/Kernel.h"
10 #include <math.h>
11 using namespace std;
12 #include <vector>
13 #include "ToolManager.h"
14 #include "PublicDataRequest.h"
15 #include "ToolManagerPublicAccess.h"
16 #include "Config.h"
17 #include "Robot.h"
18 #include "ConfigValue.h"
19 #include "Conveyor.h"
20 #include "checksumm.h"
21 #include "PublicData.h"
22 #include "Gcode.h"
23
24 #include "libs/SerialMessage.h"
25 #include "libs/StreamOutput.h"
26 #include "FileStream.h"
27
28 #include "modules/robot/RobotPublicAccess.h"
29
30 #define return_error_on_unhandled_gcode_checksum CHECKSUM("return_error_on_unhandled_gcode")
31
32 #define X_AXIS 0
33 #define Y_AXIS 1
34 #define Z_AXIS 2
35
36 ToolManager::ToolManager(){
37 active_tool = 0;
38 current_tool_name = CHECKSUM("hotend");
39 }
40
41 void ToolManager::on_module_loaded(){
42 this->on_config_reload(this);
43
44 this->register_for_event(ON_CONFIG_RELOAD);
45 this->register_for_event(ON_GCODE_RECEIVED);
46 this->register_for_event(ON_GET_PUBLIC_DATA);
47 this->register_for_event(ON_SET_PUBLIC_DATA);
48 }
49
50 void ToolManager::on_config_reload(void *argument){
51 return_error_on_unhandled_gcode = THEKERNEL->config->value( return_error_on_unhandled_gcode_checksum )->by_default(false)->as_bool();
52 }
53
54 void ToolManager::on_gcode_received(void *argument){
55 Gcode *gcode = static_cast<Gcode*>(argument);
56
57 if( gcode->has_letter('T') ){
58 int new_tool = gcode->get_value('T');
59 gcode->mark_as_taken();
60 if(new_tool >= (int)this->tools.size() || new_tool < 0){
61 // invalid tool
62 if( return_error_on_unhandled_gcode ) {
63 char buf[32]; // should be big enough for any status
64 int n= snprintf(buf, sizeof(buf), "T%d invalid tool ", new_tool);
65 gcode->txt_after_ok.append(buf, n);
66 }
67 } else {
68 if(new_tool != this->active_tool){
69 this->tools[active_tool]->disable();
70 this->active_tool = new_tool;
71 this->current_tool_name = this->tools[active_tool]->get_name();
72 this->tools[active_tool]->enable();
73
74 //send new_tool_offsets to robot
75 float *new_tool_offset = tools[new_tool]->get_offset();
76 THEKERNEL->robot->setToolOffset(new_tool_offset[0], new_tool_offset[1], new_tool_offset[2]);
77 }
78 }
79 }
80 }
81
82 void ToolManager::on_get_public_data(void* argument){
83 PublicDataRequest* pdr = static_cast<PublicDataRequest*>(argument);
84
85 if(!pdr->starts_with(tool_manager_checksum)) return;
86
87 // ok this is targeted at us, so send back the requested data
88 // this must be static as it will be accessed long after we have returned
89 static struct pad_toolmanager tool_return;
90 tool_return.current_tool_name= this->current_tool_name;
91
92 pdr->set_data_ptr(&tool_return);
93 pdr->set_taken();
94 }
95
96 void ToolManager::on_set_public_data(void* argument){
97 PublicDataRequest* pdr = static_cast<PublicDataRequest*>(argument);
98
99 if(!pdr->starts_with(tool_manager_checksum)) return;
100
101 // ok this is targeted at us, so change tools
102 uint16_t tool_name= *static_cast<float*>(pdr->get_data_ptr());
103 // TODO: fire a tool change gcode
104 pdr->set_taken();
105 }
106
107 // Add a tool to the tool list
108 void ToolManager::add_tool(Tool* tool_to_add){
109 if(this->tools.size() == 0){
110 tool_to_add->enable();
111 this->current_tool_name = tool_to_add->get_name();
112 } else {
113 tool_to_add->disable();
114 }
115 this->tools.push_back( tool_to_add );
116 }
117
118
119