-
Notifications
You must be signed in to change notification settings - Fork 8
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #29 from rruiter87/tc-version-check
Tc version check
- Loading branch information
Showing
14 changed files
with
17,116 additions
and
11 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,145 @@ | ||
import argparse | ||
import re | ||
import xml.etree.ElementTree as ET | ||
|
||
from pre_commit_hooks.exceptions import PreCommitException | ||
|
||
|
||
def tc_version_pinned(xml_content: str) -> bool: | ||
root = ET.fromstring(xml_content) | ||
|
||
return ( | ||
"TcVersionFixed" in root.attrib and root.attrib.get("TcVersionFixed") == "true" | ||
) | ||
|
||
|
||
def get_tc_version(xml_content: str) -> str: | ||
root = ET.fromstring(xml_content) | ||
|
||
return root.attrib.get("TcVersion") | ||
|
||
|
||
def fix_tc_version(xml_content: str, new_version: str) -> str: | ||
pattern = r'(TcVersion=")([^"]*)(")' | ||
new_xml_content = re.sub(pattern, r"\g<1>" + new_version + r"\g<3>", xml_content) | ||
|
||
return new_xml_content | ||
|
||
|
||
def fix_pinned_version(xml_content: str, pin_version: bool) -> str: | ||
new_value = "true" if pin_version else "false" | ||
|
||
pattern = r'(TcVersionFixed=")([^"]*)(")' | ||
|
||
if re.search(pattern, xml_content): | ||
new_xml_content = re.sub(pattern, r"\g<1>" + new_value + r"\g<3>", xml_content) | ||
else: | ||
version_pattern = r'(TcVersion="[^"]*")' | ||
new_xml_content = re.sub( | ||
version_pattern, r'\g<1> TcVersionFixed="' + new_value + r'"', xml_content | ||
) | ||
|
||
return new_xml_content | ||
|
||
|
||
def main(args=None): | ||
if args is None: | ||
parser = argparse.ArgumentParser() | ||
parser.add_argument( | ||
"filenames", nargs="+", help="List of tsproj filenames to process." | ||
) | ||
parser.add_argument( | ||
"--target-version", type=str, help="Target TwinCAT version to enforce." | ||
) | ||
parser.add_argument( | ||
"--fix", | ||
action="store_true", | ||
help="Fix the versions if they do not match the target version and fix the pinned state if combined with --pinned/no-pinned.", | ||
) | ||
parser.add_argument( | ||
"--reason", type=str, help="Reason for targeting a specific version." | ||
) | ||
parser.add_argument( | ||
"--pinned", | ||
action=argparse.BooleanOptionalAction, | ||
help="Check if the TwinCAT version should be pinned. Applies or removes pinning if combined with --fix.", | ||
) | ||
|
||
args = parser.parse_args() | ||
|
||
try: | ||
versions = {} | ||
pinned = {} | ||
for filename in args.filenames: | ||
with open(filename, "r") as file: | ||
xml_content = file.read() | ||
versions[filename] = get_tc_version(xml_content) | ||
pinned[filename] = tc_version_pinned(xml_content) | ||
|
||
itemize = "\n -" | ||
exception_message = "" | ||
if args.target_version: | ||
mismatched_files = [ | ||
fname for fname, ver in versions.items() if ver != args.target_version | ||
] | ||
if mismatched_files: | ||
reason_msg = f"\nReason: {args.reason}" if args.reason else "" | ||
if args.fix: | ||
for filename in mismatched_files: | ||
with open(filename, "r") as file: | ||
xml_content = file.read() | ||
fixed_content = fix_tc_version(xml_content, args.target_version) | ||
with open(filename, "w") as file: | ||
file.write(fixed_content) | ||
|
||
print( | ||
f"Fixed TwinCAT versions for:{itemize}{itemize.join(mismatched_files)}{reason_msg}" | ||
) | ||
else: | ||
exception_message += ( | ||
"The following files are not set to the targeted TwinCAT version " | ||
f"{args.target_version}:{itemize}{itemize.join(mismatched_files)}{reason_msg}" | ||
) | ||
else: | ||
unique_versions = set(versions.values()) | ||
if len(unique_versions) > 1: | ||
exception_message += ( | ||
"Not all files have the same TwinCAT version:" | ||
f"{itemize}" | ||
+ itemize.join(f"{fname}: {ver}" for fname, ver in versions.items()) | ||
) | ||
|
||
if args.pinned is not None: | ||
mismatched_files = [ | ||
fname for fname, pin in pinned.items() if pin != args.pinned | ||
] | ||
if mismatched_files: | ||
if args.fix: | ||
for filename in mismatched_files: | ||
with open(filename, "r") as file: | ||
xml_content = file.read() | ||
fixed_content = fix_pinned_version(xml_content, args.pinned) | ||
with open(filename, "w") as file: | ||
file.write(fixed_content) | ||
print( | ||
f"Fixed pinned state for:{itemize}{itemize.join(mismatched_files)}" | ||
) | ||
else: | ||
should_be_pinned_message = ( | ||
"The following files should have a pinned TwinCAT version" | ||
if args.pinned | ||
else "The following files should NOT have a pinned TwinCAT version" | ||
) | ||
exception_message += "\n\n" if len(exception_message) > 0 else "" | ||
exception_message += f"{should_be_pinned_message}{itemize}{itemize.join(mismatched_files)}" | ||
if len(exception_message) > 0: | ||
raise PreCommitException(exception_message) | ||
|
||
return 0 | ||
except Exception as exc: | ||
print(exc) | ||
return 1 | ||
|
||
|
||
if __name__ == "__main__": | ||
exit(main()) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,2 @@ | ||
class PreCommitException(Exception): | ||
pass |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.