-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathutil.cpp
62 lines (57 loc) · 2.08 KB
/
util.cpp
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
56
57
58
59
60
61
62
//
// Created by eric on 13/06/22.
//
#include "util.h"
namespace util {
std::vector<std::string> getObjCols(char type) {
static std::vector<std::string> courseObjCols = {
"requisites",
"corequisites",
"additionalRequirements",
"class",
"assessment",
"belongsTo",
};
static std::vector<std::string> planObjCols = {
"modules",
};
if (type == 'c') return courseObjCols;
else return planObjCols;
}
crow::json::wvalue select(SQLite::Statement& query, char type) {
std::vector<crow::json::wvalue> rows = {};
int columnNum = query.getColumnCount();
std::vector<std::string> objCols = getObjCols(type);
while (query.executeStep()) {
auto row = crow::json::wvalue();
for (int i = 0; i < columnNum; i++) {
std::string columnName = query.getColumnName(i);
if (std::find(objCols.begin(), objCols.end(), columnName) != objCols.end()) {
row[columnName] = crow::json::load(query.getColumn(i).getString());
}
else {
row[columnName] = query.getColumn(i).getString();
}
}
rows.push_back(row);
}
return rows;
}
crow::json::wvalue selectOne(SQLite::Statement& query, char type) {
int columnNum = query.getColumnCount();
auto row = crow::json::wvalue();
std::vector<std::string> objCols = getObjCols(type);
if (query.executeStep()) {
for (int i = 0; i < columnNum; i++) {
std::string columnName = query.getColumnName(i);
if (std::find(objCols.begin(), objCols.end(), columnName) != objCols.end()) {
row[columnName] = crow::json::load(query.getColumn(i).getString());
}
else {
row[columnName] = query.getColumn(i).getString();
}
}
}
return row;
}
} // util