summaryrefslogtreecommitdiff
path: root/util.py
blob: 76cb182054f968b57de9418f66c3648be6bb49f3 (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
import logging
import re


class Logger():
    _instance = None

    def __new__(cls, fileName="VG101GradeHelper.log", loggerName="myLogger"):
        if cls._instance is None:
            logger = logging.getLogger(loggerName)
            formatter = logging.Formatter(
                '[%(asctime)s][%(levelname)8s][%(filename)s %(lineno)3s]%(message)s'
            )
            logger.setLevel(logging.DEBUG)
            streamHandler = logging.StreamHandler()
            streamHandler.setFormatter(formatter)
            streamHandler.setLevel(logging.WARNING)
            fileHandler = logging.FileHandler(filename=fileName)
            fileHandler.setFormatter(formatter)
            fileHandler.setLevel(logging.DEBUG)
            logger.addHandler(fileHandler)
            logger.addHandler(streamHandler)
            cls._instance = logger
        return cls._instance


def first(iterable, condition=lambda x: True):
    try:
        return next(x for x in iterable if condition(x))
    except StopIteration:
        return None


def getProjRepoName(arg):
    id_, name, projNum, *_ = arg
    eng = re.sub('[\u4e00-\u9fa5]', '', name)
    eng = ''.join([word[0].capitalize() + word[1:] for word in eng.split()])
    return f"{eng}{id_}-p{projNum}"


def passCodeQuality(path, language):
    with open(path, encoding='utf-8', errors='replace') as f:
        res = f.read()
    if language == "matlab":
        return "global " not in res