[PATCH 1/7] gitlab: use argparse in check-units script

Alex Bennée posted 7 patches 4 months, 1 week ago
Maintainers: "Alex Bennée" <alex.bennee@linaro.org>, "Philippe Mathieu-Daudé" <philmd@linaro.org>, Thomas Huth <thuth@redhat.com>, Riku Voipio <riku.voipio@iki.fi>, Laurent Vivier <laurent@vivier.eu>, Alexandre Iooss <erdnaxe@crans.org>, Mahmoud Mandour <ma.mandourr@gmail.com>, Pierrick Bouvier <pierrick.bouvier@linaro.org>, Jason Wang <jasowang@redhat.com>, Richard Henderson <richard.henderson@linaro.org>
[PATCH 1/7] gitlab: use argparse in check-units script
Posted by Alex Bennée 4 months, 1 week ago
Modernise the argument parsing so we can easily add to the script.

Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
---
 .gitlab-ci.d/check-units.py | 21 ++++++++++++---------
 1 file changed, 12 insertions(+), 9 deletions(-)

diff --git a/.gitlab-ci.d/check-units.py b/.gitlab-ci.d/check-units.py
index 268a4118d5..cdc62ae5ee 100755
--- a/.gitlab-ci.d/check-units.py
+++ b/.gitlab-ci.d/check-units.py
@@ -8,8 +8,10 @@
 # SPDX-License-Identifier: GPL-2.0-or-later
 
 from os import access, R_OK, path
-from sys import argv, exit
+from sys import exit
 import json
+import argparse
+from pathlib import Path
 from collections import Counter
 
 
@@ -51,16 +53,17 @@ def analyse_units(build_units):
 
 
 if __name__ == "__main__":
-    if len(argv) != 2:
-        script_name = path.basename(argv[0])
-        print(f"Usage: {script_name} <path_to_compile_commands.json>")
-        exit(1)
+    parser = argparse.ArgumentParser(
+        description="analyse number of build units in compile_commands.json")
+    parser.add_argument("cc_path", type=Path, default=None,
+                        help="Path to compile_commands.json")
+
+    args = parser.parse_args()
 
-    cc_path = argv[1]
-    if path.isfile(cc_path) and access(cc_path, R_OK):
-        units = extract_build_units(cc_path)
+    if path.isfile(args.cc_path) and access(args.cc_path, R_OK):
+        units = extract_build_units(args.cc_path)
         analyse_units(units)
         exit(0)
     else:
-        print(f"{cc_path} doesn't exist or isn't readable")
+        print(f"{args.cc_path} doesn't exist or isn't readable")
         exit(1)
-- 
2.47.2


Re: [PATCH 1/7] gitlab: use argparse in check-units script
Posted by Manos Pitsidianakis 4 months, 1 week ago
On Thu, Jul 10, 2025 at 1:46 PM Alex Bennée <alex.bennee@linaro.org> wrote:
>
> Modernise the argument parsing so we can easily add to the script.
>
> Signed-off-by: Alex Bennée <alex.bennee@linaro.org>
> ---
>  .gitlab-ci.d/check-units.py | 21 ++++++++++++---------
>  1 file changed, 12 insertions(+), 9 deletions(-)
>
> diff --git a/.gitlab-ci.d/check-units.py b/.gitlab-ci.d/check-units.py
> index 268a4118d5..cdc62ae5ee 100755
> --- a/.gitlab-ci.d/check-units.py
> +++ b/.gitlab-ci.d/check-units.py
> @@ -8,8 +8,10 @@
>  # SPDX-License-Identifier: GPL-2.0-or-later
>
>  from os import access, R_OK, path
> -from sys import argv, exit
> +from sys import exit
>  import json
> +import argparse
> +from pathlib import Path
>  from collections import Counter
>
>
> @@ -51,16 +53,17 @@ def analyse_units(build_units):
>
>
>  if __name__ == "__main__":
> -    if len(argv) != 2:
> -        script_name = path.basename(argv[0])
> -        print(f"Usage: {script_name} <path_to_compile_commands.json>")
> -        exit(1)
> +    parser = argparse.ArgumentParser(
> +        description="analyse number of build units in compile_commands.json")
> +    parser.add_argument("cc_path", type=Path, default=None,
> +                        help="Path to compile_commands.json")
> +
> +    args = parser.parse_args()
>
> -    cc_path = argv[1]
> -    if path.isfile(cc_path) and access(cc_path, R_OK):
> -        units = extract_build_units(cc_path)
> +    if path.isfile(args.cc_path) and access(args.cc_path, R_OK):
> +        units = extract_build_units(args.cc_path)
>          analyse_units(units)
>          exit(0)
>      else:
> -        print(f"{cc_path} doesn't exist or isn't readable")
> +        print(f"{args.cc_path} doesn't exist or isn't readable")
>          exit(1)
> --
> 2.47.2
>
>

Reviewed-by: Manos Pitsidianakis <manos.pitsidianakis@linaro.org>