File: value_with_trace.py

package info (click to toggle)
crazy-complete 0.3.6-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 2,404 kB
  • sloc: python: 7,949; sh: 4,636; makefile: 74
file content (44 lines) | stat: -rw-r--r-- 1,485 bytes parent folder | download | duplicates (2)
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
'''Value holder class with line and column information'''


class ValueWithTrace:
    '''Represents a value from a configuration file along with its metadata.

    This class is used to associate a value from a YAML or JSON file with its
    source, line number, and column number. It is particularly useful for
    debugging and error reporting, as it provides precise location information
    for the value in the original configuration file.

    Attributes:
        value (Any): The value extracted from the configuration file.
        src (str): The source of the configuration file.
        line (int): The line number of the value in the source.
        column (int): The column number of the value in the source.
    '''

    def __init__(self, value, source, line, column):
        self.value = value
        self.source = source
        self.line = line
        self.column = column

    @staticmethod
    def from_yaml_event(value, source, event):
        '''Constructs a `ValueWithTrace` from a YAML event object.'''

        return ValueWithTrace(value, source,
            event.start_mark.line + 1, event.start_mark.column + 1)

    def get_position_string(self):
        '''Return a string describing the position of the value.'''

        return f'line {self.line}, column {self.column}'

    def __hash__(self):
        return hash(self.value)

    def __eq__(self, other):
        return self.value == other

    def __repr__(self):
        return f'{self.value!r}'