From ff05614404d55e64c1b5d77917966228ba89d4ed Mon Sep 17 00:00:00 2001 From: N08I40K Date: Wed, 16 Apr 2025 16:21:18 +0400 Subject: [PATCH] =?UTF-8?q?=D0=98=D1=81=D0=BF=D1=80=D0=B0=D0=B2=D0=BB?= =?UTF-8?q?=D0=B5=D0=BD=D0=B8=D0=B5=20=D0=BE=D0=B1=D1=80=D0=B0=D0=B1=D0=BE?= =?UTF-8?q?=D1=82=D0=BA=D0=B8=20=D0=B2=D1=80=D0=B5=D0=BC=D0=B5=D0=BD=D0=B8?= =?UTF-8?q?=20=D1=83=20=D0=BF=D0=B0=D1=80.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/parser/mod.rs | 42 ++++++++++++++++++++++-------------------- 1 file changed, 22 insertions(+), 20 deletions(-) diff --git a/src/parser/mod.rs b/src/parser/mod.rs index f72fb2b..04781dc 100644 --- a/src/parser/mod.rs +++ b/src/parser/mod.rs @@ -1,12 +1,12 @@ -use crate::parser::LessonParseResult::{Lessons, Street}; use crate::parser::schema::LessonType::Break; use crate::parser::schema::{ Day, Lesson, LessonSubGroup, LessonTime, LessonType, ParseError, ParseResult, ScheduleEntry, }; -use calamine::{Reader, Xls, open_workbook_from_rs}; -use chrono::{Duration, NaiveDateTime}; -use fuzzy_matcher::FuzzyMatcher; +use crate::parser::LessonParseResult::{Lessons, Street}; +use calamine::{open_workbook_from_rs, Reader, Xls}; +use chrono::{DateTime, Duration, NaiveDateTime, Utc}; use fuzzy_matcher::skim::SkimMatcherV2; +use fuzzy_matcher::FuzzyMatcher; use regex::Regex; use std::collections::HashMap; use std::io::Cursor; @@ -557,20 +557,20 @@ fn convert_groups_to_teachers( } /// Reading XLS Document from the buffer and converting it into the schedule ready to use. -/// -/// # Arguments -/// +/// +/// # Arguments +/// /// * `buffer`: XLS data containing schedule. -/// -/// returns: Result -/// -/// # Examples -/// +/// +/// returns: Result +/// +/// # Examples +/// /// ``` /// let result = parse_xls(&include_bytes!("../../schedule.xls").to_vec()); -/// +/// /// assert!(result.is_ok()); -/// +/// /// assert_ne!(result.as_ref().unwrap().groups.len(), 0); /// assert_ne!(result.as_ref().unwrap().teachers.len(), 0); /// ``` @@ -674,13 +674,15 @@ pub fn parse_xls(buffer: &Vec) -> Result { let end_match = parse_res.get(2).unwrap().as_str(); let end_parts: Vec<&str> = end_match.split(".").collect(); + static GET_TIME: fn(DateTime, &Vec<&str>) -> DateTime = + |date, parts| { + date + Duration::hours(parts[0].parse::().unwrap() - 4) + + Duration::minutes(parts[1].parse::().unwrap()) + }; + LessonTime { - start: day.date.clone() - + Duration::hours(start_parts[0].parse().unwrap()) - + Duration::minutes(start_parts[1].parse().unwrap()), - end: day.date.clone() - + Duration::hours(end_parts[0].parse().unwrap()) - + Duration::minutes(end_parts[1].parse().unwrap()), + start: GET_TIME(day.date.clone(), &start_parts), + end: GET_TIME(day.date.clone(), &end_parts), } };