/*************************************************************************** * Copyright (C) 2006 Nicolas Hadacek * * * * This program 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 2 of the License, or * * (at your option) any later version. * ***************************************************************************/ #include "xml_to_data/prog_xml_to_data.h" #include "progs/pickit1/base/pickit1_data.h" namespace Pickit1 { class XmlToData : public Programmer::XmlToData { public: XmlToData() : Programmer::XmlToData("pickit1", "Pickit1") {} private: virtual void parseData(TQDomElement element, Data &data); virtual void outputData(const Data &data, TQTextStream &s) const; virtual void outputFunctions(TQTextStream &s) const; }; void Pickit1::XmlToData::parseData(TQDomElement element, Data &data) { TQString s = element.attribute("entry"); if ( s.length()!=1 || (s[0]!='O' && s[0]!='P') ) tqFatal("Invalid or missing entry mode"); data.entryMode = s[0].latin1(); s = element.attribute("regen"); if ( s.isEmpty() || s=="false" ) data.regenerateOsccal = false; else if ( s=="true" ) data.regenerateOsccal = true; else tqFatal("Invalid regen value"); } void Pickit1::XmlToData::outputData(const Data &data, TQTextStream &s) const { s << "'" << data.entryMode << "', " << (data.regenerateOsccal ? "true" : "false"); } void Pickit1::XmlToData::outputFunctions(TQTextStream &s) const { Programmer::XmlToData::outputFunctions(s); s << "::Programmer::DeviceSpecific *Group::createDeviceSpecific(Programmer::Base &base) const" << endl; s << "{" << endl; s << " uint i = family(static_cast< ::Pickit1::Base &>(base).device()->name());" << endl; s << " switch(i) {" << endl; for (uint i=0; i