aboutsummaryrefslogtreecommitdiff
path: root/utils.py
blob: 2de7ef0576b4024d3510a9daf3a08cf85d85e58e (plain)
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
63
64
65
66
67
68
69
70
71
72
73
#    Copyright (C) 2017  Alban Gruin
#
#    celcatsanitizer is free software; you can redistribute it and/or modify
#    it under the terms of the GNU General Public License as published by
#    the Free Software Foundation; either version 2 of the License, or
#    (at your option) any later version.
#
#    celcatsanitizer is distributed in the hope that it will be useful,
#    but WITHOUT ANY WARRANTY; without even the implied warranty of
#    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
#    GNU General Public License for more details.
#
#    You should have received a copy of the GNU General Public License along
#    with celcatsanitizer; if not, write to the Free Software Foundation, Inc.,
#    51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

from django.utils import timezone

import datetime
import re

def get_current_week():
    return timezone.now().isocalendar()[:2]

def get_current_or_next_week():
    year, week, day = timezone.now().isocalendar()
    if day >= 6:
        year, week, _ = (timezone.now() + datetime.timedelta(weeks=1)).isocalendar()

    return year, week

def get_week(year, week):
    start = timezone.make_aware(datetime.datetime.strptime(
        "{0}-W{1:02d}-1".format(year, week), "%Y-W%W-%w"))
    end = start + datetime.timedelta(weeks=1)

    return start, end

def group_courses(courses):
    grouped_courses = []
    for i, course in enumerate(courses):
        if i == 0 or courses[i - 1].begin.day != course.begin.day:
            grouped_courses.append([course])
        else:
            grouped_courses[-1].append(course)

    return grouped_courses

def parse_group(name):
    # Explication de la regex
    #
    # ^(.+?)\s*\-\s*(((CM)(\w))|((TD)(\w)(\d))|((TP)(\w)(\d)(\d)))$
    # ^                                                              début de la ligne
    #  (.+?)                                                         correspond à au moins un caractère
    #       \s*                                                      au moins un espace
    #          \-                                                    un tiret
    #            \s*                                                 au moins un espace
    #               (((CM)(\w))|                                     correspond à CM suivi d'une lettre ou...
    #                           ((TD)(\w)(\d))|                      ... à TD suivi d'une lettre et d'un chiffre ou...
    #                                          ((TP)(\w)(\d)(\d)))   ... à TP suivi d'une lettre et de deux chiffres
    #                                                             $  fin de la ligne
    group_regex = re.compile("^(.+?)\s*\-\s*(((CM)(\w))|((TD)(\w)(\d))|((TP)(\w)(\d)(\d)))$")
    search = group_regex.search(name)
    if search is None:
        return None, None, None, None

    parts = search.groups(0)
    if parts[3] == "CM":
        return parts[0], parts[4], None, None
    elif parts[6] == "TD":
        return parts[0], parts[7], parts[8], None
    elif parts[10] == "TP":
        return parts[0], parts[11], parts[12], parts[13]