Source code for tokio.cli.cache_topology

"""
Provides CLI interface for :meth:`tokio.tools.topology.get_job_diameter`.
"""

import json
import argparse
import tokio.tools.topology

[docs]def main(argv=None): """Entry point for the CLI interface """ parser = argparse.ArgumentParser() group = parser.add_mutually_exclusive_group(required=True) group.add_argument("--jobinfo-cache", default=None, type=str, help="path to jobinfo (e.g., Slurm) cache file") parser.add_argument("--nodemap-cache", default=None, type=str, help="path to xtdb2proc cache file") parser.add_argument("-o", "--output", type=str, default=None, help="output file") group.add_argument("jobid", nargs='?', default=None, help="Slurm job id of interest") args = parser.parse_args(argv) topology_result = tokio.tools.topology.get_job_diameter(jobid=args.jobid, nodemap_cache_file=args.nodemap_cache, jobinfo_cache_file=args.jobinfo_cache) # Serialize the object cache_file = args.output if cache_file is None: print(json.dumps(topology_result, indent=4, sort_keys=True)) else: print("Caching to %s" % cache_file) json.dump(topology_result, open(cache_file, 'w'))