aboutsummaryrefslogtreecommitdiff
path: root/dbparse.js
diff options
context:
space:
mode:
Diffstat (limited to 'dbparse.js')
-rw-r--r--dbparse.js46
1 files changed, 23 insertions, 23 deletions
diff --git a/dbparse.js b/dbparse.js
index 7e8d8fd..f196c78 100644
--- a/dbparse.js
+++ b/dbparse.js
@@ -108,36 +108,36 @@ async function writeShift(weekday, shiftId, shiftLine, courseLine, DB)
);
// Shift contents
- const courseRegex = /(?:[a-ö]{2,3}\d{2,3} ?\+? ?)+ [a-ö]{4}/gi;
+ const courseRegex = /([A-ZÅÄÖ]{2,3}\d{2,3})(?:\+([A-ZÅÄÖ]{2,3}\d{2,3}))?(?: ([A-ZÅÄÖ]{4}))?/gi;
const courses = courseLine.matchAll(courseRegex);
for(const course of courses)
{
- const _lastSpace = course[0].lastIndexOf(" ");
- const courseNames = course[0].substring(0, _lastSpace).split(/ ?\+ ?/);
- const teacherName = course[0].substring(_lastSpace + 1);
-
- // For loop is needed, because some courses are marked like KE16+KE26 MATI
- async function handleCourse(courseName, teacherName)
- {
- let className = await DB.execute(
- "SELECT class FROM classes WHERE course=?",
- [courseName]
- );
- className = className[0];
- if (className !== undefined)
- className = className.class;
- else
- className = null;
-
+ const courseName1 = course[1];
+ const courseName2 = course[2]; // this exists if the course is like MA11+MA12 RIHO
+ const teacher = course[3] || null;
+
+ // Get the class
+ let className = await DB.execute(
+ "SELECT class FROM classes WHERE course=?",
+ [courseName]
+ );
+ if (className !== undefined)
+ className = className.class;
+ else
+ className = null;
+ className = className[0];
+
+ // Add the info
+ dbOperations.push(DB.execute(
+ `INSERT IGNORE INTO shifts VALUES (${weekday}, ${shiftId}, ?, ?, ?)`,
+ [courseName1, teacher, className]
+ ));
+ if (courseName2 !== null) {
dbOperations.push(DB.execute(
`INSERT IGNORE INTO shifts VALUES (${weekday}, ${shiftId}, ?, ?, ?)`,
- [courseName, teacherName, className]
+ [courseName2, teacher, className]
));
}
- for(const courseName of courseNames)
- {
- dbOperations.push(handleCourse(courseName, teacherName));
- }
}
await Promise.all(dbOperations);