rename_symbols.py 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123
  1. #!/usr/bin/env python3
  2. #
  3. # This script renames symbols in the specfied paths
  4. import argparse
  5. import os
  6. import pathlib
  7. import re
  8. import sys
  9. SDL_ROOT = pathlib.Path(__file__).resolve().parents[1]
  10. SDL_INCLUDE_DIR = SDL_ROOT / "include/SDL3"
  11. def main():
  12. if args.all_symbols:
  13. if len(args.args) < 1:
  14. print("Usage: %s --all-symbols files_or_directories ..." % sys.argv[0])
  15. exit(1)
  16. replacements = get_all_replacements()
  17. entries = args.args
  18. else:
  19. if len(args.args) < 3:
  20. print("Usage: %s oldname newname files_or_directories ..." % sys.argv[0])
  21. exit(1)
  22. replacements = { args.args[0]: args.args[1] }
  23. entries = args.args[2:]
  24. if args.substring:
  25. regex = create_substring_regex_from_replacements(replacements)
  26. else:
  27. regex = create_regex_from_replacements(replacements)
  28. for entry in entries:
  29. path = pathlib.Path(entry)
  30. if not path.exists():
  31. print("%s doesn't exist, skipping" % entry)
  32. continue
  33. replace_symbols_in_path(path, regex, replacements)
  34. def get_all_replacements():
  35. replacements = {}
  36. file = (SDL_INCLUDE_DIR / "SDL_oldnames.h")
  37. mode = 0
  38. for line in file.read_text().splitlines():
  39. if line == "#ifdef SDL_ENABLE_OLD_NAMES":
  40. if mode == 0:
  41. mode = 1
  42. else:
  43. raise Exception("get_all_replacements(): expected mode 0")
  44. elif line == "#else /* !SDL_ENABLE_OLD_NAMES */":
  45. if mode == 1:
  46. mode = 2
  47. else:
  48. raise Exception("get_all_replacements(): expected mode 1")
  49. elif mode == 1 and line.startswith("#define "):
  50. words = line.split()
  51. replacements[words[1]] = words[2]
  52. return replacements
  53. def create_regex_from_replacements(replacements):
  54. return re.compile(r"\b(%s)\b" % "|".join(map(re.escape, replacements.keys())))
  55. def create_substring_regex_from_replacements(replacements):
  56. return re.compile(r"(%s)" % "|".join(map(re.escape, replacements.keys())))
  57. def replace_symbols_in_file(file, regex, replacements):
  58. try:
  59. with file.open("r", encoding="UTF-8", newline="") as rfp:
  60. original = rfp.read()
  61. contents = regex.sub(lambda mo: replacements[mo.string[mo.start():mo.end()]], original)
  62. if contents != original:
  63. with file.open("w", encoding="UTF-8", newline="") as wfp:
  64. wfp.write(contents)
  65. except UnicodeDecodeError:
  66. print("%s is not text, skipping" % file)
  67. except Exception as err:
  68. print("%s" % err)
  69. def replace_symbols_in_dir(path, regex, replacements):
  70. for entry in path.glob("*"):
  71. if entry.is_dir():
  72. replace_symbols_in_dir(entry, regex, replacements)
  73. else:
  74. print("Processing %s" % entry)
  75. replace_symbols_in_file(entry, regex, replacements)
  76. def replace_symbols_in_path(path, regex, replacements):
  77. if path.is_dir():
  78. replace_symbols_in_dir(path, regex, replacements)
  79. else:
  80. replace_symbols_in_file(path, regex, replacements)
  81. if __name__ == "__main__":
  82. parser = argparse.ArgumentParser(fromfile_prefix_chars='@')
  83. parser.add_argument("--all-symbols", action="store_true")
  84. parser.add_argument("--substring", action="store_true")
  85. parser.add_argument("args", nargs="*")
  86. args = parser.parse_args()
  87. try:
  88. main()
  89. except Exception as e:
  90. print(e)
  91. exit(-1)
  92. exit(0)