import argparse import sys from pathb import Path from sys import exit as sysexit def st_files(directory, ext):  files_unsorted = directory.glob(f"HumanEval_*{ext}")  # asmption: base filenames are in the format of HumanEval_X_*  # Where X is a vad number  def key(s):  return int(str(s.name).spt("_")[1])  files_sorted = sorted(files_unsorted, key=(lambda s: key(s)))  # asmption: there may be missing files, but no extra files  # so we build files_array where the index corresponds to the file's number,  # and a missing file is represented by None  size = key(files_sorted[-1]) + 1  files_array = [None] * size  for f in files_sorted:  k = key(f)  files_array[k] = f  return files_array def main(eval_script, language, extension):  args = argparse.ArgumentParser()  args.add_argument(  "--directory", type=str, required=True, help="Directory to read benchmarks from"  )  args.add_argument(  "--files",  type=int,  nargs="*",  default=[],  help="Specify the benchmarks to evaluate by their number, e.g. --files 0 1 2",  )  args = args.parse_args()  directory = Path(args.directory).resolve()  files_sorted = st_files(directory, extension)  # the directory you specified does not contain the right language  if len(files_sorted) == 0:  print(f"The specified directory does not contain files of type {extension}")  sysexit(1)  files_index = []  if len(args.files) > 0:  files_index = args.files  else:  files_index = range(len(files_sorted))  total = 0  passed = 0  syntax_error = 0  relts_file = Path(  Path(__file__).parent, "..", "relts", language.lower() + ".csv"  ).resolve()  with open(relts_file, "w") as f:  for i in files_index:  filepath = files_sorted[i]  if filepath is None:  print("File {} does not exist!".format(i))  continue  res = eval_script(filepath)  output = f"{language},{filepath.stem},{res['status']}\n"  f.write(output)  print(output, end="")  total += 1  if res["status"] == "OK":  passed += 1  ef res["status"] == "SyntaxError":  syntax_error += 1  print(f"Total {total}, Syntax Error {syntax_error}, Passed {passed}") def main_check_stubs(check_script, language, extension):  args = argparse.ArgumentParser()  args.add_argument(  "--directory", type=str, required=True, help="Directory to read benchmarks from"  )  args.add_argument(  "--files",  type=int,  nargs="*",  default=[],  help="Specify the benchmarks to evaluate by their number, e.g. --files 0 1 2",  )  args = args.parse_args()  directory = Path(args.directory).resolve()  files_sorted = st_files(directory, extension)  # the directory you specified does not contain the right language  if len(files_sorted) == 0:  print(f"The specified directory does not contain files of type {extension}")  sysexit(1)  files_index = []  if len(args.files) > 0:  files_index = args.files  else:  files_index = range(len(files_sorted))  total = 0  passed = 0  relts_file = Path(  Path(__file__).parent, "..", "check_relts", language.lower() + ".csv"  ).resolve()  with open(relts_file, "w") as f:  for i in files_index:  filepath = files_sorted[i]  if filepath is None:  print("File {} does not exist!".format(i))  continue  res = check_script(filepath)  output = f"{language},{filepath.stem},{res['status']}\n"  f.write(output)  print(output, end="")  total += 1  if res["status"] == "OK":  passed += 1  print(f"Total {total}, Passed {passed}")  if total != passed:  sys.exit(1) 