File: common.py

package info (click to toggle)
snapd 2.71-3
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 79,536 kB
  • sloc: ansic: 16,114; sh: 16,105; python: 9,941; makefile: 1,890; exp: 190; awk: 40; xml: 22
file content (58 lines) | stat: -rwxr-xr-x 1,515 bytes parent folder | download
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
#!/usr/bin/env python3

from __future__ import annotations


class LockOpTrace:
    """
    LockOpTrace: Represents a Lock Operation trace in the log file.
    It holds the lines for the trace and allows matching against a part of
    the trace.
    """

    def __init__(self, lines: list[str]):
        self.lines = lines
        self.hash = hash(str(self))

    def get_trace_lines(self) -> list[str]:
        return self.lines

    def match(self, part: str) -> bool:
        for line in self.lines:
            if part in line:
                return True

        return False

    def print(self):
        print("-" * 20 + "TRACE" + "-" * 20)
        print("")
        print(self)
        print("")

    def __str__(self) -> str:
        return "".join(self.lines).rstrip()

    def __hash__(self) -> int:
        return self.hash

    def __eq__(self, other: object) -> bool:
        if not isinstance(other, LockOpTrace):
            # don't attempt to compare against unrelated types
            return NotImplemented

        return self.hash == other.hash


"""
Generic function used to iterate a list of strings until it is found an
element which starts with the prefix passed as parameter. The function
returns the index for the first match, and -1 in case there isn't any.
"""


def get_next_match(lines: list[str], start: int, prefix: str) -> int:
    for current_line in range(start + 1, len(lines)):
        if lines[current_line].startswith(prefix):
            return current_line
    return -1