2019-10-31 13:42:52 +00:00
|
|
|
#!/usr/bin/env python3
|
2018-05-06 21:58:06 +00:00
|
|
|
# SPDX-License-Identifier: GPL-2.0+
|
2012-01-14 15:12:45 +00:00
|
|
|
#
|
|
|
|
# Copyright (c) 2011 The Chromium OS Authors.
|
|
|
|
#
|
|
|
|
|
|
|
|
"""See README for more information"""
|
|
|
|
|
2023-04-22 14:42:48 +00:00
|
|
|
try:
|
2023-11-04 16:25:24 +00:00
|
|
|
from importlib import resources
|
2023-04-22 14:42:48 +00:00
|
|
|
except ImportError:
|
|
|
|
# for Python 3.6
|
2023-11-04 16:25:24 +00:00
|
|
|
import importlib_resources as resources
|
2012-01-14 15:12:45 +00:00
|
|
|
import os
|
|
|
|
import re
|
|
|
|
import sys
|
2020-07-06 03:41:59 +00:00
|
|
|
import traceback
|
2012-01-14 15:12:45 +00:00
|
|
|
|
2023-11-04 16:25:22 +00:00
|
|
|
# Allow 'from patman import xxx to work'
|
|
|
|
# pylint: disable=C0413
|
|
|
|
our_path = os.path.dirname(os.path.realpath(__file__))
|
|
|
|
sys.path.append(os.path.join(our_path, '..'))
|
2020-04-18 00:08:52 +00:00
|
|
|
|
2012-01-14 15:12:45 +00:00
|
|
|
# Our modules
|
2023-11-04 16:25:20 +00:00
|
|
|
from patman import cmdline
|
2020-07-06 03:41:49 +00:00
|
|
|
from patman import control
|
2023-02-24 01:18:04 +00:00
|
|
|
from u_boot_pylib import terminal
|
|
|
|
from u_boot_pylib import test_util
|
|
|
|
from u_boot_pylib import tools
|
2012-01-14 15:12:45 +00:00
|
|
|
|
|
|
|
|
2023-11-04 16:25:21 +00:00
|
|
|
def run_patman():
|
|
|
|
"""Run patamn
|
|
|
|
|
|
|
|
This is the main program. It collects arguments and runs either the tests or
|
|
|
|
the control module.
|
|
|
|
"""
|
|
|
|
args = cmdline.parse_args()
|
|
|
|
|
|
|
|
if not args.debug:
|
|
|
|
sys.tracebacklimit = 0
|
|
|
|
|
|
|
|
# Run our meagre tests
|
|
|
|
if args.cmd == 'test':
|
2023-11-04 16:25:22 +00:00
|
|
|
# pylint: disable=C0415
|
2023-11-04 16:25:21 +00:00
|
|
|
from patman import func_test
|
|
|
|
from patman import test_checkpatch
|
|
|
|
|
|
|
|
result = test_util.run_test_suites(
|
|
|
|
'patman', False, False, False, None, None, None,
|
|
|
|
[test_checkpatch.TestPatch, func_test.TestFunctional,
|
|
|
|
'gitutil', 'settings'])
|
|
|
|
|
|
|
|
sys.exit(0 if result.wasSuccessful() else 1)
|
|
|
|
|
|
|
|
# Process commits, produce patches files, check them, email them
|
|
|
|
elif args.cmd == 'send':
|
|
|
|
# Called from git with a patch filename as argument
|
|
|
|
# Printout a list of additional CC recipients for this patch
|
|
|
|
if args.cc_cmd:
|
2023-11-04 16:25:22 +00:00
|
|
|
re_line = re.compile(r'(\S*) (.*)')
|
|
|
|
with open(args.cc_cmd, 'r', encoding='utf-8') as inf:
|
|
|
|
for line in inf.readlines():
|
|
|
|
match = re_line.match(line)
|
|
|
|
if match and match.group(1) == args.patchfiles[0]:
|
|
|
|
for cca in match.group(2).split('\0'):
|
|
|
|
cca = cca.strip()
|
|
|
|
if cca:
|
|
|
|
print(cca)
|
2023-11-04 16:25:21 +00:00
|
|
|
|
|
|
|
elif args.full_help:
|
2023-11-04 16:25:24 +00:00
|
|
|
with resources.path('patman', 'README.rst') as readme:
|
2023-11-04 16:25:21 +00:00
|
|
|
tools.print_full_help(str(readme))
|
|
|
|
else:
|
|
|
|
# If we are not processing tags, no need to warning about bad ones
|
|
|
|
if not args.process_tags:
|
|
|
|
args.ignore_bad_tags = True
|
|
|
|
control.send(args)
|
|
|
|
|
|
|
|
# Check status of patches in patchwork
|
|
|
|
elif args.cmd == 'status':
|
|
|
|
ret_code = 0
|
|
|
|
try:
|
|
|
|
control.patchwork_status(args.branch, args.count, args.start, args.end,
|
|
|
|
args.dest_branch, args.force,
|
|
|
|
args.show_comments, args.patchwork_url)
|
2023-11-04 16:25:22 +00:00
|
|
|
except Exception as exc:
|
|
|
|
terminal.tprint(f'patman: {type(exc).__name__}: {exc}',
|
2023-11-04 16:25:21 +00:00
|
|
|
colour=terminal.Color.RED)
|
|
|
|
if args.debug:
|
|
|
|
print()
|
|
|
|
traceback.print_exc()
|
|
|
|
ret_code = 1
|
|
|
|
sys.exit(ret_code)
|
|
|
|
|
|
|
|
|
|
|
|
if __name__ == "__main__":
|
|
|
|
sys.exit(run_patman())
|