Skip to content

Commit

Permalink
Merge pull request #6821 from gilles-peskine-arm/code-style-skip-gene…
Browse files Browse the repository at this point in the history
…rated-files-2.28

Backport 2.28: Don't touch the style of generated files
  • Loading branch information
mpg authored Dec 19, 2022
2 parents 910222b + 4ca54d4 commit 71e934f
Show file tree
Hide file tree
Showing 2 changed files with 37 additions and 5 deletions.
37 changes: 32 additions & 5 deletions scripts/code_style.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,20 +22,44 @@
import argparse
import io
import os
import re
import subprocess
import sys
from typing import List
from typing import FrozenSet, List

UNCRUSTIFY_SUPPORTED_VERSION = "0.75.1"
CONFIG_FILE = ".uncrustify.cfg"
UNCRUSTIFY_EXE = "uncrustify"
UNCRUSTIFY_ARGS = ["-c", CONFIG_FILE]
STDOUT_UTF8 = io.TextIOWrapper(sys.stdout.buffer, encoding='utf-8')
STDERR_UTF8 = io.TextIOWrapper(sys.stderr.buffer, encoding='utf-8')
CHECK_GENERATED_FILES = "tests/scripts/check-generated-files.sh"

def print_err(*args):
print("Error: ", *args, file=STDERR_UTF8)

# Match FILENAME(s) in "check SCRIPT (FILENAME...)"
CHECK_CALL_RE = re.compile(r"\n\s*check\s+[^\s#$&*?;|]+([^\n#$&*?;|]+)",
re.ASCII)
def list_generated_files() -> FrozenSet[str]:
"""Return the names of generated files.
We don't reformat generated files, since the result might be different
from the output of the generator. Ideally the result of the generator
would conform to the code style, but this would be difficult, especially
with respect to the placement of line breaks in long logical lines.
"""
# Parse check-generated-files.sh to get an up-to-date list of
# generated files. Read the file rather than calling it so that
# this script only depends on Git, Python and uncrustify, and not other
# tools such as sh or grep which might not be available on Windows.
# This introduces a limitation: check-generated-files.sh must have
# the expected format and must list the files explicitly, not through
# wildcards or command substitution.
content = open(CHECK_GENERATED_FILES, encoding="utf-8").read()
checks = re.findall(CHECK_CALL_RE, content)
return frozenset(word for s in checks for word in s.split())

def get_src_files() -> List[str]:
"""
Use git ls-files to get a list of the source files
Expand All @@ -52,11 +76,14 @@ def get_src_files() -> List[str]:
print_err("git ls-files returned: " + str(result.returncode))
return []
else:
generated_files = list_generated_files()
src_files = str(result.stdout, "utf-8").split()
# Don't correct style for files in 3rdparty/
src_files = list(filter( \
lambda filename: not filename.startswith("3rdparty/"), \
src_files))
# Don't correct style for third-party files (and, for simplicity,
# companion files in the same subtree), or for automatically
# generated files (we're correcting the templates instead).
src_files = [filename for filename in src_files
if not (filename.startswith("3rdparty/") or
filename in generated_files)]
return src_files

def get_uncrustify_version() -> str:
Expand Down
5 changes: 5 additions & 0 deletions tests/scripts/check-generated-files.sh
Original file line number Diff line number Diff line change
Expand Up @@ -102,6 +102,11 @@ check()
fi
}

# Note: if the format of calls to the "check" function changes, update
# scripts/code_style.py accordingly. For generated C source files (*.h or *.c),
# the format must be "check SCRIPT FILENAME...". For other source files,
# any shell syntax is permitted (including e.g. command substitution).

check scripts/generate_errors.pl library/error.c
check scripts/generate_query_config.pl programs/test/query_config.c
check scripts/generate_features.pl library/version_features.c
Expand Down

0 comments on commit 71e934f

Please sign in to comment.