Merge remote-tracking branch 'origin/master' into develop
This commit is contained in:
commit
0786314bfb
1 changed files with 49 additions and 34 deletions
|
@ -1,9 +1,9 @@
|
||||||
# Copyright 2023 Nick Brassel (@tzarc)
|
# Copyright 2023 Nick Brassel (@tzarc)
|
||||||
# SPDX-License-Identifier: GPL-2.0-or-later
|
# SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
import re
|
import re
|
||||||
from pathlib import Path
|
|
||||||
from milc import cli
|
from milc import cli
|
||||||
from qmk.constants import LICENSE_TEXTS
|
from qmk.constants import LICENSE_TEXTS
|
||||||
|
from qmk.path import normpath
|
||||||
|
|
||||||
L_PAREN = re.compile(r'\(\[\{\<')
|
L_PAREN = re.compile(r'\(\[\{\<')
|
||||||
R_PAREN = re.compile(r'\)\]\}\>')
|
R_PAREN = re.compile(r'\)\]\}\>')
|
||||||
|
@ -27,7 +27,45 @@ def _simplify_text(input):
|
||||||
return ' '.join(lines)
|
return ' '.join(lines)
|
||||||
|
|
||||||
|
|
||||||
def _detect_license_from_file_contents(filename, absolute=False):
|
def _preformat_license_texts():
|
||||||
|
# Pre-format all the licenses
|
||||||
|
for _, long_licenses in LICENSE_TEXTS:
|
||||||
|
for i in range(len(long_licenses)):
|
||||||
|
long_licenses[i] = _simplify_text(long_licenses[i])
|
||||||
|
|
||||||
|
|
||||||
|
def _determine_suffix_condition(extensions):
|
||||||
|
def _default_suffix_condition(s):
|
||||||
|
return s in SUFFIXES
|
||||||
|
|
||||||
|
conditional = _default_suffix_condition
|
||||||
|
|
||||||
|
if extensions is not None and len(extensions) > 0:
|
||||||
|
suffixes = [f'.{s}' if not s.startswith('.') else s for s in extensions]
|
||||||
|
|
||||||
|
def _specific_suffix_condition(s):
|
||||||
|
return s in suffixes
|
||||||
|
|
||||||
|
conditional = _specific_suffix_condition
|
||||||
|
|
||||||
|
return conditional
|
||||||
|
|
||||||
|
|
||||||
|
def _determine_file_list(inputs, conditional):
|
||||||
|
check_list = set()
|
||||||
|
for filename in inputs:
|
||||||
|
if filename.is_dir():
|
||||||
|
for file in sorted(filename.rglob('*')):
|
||||||
|
if file.is_file() and conditional(file.suffix):
|
||||||
|
check_list.add(file)
|
||||||
|
elif filename.is_file():
|
||||||
|
if conditional(filename.suffix):
|
||||||
|
check_list.add(filename)
|
||||||
|
|
||||||
|
return list(sorted(check_list))
|
||||||
|
|
||||||
|
|
||||||
|
def _detect_license_from_file_contents(filename, absolute=False, short=False):
|
||||||
data = filename.read_text(encoding='utf-8', errors='ignore')
|
data = filename.read_text(encoding='utf-8', errors='ignore')
|
||||||
filename_out = str(filename.absolute()) if absolute else str(filename)
|
filename_out = str(filename.absolute()) if absolute else str(filename)
|
||||||
|
|
||||||
|
@ -42,13 +80,13 @@ def _detect_license_from_file_contents(filename, absolute=False):
|
||||||
break
|
break
|
||||||
|
|
||||||
if not found:
|
if not found:
|
||||||
if cli.args.short:
|
if short:
|
||||||
print(f'{filename_out} UNKNOWN')
|
print(f'{filename_out} UNKNOWN')
|
||||||
else:
|
else:
|
||||||
cli.log.error(f'{{fg_cyan}}{filename_out}{{fg_reset}} -- unknown license, or no license detected!')
|
cli.log.error(f'{{fg_cyan}}{filename_out}{{fg_reset}} -- unknown license, or no license detected!')
|
||||||
return False
|
return False
|
||||||
|
|
||||||
if cli.args.short:
|
if short:
|
||||||
print(f'{filename_out} {license}')
|
print(f'{filename_out} {license}')
|
||||||
else:
|
else:
|
||||||
cli.log.info(f'{{fg_cyan}}{filename_out}{{fg_reset}} -- license detected: {license} (SPDX License Identifier)')
|
cli.log.info(f'{{fg_cyan}}{filename_out}{{fg_reset}} -- license detected: {license} (SPDX License Identifier)')
|
||||||
|
@ -59,13 +97,13 @@ def _detect_license_from_file_contents(filename, absolute=False):
|
||||||
for short_license, long_licenses in LICENSE_TEXTS:
|
for short_license, long_licenses in LICENSE_TEXTS:
|
||||||
for long_license in long_licenses:
|
for long_license in long_licenses:
|
||||||
if long_license in simple_text:
|
if long_license in simple_text:
|
||||||
if cli.args.short:
|
if short:
|
||||||
print(f'{filename_out} {short_license}')
|
print(f'{filename_out} {short_license}')
|
||||||
else:
|
else:
|
||||||
cli.log.info(f'{{fg_cyan}}{filename_out}{{fg_reset}} -- license detected: {short_license} (Full text)')
|
cli.log.info(f'{{fg_cyan}}{filename_out}{{fg_reset}} -- license detected: {short_license} (Full text)')
|
||||||
return True
|
return True
|
||||||
|
|
||||||
if cli.args.short:
|
if short:
|
||||||
print(f'{filename_out} UNKNOWN')
|
print(f'{filename_out} UNKNOWN')
|
||||||
else:
|
else:
|
||||||
cli.log.error(f'{{fg_cyan}}{filename_out}{{fg_reset}} -- unknown license, or no license detected!')
|
cli.log.error(f'{{fg_cyan}}{filename_out}{{fg_reset}} -- unknown license, or no license detected!')
|
||||||
|
@ -73,43 +111,20 @@ def _detect_license_from_file_contents(filename, absolute=False):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
|
||||||
@cli.argument('inputs', nargs='*', arg_only=True, type=Path, help='List of input files or directories.')
|
@cli.argument('inputs', nargs='*', arg_only=True, type=normpath, help='List of input files or directories.')
|
||||||
@cli.argument('-s', '--short', action='store_true', help='Short output.')
|
@cli.argument('-s', '--short', action='store_true', help='Short output.')
|
||||||
@cli.argument('-a', '--absolute', action='store_true', help='Print absolute paths.')
|
@cli.argument('-a', '--absolute', action='store_true', help='Print absolute paths.')
|
||||||
@cli.argument('-e', '--extension', arg_only=True, action='append', default=[], help='Override list of extensions. Can be specified multiple times for multiple extensions.')
|
@cli.argument('-e', '--extension', arg_only=True, action='append', default=[], help='Override list of extensions. Can be specified multiple times for multiple extensions.')
|
||||||
@cli.subcommand('File license check.', hidden=False if cli.config.user.developer else True)
|
@cli.subcommand('File license check.', hidden=False if cli.config.user.developer else True)
|
||||||
def license_check(cli):
|
def license_check(cli):
|
||||||
def _default_suffix_condition(s):
|
_preformat_license_texts()
|
||||||
return s in SUFFIXES
|
|
||||||
|
|
||||||
conditional = _default_suffix_condition
|
conditional = _determine_suffix_condition(cli.args.extension)
|
||||||
|
check_list = _determine_file_list(cli.args.inputs, conditional)
|
||||||
if len(cli.args.extension) > 0:
|
|
||||||
suffixes = [f'.{s}' if not s.startswith('.') else s for s in cli.args.extension]
|
|
||||||
|
|
||||||
def _specific_suffix_condition(s):
|
|
||||||
return s in suffixes
|
|
||||||
|
|
||||||
conditional = _specific_suffix_condition
|
|
||||||
|
|
||||||
# Pre-format all the licenses
|
|
||||||
for _, long_licenses in LICENSE_TEXTS:
|
|
||||||
for i in range(len(long_licenses)):
|
|
||||||
long_licenses[i] = _simplify_text(long_licenses[i])
|
|
||||||
|
|
||||||
check_list = set()
|
|
||||||
for filename in sorted(cli.args.inputs):
|
|
||||||
if filename.is_dir():
|
|
||||||
for file in sorted(filename.rglob('*')):
|
|
||||||
if file.is_file() and conditional(file.suffix):
|
|
||||||
check_list.add(file)
|
|
||||||
elif filename.is_file():
|
|
||||||
if conditional(filename.suffix):
|
|
||||||
check_list.add(filename)
|
|
||||||
|
|
||||||
failed = False
|
failed = False
|
||||||
for filename in sorted(check_list):
|
for filename in sorted(check_list):
|
||||||
if not _detect_license_from_file_contents(filename, absolute=cli.args.absolute):
|
if not _detect_license_from_file_contents(filename, absolute=cli.args.absolute, short=cli.args.short):
|
||||||
failed = True
|
failed = True
|
||||||
|
|
||||||
if failed:
|
if failed:
|
||||||
|
|
Loading…
Reference in a new issue