Files
StorytellersBestFriend/sbf-cpp/Ranks.cpp

38 lines
816 B
C++

#include "Ranks.h"
#include <ostream>
#include <string>
#include <vector>
namespace SBF {
using std::string;
using std::vector;
std::ostream& operator<<(std::ostream& os, const RankType& rank) {
os << "Rank: {id: " << rank.id << ", label: \"" << rank.label << "\"}";
return os;
}
bool operator==(const RankType& left, const RankType& right) {
return left.id == right.id && left.label == right.label;
}
bool operator!=(const RankType& left, const RankType& right) {
return !(left == right);
}
RankType GetRank(int rankId) {
if (rankId > 0 && rankId <= kRanksCount) {
return kRanks[rankId];
}
return kRankUnknown;
}
void FillRanks(std::vector<RankType>& ranks) {
ranks.clear();
for (int id = 1; id <= kRanksCount; id++) {
ranks.push_back(GetRank(id));
}
}
} // End namespace SBF