diff options
Diffstat (limited to 'scripts/generatePortVersionsDb.py')
| -rw-r--r-- | scripts/generatePortVersionsDb.py | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/scripts/generatePortVersionsDb.py b/scripts/generatePortVersionsDb.py new file mode 100644 index 000000000..cefd61e1c --- /dev/null +++ b/scripts/generatePortVersionsDb.py @@ -0,0 +1,71 @@ +import os
+import os.path
+import sys
+import subprocess
+import json
+import time
+
+from subprocess import CalledProcessError
+from json.decoder import JSONDecodeError
+from pathlib import Path
+
+
+SCRIPT_DIRECTORY = os.path.dirname(os.path.abspath(__file__))
+
+
+def get_current_git_ref():
+ output = subprocess.run(['git.exe', '-C', SCRIPT_DIRECTORY, 'rev-parse', '--verify', 'HEAD'],
+ capture_output=True,
+ encoding='utf-8')
+ if output.returncode == 0:
+ return output.stdout.strip()
+ print(f"Failed to get git ref:", output.stderr.strip(), file=sys.stderr)
+ return None
+
+
+def generate_port_versions_db(ports_path, db_path, revision):
+ start_time = time.time()
+ port_names = [item for item in os.listdir(ports_path) if os.path.isdir(os.path.join(ports_path, item))]
+ total_count = len(port_names)
+ for counter, port_name in enumerate(port_names):
+ containing_dir = os.path.join(db_path, f'{port_name[0]}-')
+ os.makedirs(containing_dir, exist_ok=True)
+ output_filepath = os.path.join(containing_dir, f'{port_name}.json')
+ if not os.path.exists(output_filepath):
+ output = subprocess.run(
+ [os.path.join(SCRIPT_DIRECTORY, '../vcpkg'), 'x-history', port_name, '--x-json'],
+ capture_output=True, encoding='utf-8')
+ if output.returncode == 0:
+ try:
+ versions_object = json.loads(output.stdout)
+ with open(output_filepath, 'w') as output_file:
+ json.dump(versions_object, output_file)
+ except JSONDecodeError:
+ print(f'Maformed JSON from vcpkg x-history {port_name}: ', output.stdout.strip(), file=sys.stderr)
+ else:
+ print(f'x-history {port_name} failed: ', output.stdout.strip(), file=sys.stderr)
+ # This should be replaced by a progress bar
+ if counter > 0 and counter % 100 == 0:
+ elapsed_time = time.time() - start_time
+ print(f'Processed {counter} out of {total_count}. Elapsed time: {elapsed_time:.2f} seconds')
+ rev_file = os.path.join(db_path, revision)
+ Path(rev_file).touch()
+ elapsed_time = time.time() - start_time
+ print(f'Processed {total_count} total ports. Elapsed time: {elapsed_time:.2f} seconds')
+
+
+def main(ports_path, db_path):
+ revision = get_current_git_ref()
+ if not revision:
+ print('Couldn\'t fetch current Git revision', file=sys.stderr)
+ sys.exit(1)
+ rev_file = os.path.join(db_path, revision)
+ if os.path.exists(rev_file):
+ print(f'Database files already exist for commit {revision}')
+ sys.exit(0)
+ generate_port_versions_db(ports_path=ports_path, db_path=db_path, revision=revision)
+
+
+if __name__ == "__main__":
+ main(ports_path=os.path.join(SCRIPT_DIRECTORY, '../ports'),
+ db_path=os.path.join(SCRIPT_DIRECTORY, '../port_versions'))
|
