summaryrefslogtreecommitdiffstatshomepage
diff options
context:
space:
mode:
-rw-r--r--zephyr/Makefile3
-rw-r--r--zephyr/makeprj.py29
2 files changed, 30 insertions, 2 deletions
diff --git a/zephyr/Makefile b/zephyr/Makefile
index d020ab5ce0..7d4d6674ef 100644
--- a/zephyr/Makefile
+++ b/zephyr/Makefile
@@ -102,5 +102,4 @@ z_clean:
.PHONY: prj.conf
prj.conf: prj_base.conf
- cat $< >$@
- if [ -f prj_$(BOARD).conf ]; then cat prj_$(BOARD).conf >>$@; fi
+ $(PYTHON) makeprj.py prj_base.conf prj_$(BOARD).conf $@
diff --git a/zephyr/makeprj.py b/zephyr/makeprj.py
new file mode 100644
index 0000000000..239c877cd6
--- /dev/null
+++ b/zephyr/makeprj.py
@@ -0,0 +1,29 @@
+#!/usr/bin/env python3
+import sys
+import os
+import hashlib
+
+
+def hash_file(fname):
+ if not os.path.exists(fname):
+ return b""
+ hasher = hashlib.md5()
+ with open(fname, "rb") as f:
+ hasher.update(f.read())
+ return hasher.digest()
+
+
+old_digest = hash_file(sys.argv[3])
+
+with open(sys.argv[3] + ".tmp", "wb") as f:
+ f.write(open(sys.argv[1], "rb").read())
+ if os.path.exists(sys.argv[2]):
+ f.write(open(sys.argv[2], "rb").read())
+
+new_digest = hash_file(sys.argv[3] + ".tmp")
+
+if new_digest != old_digest:
+ print("Replacing")
+ os.rename(sys.argv[3] + ".tmp", sys.argv[3])
+else:
+ os.remove(sys.argv[3] + ".tmp")