summaryrefslogtreecommitdiffstats
path: root/bin/find-headers-to-move-inside-modules.py
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-15 05:54:39 +0000
commit267c6f2ac71f92999e969232431ba04678e7437e (patch)
tree358c9467650e1d0a1d7227a21dac2e3d08b622b2 /bin/find-headers-to-move-inside-modules.py
parentInitial commit. (diff)
downloadlibreoffice-267c6f2ac71f92999e969232431ba04678e7437e.tar.xz
libreoffice-267c6f2ac71f92999e969232431ba04678e7437e.zip
Adding upstream version 4:24.2.0.upstream/4%24.2.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rwxr-xr-xbin/find-headers-to-move-inside-modules.py51
1 files changed, 51 insertions, 0 deletions
diff --git a/bin/find-headers-to-move-inside-modules.py b/bin/find-headers-to-move-inside-modules.py
new file mode 100755
index 0000000000..67060ee29f
--- /dev/null
+++ b/bin/find-headers-to-move-inside-modules.py
@@ -0,0 +1,51 @@
+#!/usr/bin/python3
+
+# Look for headers inside include/ that can be moved into their respective modules.
+# Not 100% accurate
+
+import subprocess
+import sys
+
+headerSet = set()
+a = subprocess.Popen("git ls-files include/", stdout=subprocess.PIPE, shell=True)
+with a.stdout as txt:
+ for line in txt:
+ header = line[8:].strip();
+ if b"README" in header: continue
+ if header == b"version.hrc": continue
+ # ignore URE headers
+ if header.startswith(b"IwyuFilter_include.yaml"): continue
+ if header.startswith(b"cppu/"): continue
+ if header.startswith(b"cppuhelper/"): continue
+ if header.startswith(b"osl/"): continue
+ if header.startswith(b"sal/"): continue
+ if header.startswith(b"salhelper/"): continue
+ if header.startswith(b"uno/"): continue
+ headerSet.add(header)
+
+headerSetUnused = headerSet.copy()
+headerSetOnlyInOwnModule = headerSet.copy()
+a = subprocess.Popen("git grep '^#include <'", stdout=subprocess.PIPE, shell=True)
+with a.stdout as txt:
+ for line in txt:
+ idx1 = line.find(b"#include <")
+ idx2 = line.find(b">", idx1 + 10)
+ include = line[idx1 + 10 : idx2]
+ headerSetUnused.discard(include)
+ #
+ idx1 = line.find(b"/")
+ includedFromModule = line[0 : idx1]
+ idx1 = include.find(b"/")
+ module = include[0 : idx1]
+ if module != includedFromModule:
+ headerSetOnlyInOwnModule.discard(include)
+
+print("completely unused")
+print("----------------------------")
+for x in sorted(headerSetUnused):
+ print(x)
+print("")
+print("only used in own module")
+print("----------------------------")
+for x in sorted(headerSetOnlyInOwnModule):
+ print(x)