/*************************************************************************** * Copyright (c) Yorik van Havre (yorik@uncreated.net) 2014 * * * * This file is part of the FreeCAD CAx development system. * * * * This library is free software; you can redistribute it and/or * * modify it under the terms of the GNU Library General Public * * License as published by the Free Software Foundation; either * * version 2 of the License, or (at your option) any later version. * * * * This library 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 Library General Public License for more details. * * * * You should have received a copy of the GNU Library General Public * * License along with this library; see the file COPYING.LIB. If not, * * write to the Free Software Foundation, Inc., 59 Temple Place, * * Suite 330, Boston, MA 02111-1307, USA * * * ***************************************************************************/ #include "PreCompiled.h" #ifndef _PreComp_ #endif #include #include #include #include "Tooltable.h" using namespace Base; using namespace Path; // TOOL TYPESYSTEM_SOURCE(Path::Tool , Base::Persistence); // Constructors & destructors Tool::Tool(const char* name, ToolType type, ToolMaterial material, double diameter, double lengthoffset, double flatradius, double cornerradius, double cuttingedgeangle, double cuttingedgeheight) :Name(name),Type(type),Diameter(diameter),LengthOffset(lengthoffset), FlatRadius(flatradius),CornerRadius(cornerradius),CuttingEdgeAngle(cuttingedgeangle), CuttingEdgeHeight(cuttingedgeheight) { } Tool::Tool() { } Tool::~Tool() { } // Reimplemented from base class unsigned int Tool::getMemSize (void) const { return 0; } void Tool::Save (Writer &writer) const { writer.Stream() << writer.ind() << " "; else if(Material == Tool::HIGHSPEEDSTEEL) writer.Stream() << " mat=\"HighSpeedSteel\" /> "; else if(Material == Tool::HIGHCARBONTOOLSTEEL) writer.Stream() << " mat=\"HighCarbonToolSteel\" /> "; else if(Material == Tool::CASTALLOY) writer.Stream() << " mat=\"CastAlloy\" /> "; else if(Material == Tool::CERAMICS) writer.Stream() << " mat=\"Ceramics\" /> "; else if(Material == Tool::DIAMOND) writer.Stream() << " mat=\"Diamond\" /> "; else if(Material == Tool::SIALON) writer.Stream() << " mat=\"Sialon\" /> "; else writer.Stream() << " mat=\"Undefined\" /> "; writer.Stream()<< std::endl; } void Tool::Restore(XMLReader &reader) { reader.readElement("Tool"); Name = reader.getAttribute("name"); Diameter = (double) reader.getAttributeAsFloat("diameter"); LengthOffset = (double) reader.getAttributeAsFloat("length"); FlatRadius = (double) reader.getAttributeAsFloat("flat"); CornerRadius = (double) reader.getAttributeAsFloat("corner"); CuttingEdgeAngle = (double) reader.getAttributeAsFloat("angle"); CuttingEdgeHeight = (double) reader.getAttributeAsFloat("height"); std::string type = reader.getAttribute("type"); if(type=="EndMill") Type = Tool::ENDMILL; else if(type=="Drill") Type = Tool::DRILL; else if(type=="CenterDrill") Type = Tool::CENTERDRILL; else if(type=="CounterSink") Type = Tool::COUNTERSINK; else if(type=="CounterBore") Type = Tool::COUNTERBORE; else if(type=="Reamer") Type = Tool::REAMER; else if(type=="Tap") Type = Tool::TAP; else if(type=="SlotCutter") Type = Tool::SLOTCUTTER; else if(type=="BallEndMill") Type = Tool::BALLENDMILL; else if(type=="ChamferMill") Type = Tool::CHAMFERMILL; else if(type=="CornerRound") Type = Tool::CORNERROUND; else if(type=="Engraver") Type = Tool::ENGRAVER; else Type = Tool::UNDEFINED; std::string mat = reader.getAttribute("mat"); if(mat=="Carbide") Material = Tool::CARBIDE; else if(mat=="HighSpeedSteel") Material = Tool::HIGHSPEEDSTEEL; else if(mat=="HighCarbonToolSteel") Material = Tool::HIGHCARBONTOOLSTEEL; else if(mat=="CastAlloy") Material = Tool::CASTALLOY; else if(mat=="Ceramics") Material = Tool::CERAMICS; else if(mat=="Diamond") Material = Tool::DIAMOND; else if(mat=="Sialon") Material = Tool::SIALON; else Material = Tool::MATUNDEFINED; } // TOOLTABLE TYPESYSTEM_SOURCE(Path::Tooltable , Base::Persistence); Tooltable::Tooltable() { } Tooltable::~Tooltable() { } void Tooltable::addTool(const Tool &tool) { Tool *tmp = new Tool(tool); if (!Tools.empty()) { int max = 0; for(std::map::const_iterator i = Tools.begin(); i != Tools.end(); ++i) { int k = i->first; if (k > max) max = k; } Tools[max+1]= tmp; } else Tools[1] = tmp; } void Tooltable::setTool(const Tool &tool, int pos) { if (pos == -1) { addTool(tool); } else { Tool *tmp = new Tool(tool); Tools[pos] = tmp; } } void Tooltable::deleteTool(int pos) { if (Tools.find(pos) != Tools.end()) { Tools.erase(pos); } else { throw Base::Exception("Index not found"); } } unsigned int Tooltable::getMemSize (void) const { return 0; } void Tooltable::Save (Writer &writer) const { writer.Stream() << writer.ind() << "" << std::endl; writer.incInd(); for(std::map::const_iterator i = Tools.begin(); i != Tools.end(); ++i) { int k = i->first; Tool *v = i->second; writer.Stream() << writer.ind() << "" << std::endl; writer.incInd(); v->Save(writer); writer.decInd(); writer.Stream() << writer.ind() << "" << std::endl; } writer.decInd(); writer.Stream() << writer.ind() << "" << std::endl ; } void Tooltable::Restore (XMLReader &reader) { Tools.clear(); reader.readElement("Tooltable"); int count = reader.getAttributeAsInteger("count"); for (int i = 0; i < count; i++) { reader.readElement("Toolslot"); int id = reader.getAttributeAsInteger("number"); Tool *tmp = new Tool(); tmp->Restore(reader); Tools[id] = tmp; } }