|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [XEN PATCH v7 07/51] build,include: rework compat-build-header.py
Replace a mix of shell script and python script by all python script.
No change to the final generated headers.
Signed-off-by: Anthony PERARD <anthony.perard@xxxxxxxxxx>
Acked-by: Wei Liu <wl@xxxxxxx>
---
Notes:
v7:
- actually keep the dependency on Makefile
v6:
- removed handling of $(prefix-y) and $(suffix-y), they've been removed.
- remove dependency on Makefile as it's not needed anymore
- rebased
v5:
- Removed -P from CPP when generating compat/%.i
-> keep removing linemarkers and keep de-duplicating empty lines.
So that all the blank line that currently exist in the generated
headers stays in place.
v4:
- new patch
xen/include/Makefile | 9 +------
xen/tools/compat-build-header.py | 44 ++++++++++++++++++++++++++++++--
2 files changed, 43 insertions(+), 10 deletions(-)
diff --git a/xen/include/Makefile b/xen/include/Makefile
index 4fa10e68f997..95daa8a28975 100644
--- a/xen/include/Makefile
+++ b/xen/include/Makefile
@@ -46,14 +46,7 @@ public-$(CONFIG_ARM) := $(wildcard public/arch-arm/*.h
public/arch-arm/*/*.h)
all: $(headers-y)
compat/%.h: compat/%.i Makefile $(BASEDIR)/tools/compat-build-header.py
- set -e; id=_$$(echo $@ | tr '[:lower:]-/.' '[:upper:]___'); \
- echo "#ifndef $$id" >$@.new; \
- echo "#define $$id" >>$@.new; \
- echo "#include <xen/compat.h>" >>$@.new; \
- $(if $(filter-out compat/arch-%.h,$@),echo "#include <$(patsubst
compat/%,public/%,$@)>" >>$@.new;) \
- grep -v '^# [0-9]' $< | \
- $(PYTHON) $(BASEDIR)/tools/compat-build-header.py | uniq >>$@.new; \
- echo "#endif /* $$id */" >>$@.new
+ $(PYTHON) $(BASEDIR)/tools/compat-build-header.py <$< $@ >>$@.new; \
mv -f $@.new $@
compat/%.i: compat/%.c Makefile
diff --git a/xen/tools/compat-build-header.py b/xen/tools/compat-build-header.py
index 065d3b1b6ee8..5f5474fba051 100755
--- a/xen/tools/compat-build-header.py
+++ b/xen/tools/compat-build-header.py
@@ -2,6 +2,12 @@
import re,sys
+try:
+ maketrans = str.maketrans
+except AttributeError:
+ # For python2
+ from string import maketrans
+
pats = [
[ r"__InClUdE__(.*)", r"#include\1" ],
[ r"__IfDeF__ (XEN_HAVE.*)", r"#ifdef \1" ],
@@ -23,7 +29,41 @@ pats = [
[ r"(^|[^\w])long([^\w]|$$)", r"\1int\2" ]
];
+output_filename = sys.argv[1]
+
+# tr '[:lower:]-/.' '[:upper:]___'
+header_id = '_' + \
+ output_filename.upper().translate(maketrans('-/.','___'))
+
+header = """#ifndef {0}
+#define {0}
+#include <xen/compat.h>""".format(header_id)
+
+print(header)
+
+if not re.match("compat/arch-.*.h$", output_filename):
+ x = output_filename.replace("compat/","public/")
+ print('#include <%s>' % x)
+
+last_line_empty = False
for line in sys.stdin.readlines():
+ line = line.rstrip()
+
+ # Remove linemarkers generated by the preprocessor.
+ if re.match(r"^# \d", line):
+ continue
+
+ # De-duplicate empty lines.
+ if len(line) == 0:
+ if not last_line_empty:
+ print(line)
+ last_line_empty = True
+ continue
+ else:
+ last_line_empty = False
+
for pat in pats:
- line = re.subn(pat[0], pat[1], line)[0]
- print(line.rstrip())
+ line = re.sub(pat[0], pat[1], line)
+ print(line)
+
+print("#endif /* %s */" % header_id)
--
Anthony PERARD
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |