File: changesets.py

package info (click to toggle)
thunderbird 1%3A127.0~b5-1
  • links: PTS, VCS
  • area: main
  • in suites: experimental
  • size: 4,421,808 kB
  • sloc: cpp: 7,379,480; javascript: 5,568,142; ansic: 3,852,317; python: 1,221,238; xml: 620,984; asm: 456,308; java: 179,035; sh: 118,742; makefile: 21,918; perl: 14,823; objc: 12,399; yacc: 4,583; pascal: 2,973; lex: 1,720; ruby: 1,190; exp: 762; sql: 666; awk: 580; php: 436; lisp: 430; sed: 70; csh: 10
file content (66 lines) | stat: -rw-r--r-- 1,777 bytes parent folder | download | duplicates (25)
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
from __future__ import annotations
from typing import Set, Tuple, TypedDict

import time

from .blame import BlameResult

Changes = Set[Tuple[str, str]]


class Changeset(TypedDict):
    author: str
    first_commit: float
    changes: Changes


def by_first_commit(item: Changeset):
    """Order two changesets by their first commit date."""
    return item["first_commit"]


def convert_blame_to_changesets(blame_json: BlameResult) -> list[Changeset]:
    """Convert a blame dict into a list of changesets.

    The blame information in `blame_json` should be a dict of the following
    structure:

        {
            'authors': [
                'A.N. Author <author@example.com>',
            ],
            'blame': {
                'path/one': {
                    'key1': [0, 1346095921.0],
                },
            }
        }

    It will be transformed into a list of changesets which can be fed into
    `InternalContext.serialize_changeset`:

        [
            {
                'author': 'A.N. Author <author@example.com>',
                'first_commit': 1346095921.0,
                'changes': {
                    ('path/one', 'key1'),
                }
            },
        ]

    """
    now = time.time()
    changesets: list[Changeset] = [
        {"author": author, "first_commit": now, "changes": set()}
        for author in blame_json["authors"]
    ]

    for path, keys_info in blame_json["blame"].items():
        for key, (author_index, timestamp) in keys_info.items():
            changeset = changesets[author_index]
            changeset["changes"].add((path, key))
            if timestamp < changeset["first_commit"]:
                changeset["first_commit"] = timestamp

    return sorted(changesets, key=by_first_commit)