aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPetteri Aimonen <jpa@git.mail.kapsi.fi>2013-11-17 15:46:41 +0200
committerPetteri Aimonen <jpa@git.mail.kapsi.fi>2013-12-29 20:26:57 +0200
commit58b3a22d6d66c485bfd7c571c528e4c6d3619cb2 (patch)
treec864341cd84712f1800c22df0a3e0de8becf03a7
parent356535da9bd79252e5365a6e5648b7fcd28b367c (diff)
Add script for making linux binary package
-rw-r--r--.gitignore2
-rwxr-xr-xtools/make_linux_package.sh38
2 files changed, 40 insertions, 0 deletions
diff --git a/.gitignore b/.gitignore
index 70f80a6..3bb09db 100644
--- a/.gitignore
+++ b/.gitignore
@@ -6,6 +6,7 @@
*.pb.h
*.pb
*.pyc
+*_pb2.py
*~
*.tar.gz
.sconsign.dblite
@@ -13,6 +14,7 @@ config.log
.sconf_temp
tests/build
julkaisu.txt
+dist
docs/*.html
docs/generator_flow.png
examples/simple/simple
diff --git a/tools/make_linux_package.sh b/tools/make_linux_package.sh
new file mode 100755
index 0000000..b0ad2dd
--- /dev/null
+++ b/tools/make_linux_package.sh
@@ -0,0 +1,38 @@
+#!/bin/bash
+
+# Run this script in the top nanopb directory to create a binary package
+# for Linux users.
+
+set -e
+set -x
+
+VERSION=`git describe --always`
+DEST=dist/$VERSION
+
+rm -rf $DEST
+mkdir -p $DEST
+
+# Export the files from newest commit
+git archive HEAD | tar x -C $DEST
+
+# Rebuild the Python .proto files
+make -BC $DEST/generator/proto
+
+# Package the Python libraries
+( cd $DEST/generator; bbfreeze nanopb_generator.py )
+mv $DEST/generator/dist $DEST/generator-bin
+
+# Package the protoc compiler
+cp `which protoc` $DEST/generator-bin/protoc.bin
+cat > $DEST/generator-bin/protoc << EOF
+#!/bin/bash
+SCRIPTDIR=\$(dirname \$(readlink -f \$0))
+export LD_LIBRARY_PATH=\$SCRIPTDIR
+export PATH=\$SCRIPTDIR:\$PATH
+exec \$SCRIPTDIR/protoc.bin "\$@"
+EOF
+chmod +x $DEST/generator-bin/protoc
+
+# Make the nanopb generator available as a protoc plugin
+ln -s nanopb-generator $DEST/generator-bin/protoc-gen-nanopb
+