summaryrefslogtreecommitdiffstats
path: root/gfx/harfbuzz/src/check-c-linkage-decls.py
diff options
context:
space:
mode:
Diffstat (limited to 'gfx/harfbuzz/src/check-c-linkage-decls.py')
-rwxr-xr-xgfx/harfbuzz/src/check-c-linkage-decls.py36
1 files changed, 36 insertions, 0 deletions
diff --git a/gfx/harfbuzz/src/check-c-linkage-decls.py b/gfx/harfbuzz/src/check-c-linkage-decls.py
new file mode 100755
index 0000000000..fe18eda897
--- /dev/null
+++ b/gfx/harfbuzz/src/check-c-linkage-decls.py
@@ -0,0 +1,36 @@
+#!/usr/bin/env python3
+
+import sys, os
+
+srcdir = os.getenv ('srcdir', os.path.dirname (__file__))
+base_srcdir = os.getenv ('base_srcdir', srcdir)
+
+os.chdir (srcdir)
+
+def removeprefix(s):
+ abs_path = os.path.join(base_srcdir, s)
+ return os.path.relpath(abs_path, srcdir)
+
+
+HBHEADERS = [os.path.basename (x) for x in os.getenv ('HBHEADERS', '').split ()] or \
+ [x for x in os.listdir ('.') if x.startswith ('hb') and x.endswith ('.h')]
+HBSOURCES = [
+ removeprefix(x) for x in os.getenv ('HBSOURCES', '').split ()
+] or [
+ x for x in os.listdir ('.') if x.startswith ('hb') and x.endswith (('.cc', '.hh'))
+]
+stat = 0
+
+for x in HBHEADERS:
+ with open (x, 'r', encoding='utf-8') as f: content = f.read ()
+ if ('HB_BEGIN_DECLS' not in content) or ('HB_END_DECLS' not in content):
+ print ('Ouch, file %s does not have HB_BEGIN_DECLS / HB_END_DECLS, but it should' % x)
+ stat = 1
+
+for x in HBSOURCES:
+ with open (x, 'r', encoding='utf-8') as f: content = f.read ()
+ if ('HB_BEGIN_DECLS' in content) or ('HB_END_DECLS' in content):
+ print ('Ouch, file %s has HB_BEGIN_DECLS / HB_END_DECLS, but it shouldn\'t' % x)
+ stat = 1
+
+sys.exit (stat)