samgis_core 3.0.10__py3-none-any.whl → 3.0.11__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -15,11 +15,16 @@ def get_dependencies_freeze() -> dict:
15
15
  return {dist.metadata["name"]: dist.version for dist in metadata.distributions()}
16
16
 
17
17
 
18
- def sanitize_path(filename: str | Path) -> Path:
18
+ def sanitize_path(filename: str | Path, strict_on_filename: bool = True) -> Path:
19
19
  filename = Path(filename)
20
20
  base_path = Path.cwd().resolve(strict=True)
21
21
  logger.info(f"base_path (current working folder):{base_path} ...")
22
- safe_path = filename.resolve(strict=True)
22
+ try:
23
+ safe_path = filename.resolve(strict=strict_on_filename)
24
+ except FileNotFoundError as fnfe:
25
+ logger.error(f"filename not found:{filename.absolute()}.")
26
+ logger.error(f"fnfe:{fnfe}.")
27
+ raise fnfe
23
28
  try:
24
29
  assert base_path / filename.name == safe_path
25
30
  except AssertionError:
@@ -46,15 +51,18 @@ def get_requirements_txt(requirements_no_versions_filename: str | Path, requirem
46
51
  logger.info("start requirements.txt update...")
47
52
  freeze_dict = get_dependencies_freeze()
48
53
  logger.debug(f"freeze_dict:{freeze_dict}.")
49
- requirements_no_versions_filename = sanitize_path(requirements_no_versions_filename)
50
- with open(requirements_no_versions_filename) as req_src:
54
+ logger.debug(f"requirements_no_versions_filename:{requirements_no_versions_filename}.")
55
+ requirements_no_versions_filename_sanitized = sanitize_path(requirements_no_versions_filename)
56
+ logger.info(f"requirements_no_versions_filename_sanitized:{requirements_no_versions_filename_sanitized}.")
57
+ with open(requirements_no_versions_filename_sanitized) as req_src:
51
58
  packages_no_requirements = req_src.read().split("\n")
52
59
  requirements_output = {
53
60
  name: version for name, version in sorted(freeze_dict.items()) if name in packages_no_requirements
54
61
  }
55
- logger.info(f"requirements to write:{requirements_output}.")
56
- requirements_output_filename = sanitize_path(requirements_output_filename)
57
- with open(requirements_output_filename, "w") as dst:
62
+ logger.debug(f"requirements to write:{requirements_output}.")
63
+ requirements_output_filename_sanitized = sanitize_path(requirements_output_filename, strict_on_filename=False)
64
+ logger.debug(f"requirements_output_filename_sanitized:{requirements_output_filename_sanitized}.")
65
+ with open(requirements_output_filename_sanitized, "w") as dst:
58
66
  out = ""
59
67
  for name, version in requirements_output.items():
60
68
  out += f"{name}=={version}\n"
@@ -65,6 +73,7 @@ def get_requirements_txt(requirements_no_versions_filename: str | Path, requirem
65
73
 
66
74
  def get_args(current_args: list) -> argparse.Namespace:
67
75
  warning = "This file must be within the current folder."
76
+ logger.info(f"current_args:{current_args}.")
68
77
  parser = argparse.ArgumentParser(description="Update requirements.txt from current installed packages.")
69
78
  parser.add_argument(
70
79
  "--req_no_version_path", required=True,
@@ -74,11 +83,20 @@ def get_args(current_args: list) -> argparse.Namespace:
74
83
  "--req_output_path", required=True,
75
84
  help=f"file path for output requirements. {warning}."
76
85
  )
77
- return parser.parse_args(current_args)
86
+ parser.add_argument(
87
+ "--loglevel", required=False,
88
+ default="INFO",
89
+ choices=["DEBUG", "INFO"],
90
+ help=f"log level (default INFO)."
91
+ )
92
+ args = parser.parse_args(current_args)
93
+ logger.debug(f"args:{args}.")
94
+ return args
78
95
 
79
96
 
80
97
  if __name__ == '__main__':
81
98
  args = get_args(sys.argv[1:])
99
+ session_logger.setup_logging(json_logs=False, log_level=args.loglevel)
82
100
  get_requirements_txt(
83
101
  requirements_no_versions_filename=args.req_no_version_path,
84
102
  requirements_output_filename=args.req_output_path
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: samgis_core
3
- Version: 3.0.10
3
+ Version: 3.0.11
4
4
  Summary: SamGIS CORE
5
5
  License: MIT
6
6
  Author: alessandro trinca tornidor
@@ -11,9 +11,9 @@ samgis_core/utilities/plot_images.py,sha256=1pwTJC2_ju-QhJXDonvEw6FMK_9i1kQhLnC4
11
11
  samgis_core/utilities/serialize.py,sha256=aIjhEoibBpV_gpgOg6LiVxZCWjOkYxlzcboDZLQctJE,2689
12
12
  samgis_core/utilities/session_logger.py,sha256=mlzLaeSC2b_MF3wLywyXYQsSPIvEd3OnhlD7_4VhMzo,5704
13
13
  samgis_core/utilities/type_hints.py,sha256=anbm8pHFWr_C1upCmncYOK-q9Iq82fO9_yftTqXeizc,1649
14
- samgis_core/utilities/update_requirements_txt.py,sha256=yIqwFhRIPsxtFvv64C8EbOo76qYnXKYNNTP4VLUc47Q,3418
14
+ samgis_core/utilities/update_requirements_txt.py,sha256=w0KQSyiM6b70_Yinf06g0ujqS41bnlR0-dKwD4enYE0,4356
15
15
  samgis_core/utilities/utilities.py,sha256=Yi-nBdgz75BOfPbBPs3pFE6ag6KyZ-wK_FAgHkGtNQs,4298
16
- samgis_core-3.0.10.dist-info/LICENSE,sha256=cmg7mi2IynvK5xYN_TJBikA008n6IJNjQIig1c3ge9Q,1083
17
- samgis_core-3.0.10.dist-info/METADATA,sha256=hS5NltC6HZsoV4FApVlAYRUWxWj7s97rPuGMRwGVFjM,1110
18
- samgis_core-3.0.10.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
19
- samgis_core-3.0.10.dist-info/RECORD,,
16
+ samgis_core-3.0.11.dist-info/LICENSE,sha256=cmg7mi2IynvK5xYN_TJBikA008n6IJNjQIig1c3ge9Q,1083
17
+ samgis_core-3.0.11.dist-info/METADATA,sha256=1zNwWk5PaSLeYxdnbQAZQrgurVN-bBDe4tuQ14tNDBw,1110
18
+ samgis_core-3.0.11.dist-info/WHEEL,sha256=sP946D7jFCHeNz5Iq4fL4Lu-PrWrFsgfLXbbkciIZwg,88
19
+ samgis_core-3.0.11.dist-info/RECORD,,