From 71f0e1d0acf141c5ebe869039537e340ae11407f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20T=C5=AFma?= Date: Wed, 12 Feb 2020 20:33:23 +0100 Subject: [PATCH] Cleanup the data loading code --- src/data/data.cpp | 65 ++++++++++++++++++++--------------------------- src/data/data.h | 4 +-- 2 files changed, 30 insertions(+), 39 deletions(-) diff --git a/src/data/data.cpp b/src/data/data.cpp index 9e8066b1..3731b901 100644 --- a/src/data/data.cpp +++ b/src/data/data.cpp @@ -44,37 +44,37 @@ static CUPParser cup; static GPIParser gpi; static SMLParser sml; -static QHash parsers() +static QMap parsers() { - QHash hash; + QMap map; - hash.insert("gpx", &gpx); - hash.insert("tcx", &tcx); - hash.insert("kml", &kml); - hash.insert("fit", &fit); - hash.insert("csv", &csv); - hash.insert("igc", &igc); - hash.insert("nmea", &nmea); - hash.insert("plt", &plt); - hash.insert("wpt", &wpt); - hash.insert("rte", &rte); - hash.insert("loc", &loc); - hash.insert("slf", &slf); + map.insert("gpx", &gpx); + map.insert("tcx", &tcx); + map.insert("kml", &kml); + map.insert("fit", &fit); + map.insert("csv", &csv); + map.insert("igc", &igc); + map.insert("nmea", &nmea); + map.insert("plt", &plt); + map.insert("wpt", &wpt); + map.insert("rte", &rte); + map.insert("loc", &loc); + map.insert("slf", &slf); #ifdef ENABLE_GEOJSON - hash.insert("json", &geojson); - hash.insert("geojson", &geojson); + map.insert("json", &geojson); + map.insert("geojson", &geojson); #endif // ENABLE_GEOJSON - hash.insert("jpeg", &exif); - hash.insert("jpg", &exif); - hash.insert("cup", &cup); - hash.insert("gpi", &gpi); - hash.insert("sml", &sml); + map.insert("jpeg", &exif); + map.insert("jpg", &exif); + map.insert("cup", &cup); + map.insert("gpi", &gpi); + map.insert("sml", &sml); - return hash; + return map; } -QHash Data::_parsers = parsers(); +QMap Data::_parsers = parsers(); bool Data::_useDEM = false; void Data::processData(QList &trackData, QList &routeData) @@ -130,7 +130,7 @@ Data::Data(const QString &fileName, bool poi) return; } - QHash::iterator it; + QMap::iterator it; if ((it = _parsers.find(fi.suffix().toLower())) != _parsers.end()) { if (it.value()->parse(&file, trackData, routeData, _polygons, _waypoints)) { @@ -166,17 +166,8 @@ Data::Data(const QString &fileName, bool poi) QString Data::formats() { - QStringList l(filter()); - qSort(l); - QString supported; - for (int i = 0; i < l.size(); i++) { - supported += l.at(i); - if (i != l.size() - 1) - supported += " "; - } - return - qApp->translate("Data", "Supported files") + " (" + supported + ");;" + qApp->translate("Data", "Supported files") + " (" + filter().join(" ") + ");;" + qApp->translate("Data", "CSV files") + " (*.csv);;" + qApp->translate("Data", "CUP files") + " (*.cup);;" + qApp->translate("Data", "FIT files") + " (*.fit);;" @@ -200,10 +191,10 @@ QString Data::formats() QStringList Data::filter() { QStringList filter; - QHash::iterator it; - for (it = _parsers.begin(); it != _parsers.end(); it++) - filter << QString("*.%1").arg(it.key()); + for (QMap::iterator it = _parsers.begin(); + it != _parsers.end(); it++) + filter << "*." + it.key(); return filter; } diff --git a/src/data/data.h b/src/data/data.h index 48e490ee..9367efa8 100644 --- a/src/data/data.h +++ b/src/data/data.h @@ -2,7 +2,7 @@ #define DATA_H #include -#include +#include #include #include #include "waypoint.h" @@ -42,7 +42,7 @@ private: QList _polygons; QVector _waypoints; - static QHash _parsers; + static QMap _parsers; static bool _useDEM; };