forked from openbmc/openbmc
-
Notifications
You must be signed in to change notification settings - Fork 1
/
patchtest-get-branch
executable file
·81 lines (67 loc) · 2.85 KB
/
patchtest-get-branch
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
#!/usr/bin/env python3
# Get target branch from the corresponding mbox
#
# NOTE: this script was based on patches coming to the openembedded-core
# where target branch is defined inside brackets as subject prefix
# i.e. [master], [rocko], etc.
#
# Copyright (C) 2016 Intel Corporation
#
# SPDX-License-Identifier: GPL-2.0-only
#
import mailbox
import argparse
import re
import git
re_prefix = re.compile(r"(\[.*\])", re.DOTALL)
def get_branch(filepath_repo, filepath_mbox, default_branch):
branch = None
# get all remotes branches
gitbranches = git.Git(filepath_repo).branch('-a').splitlines()
# from gitbranches, just get the names
branches = [b.split('/')[-1] for b in gitbranches]
subject = ' '.join(mailbox.mbox(filepath_mbox)[0]['subject'].splitlines())
# we expect that patches will have somewhere between one and three
# consecutive sets of square brackets with tokens inside, e.g.:
# 1. [PATCH]
# 2. [OE-core][PATCH]
# 3. [OE-core][kirkstone][PATCH]
# Some of them may also be part of a series, in which case the PATCH
# token will be formatted like:
# [PATCH 1/4]
# or they will be revisions to previous patches, where it will be:
# [PATCH v2]
# Or they may contain both:
# [PATCH v2 3/4]
# In any case, we want mprefix to contain all of these tokens so
# that we can search for branch names within them.
mprefix = re.findall(r'\[.*?\]', subject)
found_branch = None
if mprefix:
# Iterate over the tokens and compare against the branch list to
# figure out which one the patch is targeting
for token in mprefix:
stripped = token.lower().strip('[]')
if default_branch in stripped:
found_branch = default_branch
break
else:
for branch in branches:
# ignore branches named "core"
if branch != "core" and stripped.rfind(branch) != -1:
found_branch = token.split(' ')[0].strip('[]')
break
# if there's no mprefix content or no known branches were found in
# the tokens, assume the target is master
if found_branch is None:
found_branch = "master"
return (subject, found_branch)
if __name__ == '__main__':
parser = argparse.ArgumentParser()
parser.add_argument('repo', metavar='REPO', help='Main repository')
parser.add_argument('mbox', metavar='MBOX', help='mbox filename')
parser.add_argument('--default-branch', metavar='DEFAULT_BRANCH', default='master', help='Use this branch if no one is found')
parser.add_argument('--separator', '-s', metavar='SEPARATOR', default=' ', help='Char separator for output data')
args = parser.parse_args()
subject, branch = get_branch(args.repo, args.mbox, args.default_branch)
print("branch: %s" % branch)