summaryrefslogtreecommitdiffstats
path: root/src/progs/icd2/xml/xml_icd2_parser.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/progs/icd2/xml/xml_icd2_parser.cpp')
-rw-r--r--src/progs/icd2/xml/xml_icd2_parser.cpp53
1 files changed, 53 insertions, 0 deletions
diff --git a/src/progs/icd2/xml/xml_icd2_parser.cpp b/src/progs/icd2/xml/xml_icd2_parser.cpp
new file mode 100644
index 0000000..7ce2ad9
--- /dev/null
+++ b/src/progs/icd2/xml/xml_icd2_parser.cpp
@@ -0,0 +1,53 @@
+/***************************************************************************
+ * Copyright (C) 2006 Nicolas Hadacek <[email protected]> *
+ * *
+ * 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/icd2/base/icd2_data.h"
+
+//-----------------------------------------------------------------------------
+namespace Icd2
+{
+
+class XmlToData : public Programmer::XmlToData<Data>
+{
+public:
+ XmlToData() : Programmer::XmlToData<Data>("icd2", "Icd2") {}
+
+private:
+ virtual uint familyIndex(const QString &family) const;
+ virtual void parseData(QDomElement element, Data &data);
+ virtual void outputData(const Data &data, QTextStream &s) const;
+};
+
+uint Icd2::XmlToData::familyIndex(const QString &family) const
+{
+ uint i = 0;
+ for (; Icd2::FAMILY_DATA[i].efid!=0; i++)
+ if ( family==Icd2::FAMILY_DATA[i].name ) break;
+ if ( Icd2::FAMILY_DATA[i].efid==0 ) qFatal(QString("Family \"%1\" is unknown").arg(family));
+ return i;
+}
+
+void Icd2::XmlToData::parseData(QDomElement element, Data &data)
+{
+ bool ok;
+ data.famid = fromHexLabel(element.attribute("famid"), 2, &ok);
+ if ( !ok ) qFatal("Missing or malformed famid attribute");
+ data.debugSupport = extractSupport(element.attribute("debug_support_type"));
+}
+
+void Icd2::XmlToData::outputData(const Data &data, QTextStream &s) const
+{
+ s << toHexLabel(data.famid, 2) << ", ";
+ s << "::Group::Support::Type(" << data.debugSupport.type() << ")";
+}
+
+} // namespace
+
+//-----------------------------------------------------------------------------
+XML_MAIN(Icd2::XmlToData)