-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathNamesOldLoader.hpp
55 lines (52 loc) · 1.66 KB
/
NamesOldLoader.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
#pragma once
#include <vector>
#include <iostream>
#include <QMap>
#include <QString>
class NamesOldLoader
{
public:
struct StarName
{
int HIP;
QString englishName;
QString nativeName;
QString pronounce;
QString translatorsComments;
std::vector<int> references;
};
struct DSOName
{
QString id;
QString englishName;
QString nativeName;
QString pronounce;
QString translatorsComments;
std::vector<int> references;
};
struct PlanetName
{
QString id;
QString english;
QString native;
QString translatorsComments;
};
void load(const QString& skyCultureDir, const QString& nativeLocale, bool convertUntranslatableNamesToNative);
const StarName* findStar(QString const& englishName) const;
const DSOName* findDSO(QString const& englishName) const;
const PlanetName* findPlanet(QString const& englishName) const;
bool dumpJSON(std::ostream& s) const;
auto starsBegin() const { return starNames.cbegin(); }
auto starsEnd() const { return starNames.cend(); }
auto planetsBegin() const { return planetNames.cbegin(); }
auto planetsEnd() const { return planetNames.cend(); }
auto dsosBegin() const { return dsoNames.cbegin(); }
auto dsosEnd() const { return dsoNames.cend(); }
private:
void loadStarNames(const QString& skyCultureDir, const QString& nativeLocale, bool convertUntranslatableNamesToNative);
void loadDSONames(const QString& skyCultureDir, const QString& nativeLocale, bool convertUntranslatableNamesToNative);
void loadPlanetNames(const QString& skyCultureDir);
QMap<int/*HIP*/, std::vector<StarName>> starNames;
QMap<QString/*dsoId*/,std::vector<DSOName>> dsoNames;
QMap<QString/*planetId*/,std::vector<PlanetName>> planetNames;
};