xref: /xnu-12377.61.12/tests/unit/tools/merge_cmds_json.py (revision 4d495c6e23c53686cf65f45067f79024cf5dcee8)
1*4d495c6eSApple OSS Distributions#!/usr/bin/env python3
2*4d495c6eSApple OSS Distributionsimport sys
3*4d495c6eSApple OSS Distributionsimport os
4*4d495c6eSApple OSS Distributionsimport glob
5*4d495c6eSApple OSS Distributions
6*4d495c6eSApple OSS Distributionsdef main():
7*4d495c6eSApple OSS Distributions    xnu_root = sys.argv[1]
8*4d495c6eSApple OSS Distributions    xnu_build_dir = sys.argv[2]
9*4d495c6eSApple OSS Distributions    tests_obj_dir = sys.argv[3]
10*4d495c6eSApple OSS Distributions
11*4d495c6eSApple OSS Distributions    xnu_json = os.path.join(xnu_build_dir, "compile_commands.json")
12*4d495c6eSApple OSS Distributions    if not os.path.exists(xnu_json):
13*4d495c6eSApple OSS Distributions        print(f"did not find xnu build json: {xnu_json}")
14*4d495c6eSApple OSS Distributions        return 0
15*4d495c6eSApple OSS Distributions    root_json = os.path.join(xnu_root, "compile_commands.json")
16*4d495c6eSApple OSS Distributions
17*4d495c6eSApple OSS Distributions    if os.path.exists(root_json):
18*4d495c6eSApple OSS Distributions        if not os.path.islink(root_json):
19*4d495c6eSApple OSS Distributions            print(f"root json is not a symlink, not removing it: {root_json}")
20*4d495c6eSApple OSS Distributions            return 0
21*4d495c6eSApple OSS Distributions
22*4d495c6eSApple OSS Distributions    add_text = ""
23*4d495c6eSApple OSS Distributions    for filename in glob.glob(os.path.join(tests_obj_dir, "*.json")):
24*4d495c6eSApple OSS Distributions        if filename.endswith("compile_commands.json"):
25*4d495c6eSApple OSS Distributions            continue
26*4d495c6eSApple OSS Distributions        print(f"found {filename}")
27*4d495c6eSApple OSS Distributions        text = open(filename).read()
28*4d495c6eSApple OSS Distributions        add_text += text
29*4d495c6eSApple OSS Distributions    add_text = add_text.rstrip()
30*4d495c6eSApple OSS Distributions    if add_text[-1] == ',':
31*4d495c6eSApple OSS Distributions        add_text = add_text[:-1]
32*4d495c6eSApple OSS Distributions
33*4d495c6eSApple OSS Distributions    if len(add_text) == 0:
34*4d495c6eSApple OSS Distributions        print(f"did not find any json files in {tests_obj_dir}")
35*4d495c6eSApple OSS Distributions        return 0
36*4d495c6eSApple OSS Distributions
37*4d495c6eSApple OSS Distributions    xnu_j = open(xnu_json).read()
38*4d495c6eSApple OSS Distributions    if xnu_j[-3:] != "\n]\n":
39*4d495c6eSApple OSS Distributions        print(f"doesn't look like a legit compile_commands.json: {xnu_json}")
40*4d495c6eSApple OSS Distributions        return 0
41*4d495c6eSApple OSS Distributions
42*4d495c6eSApple OSS Distributions    xnu_j_mod = xnu_j[:-3] + ",\n\n" + add_text + "]\n"
43*4d495c6eSApple OSS Distributions
44*4d495c6eSApple OSS Distributions    tests_json = os.path.join(tests_obj_dir, "compile_commands.json")
45*4d495c6eSApple OSS Distributions    open(tests_json, "w").write(xnu_j_mod)
46*4d495c6eSApple OSS Distributions    print(f"saved {tests_json}")
47*4d495c6eSApple OSS Distributions
48*4d495c6eSApple OSS Distributions    if os.path.exists(root_json):
49*4d495c6eSApple OSS Distributions        print(f"removing old link {root_json}")
50*4d495c6eSApple OSS Distributions        os.unlink(root_json)
51*4d495c6eSApple OSS Distributions    os.symlink(tests_json, root_json)
52*4d495c6eSApple OSS Distributions    print(f"added link {root_json}")
53*4d495c6eSApple OSS Distributions
54*4d495c6eSApple OSS Distributions
55*4d495c6eSApple OSS Distributionsif __name__ == "__main__":
56*4d495c6eSApple OSS Distributions    sys.exit(main())