forked from google/civics_cdf_validator
/
loggers.py
94 lines (65 loc) · 2.48 KB
/
loggers.py
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
"""Copyright 2020 Google Inc.
All Rights Reserved.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
"""
# pylint: disable=g-bad-exception-name
class ElectionException(Exception):
"""Base class for all the errors in this script."""
error_message = None
description = None
error_log = []
def __init__(self, message):
super(ElectionException, self).__init__()
self.error_message = message
def __str__(self):
return repr(self.error_message)
class ElectionError(ElectionException):
"""An error that prevents the feed from being processed successfully."""
description = "Error"
def __init__(self, message, error_log=None):
super(ElectionError, self).__init__(message)
if error_log:
self.error_log = error_log
class ElectionTreeError(ElectionError):
"""Special exception for Tree Rules."""
def __init__(self, message, error_log):
super(ElectionTreeError, self).__init__(message)
self.error_log = error_log
# pylint: disable=g-bad-exception-name
class ElectionWarning(ElectionException):
"""An issue that should be fixed.
It will not stop the feed from being successfully processed but may lead to
undefined errors.
"""
description = "Warning"
def __init__(self, message, warning_log=None):
super(ElectionWarning, self).__init__(message)
if warning_log:
self.error_log = warning_log
# pylint: disable=g-bad-exception-name
class ElectionInfo(ElectionException):
"""Information that user needs to know about following XML best practices."""
description = "Info"
def __init__(self, message, error_log=None):
super(ElectionInfo, self).__init__(message)
if error_log:
self.error_log = error_log
class ElectionTreeInfo(ElectionInfo):
"""Special exception for Tree Rules."""
def __init__(self, message, error_log):
super(ElectionTreeInfo, self).__init__(message)
self.error_log = error_log
class ErrorLogEntry(object):
line = None
message = None
def __init__(self, line, message):
self.line = line
self.message = message