lint: Convert lint-include-guards.sh to Python #24902
pull brydinh wants to merge 1 commits into bitcoin:master from brydinh:24783-port-lint-script-to-python changing 2 files +100 −30-
brydinh commented at 10:04 pm on April 17, 2022: contributorThis PR addresses issue 24783. Converted lint-include-guards.sh to python.
-
DrahtBot added the label Tests on Apr 17, 2022
-
theStack commented at 4:35 pm on April 18, 2022: member
Concept ACK
Note that there is currently a linter error in the CI:
0Traceback (most recent call last): 1 File "test/lint/lint-include-guards.py", line 88, in <module> 2 main() 3 File "test/lint/lint-include-guards.py", line 71, in main 4 header_file_contents_string = open(header_file, 'r').read() 5 File "/usr/lib/python3.6/encodings/ascii.py", line 26, in decode 6 return codecs.ascii_decode(input, self.errors)[0] 7UnicodeDecodeError: 'ascii' codec can't decode byte 0xce in position 2003: ordinal not in range(128) 8^---- failure generated from test/lint/lint-include-guards.py 9Python's open(...) seems to be used to open text files without explicitly 10specifying encoding="utf8": 11 12test/lint/lint-include-guards.py: header_file_contents_string = open(header_file, 'r').read() 13^---- failure generated from test/lint/lint-python-utf8-encoding.sh 14Success: no issues found in 236 source files
-
in test/lint/lint-include-guards.py:71 in 657d0d654d outdated
66+ for header_file in header_file_lst: 67+ header_id = _get_header_id(header_file) 68+ 69+ regex_pattern = f'#(ifndef|define|endif //) {header_id}' 70+ 71+ header_file_contents_string = open(header_file, 'r').read()
brunoerg commented at 6:55 pm on April 18, 2022:I prefer to open files usingwith
, it ensures that the file will be closed at the end of the operation.
brydinh commented at 9:21 pm on April 18, 2022:Good catch!KevinMusgrave commented at 2:26 am on April 20, 2022: contributorI tested ea3e7abc45730e7a6eb1e840c6fa40780b3dee2f by commenting out the include guard in
bench/bench.h
and got the following results:Before (
test/lint/lint-include-guards.sh
):0src/bench/bench.h seems to be missing the expected include guard: 1 #ifndef BITCOIN_BENCH_BENCH_H 2 #define BITCOIN_BENCH_BENCH_H 3 ... 4 #endif // BITCOIN_BENCH_BENCH_H
After (
test/lint/lint-include-guards.py
): The test passesIf I delete (rather than comment out) the include guard, then it prints the correct message.
in test/lint/lint-include-guards.py:83 in ea3e7abc45 outdated
78+ header_file_contents_string = f.read() 79+ 80+ include_guard_lst = re.findall( 81+ regex_pattern, header_file_contents_string) 82+ 83+ if len(include_guard_lst) != 3:
KevinMusgrave commented at 2:49 am on April 20, 2022:The following is one way to fix it:
0 regex_pattern = f'^#(ifndef|define|endif //) {header_id}' 1 2 with open(header_file, 'r', encoding='utf-8') as f: 3 header_file_contents = f.readlines() 4 5 count = 0 6 for header_file_contents_string in header_file_contents: 7 include_guard_lst = re.findall( 8 regex_pattern, header_file_contents_string) 9 10 count += len(include_guard_lst) 11 12 if count != 3:
brydinh commented at 1:29 pm on April 20, 2022:thanks, awesome catch!Convert lint-include-guards.sh to python
Specify encoding when reading header files, add docstring Update test/lint/lint-include-guards.py include guard count logic Co-authored-by: Kevin Musgrave <tkm45@cornell.edu> Update test/lint/lint-include-guards.py by removing whitespace
brydinh force-pushed on Apr 20, 2022KevinMusgrave commented at 6:43 pm on April 20, 2022: contributorTested ACK d5fdec5cf8cffe8ece5460cd8c6e83ea6eebf625
Outputs and exit codes match. Example:
0src/attributes.h seems to be missing the expected include guard: 1 #ifndef BITCOIN_ATTRIBUTES_H 2 #define BITCOIN_ATTRIBUTES_H 3 ... 4 #endif // BITCOIN_ATTRIBUTES_H 5 6src/banman.h seems to be missing the expected include guard: 7 #ifndef BITCOIN_BANMAN_H 8 #define BITCOIN_BANMAN_H 9 ... 10 #endif // BITCOIN_BANMAN_H 11 12src/bech32.h seems to be missing the expected include guard: 13 #ifndef BITCOIN_BECH32_H 14 #define BITCOIN_BECH32_H 15 ... 16 #endif // BITCOIN_BECH32_H
laanwj commented at 4:14 pm on April 25, 2022: memberCode review ACK d5fdec5cf8cffe8ece5460cd8c6e83ea6eebf625laanwj merged this on Apr 25, 2022laanwj closed this on Apr 25, 2022
sidhujag referenced this in commit 5972adab82 on Apr 26, 2022DrahtBot locked this on Apr 25, 2023
github-metadata-mirror
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 06:12 UTC
This is a metadata mirror of the GitHub repository bitcoin/bitcoin. This site is not affiliated with GitHub. Content is generated from a GitHub metadata backup.
generated: 2025-01-22 06:12 UTC
This site is hosted by @0xB10C
More mirrored repositories can be found on mirror.b10c.me
More mirrored repositories can be found on mirror.b10c.me