aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--Makefile4
-rwxr-xr-xextras/scripts/compdb_cleanup.py28
2 files changed, 31 insertions, 1 deletions
diff --git a/Makefile b/Makefile
index 3bdba65a8e5..aaba277ec28 100644
--- a/Makefile
+++ b/Makefile
@@ -606,7 +606,9 @@ cscope: cscope.files
.PHONY: compdb
compdb:
- @ninja -C build-root/build-vpp_debug-native/vpp -t compdb > compile_commands.json
+ @ninja -C build-root/build-vpp_debug-native/vpp build.ninja
+ @ninja -C build-root/build-vpp_debug-native/vpp -t compdb | \
+ extras/scripts/compdb_cleanup.py > compile_commands.json
.PHONY: checkstyle
checkstyle: checkfeaturelist
diff --git a/extras/scripts/compdb_cleanup.py b/extras/scripts/compdb_cleanup.py
new file mode 100755
index 00000000000..0139b6bb6c5
--- /dev/null
+++ b/extras/scripts/compdb_cleanup.py
@@ -0,0 +1,28 @@
+#!/usr/bin/env python3
+
+import sys
+import json
+
+objects = json.load(sys.stdin)
+
+for i in range(len(objects) - 1, -1, -1):
+ obj = objects[i]
+
+ # Remove everything except .c files
+ if not obj["file"].endswith(".c"):
+ objects.remove(obj)
+ continue
+
+ # remove duplicates introduced my multiarch
+ if "CLIB_MARCH_VARIANT" in obj["command"]:
+ objects.remove(obj)
+ continue
+
+ # remove ccache prefix
+ s = str.split(obj["command"])
+ if s[0] == "ccache":
+ s.remove(s[0])
+ s[0] = s[0].split("/")[-1]
+ obj["command"] = " ".join(s)
+
+json.dump(objects, sys.stdout, indent=2)