aboutsummaryrefslogtreecommitdiffstats
path: root/priv/templates/bin.dtl
diff options
context:
space:
mode:
authorJordan Wilberding <[email protected]>2014-03-11 12:06:57 +0100
committerJordan Wilberding <[email protected]>2014-03-11 12:06:57 +0100
commit6c962c924086fcfbc8b5e463aa6a50f1521a65f7 (patch)
tree4c24f70e61175744b6008a2f22331ef579a2cee8 /priv/templates/bin.dtl
parenteeeef1ef2648fa9815f0f61acbfe9576b2884890 (diff)
parentf32a0a44f2e0748122d90a708cbff0003762c2ba (diff)
downloadrelx-6c962c924086fcfbc8b5e463aa6a50f1521a65f7.tar.gz
relx-6c962c924086fcfbc8b5e463aa6a50f1521a65f7.tar.bz2
relx-6c962c924086fcfbc8b5e463aa6a50f1521a65f7.zip
Merge pull request #128 from nuex/dtl_scripts
Make scripts in rlx_prv_assembler DTL templates
Diffstat (limited to 'priv/templates/bin.dtl')
-rw-r--r--priv/templates/bin.dtl44
1 files changed, 44 insertions, 0 deletions
diff --git a/priv/templates/bin.dtl b/priv/templates/bin.dtl
new file mode 100644
index 0000000..067e9f7
--- /dev/null
+++ b/priv/templates/bin.dtl
@@ -0,0 +1,44 @@
+#!/bin/sh
+
+set -e
+
+SCRIPT_DIR=`dirname $0`
+RELEASE_ROOT_DIR=`cd $SCRIPT_DIR/.. && pwd`
+REL_NAME={{ rel_name }}
+REL_VSN={{ rel_vsn }}
+ERTS_VSN={{ erts_vsn }}
+REL_DIR=$RELEASE_ROOT_DIR/releases/$REL_VSN
+ERL_OPTS={{ erl_opts }}
+
+find_erts_dir() {
+ local erts_dir=$RELEASE_ROOT_DIR/erts-$ERTS_VSN
+ if [ -d "$erts_dir" ]; then
+ ERTS_DIR=$erts_dir;
+ ROOTDIR=$RELEASE_ROOT_DIR
+ else
+ local erl=`which erl`
+ local erl_root=`$erl -noshell -eval "io:format(\\"~s\\", [code:root_dir()])." -s init stop`
+ ERTS_DIR=$erl_root/erts-$ERTS_VSN
+ ROOTDIR=$erl_root
+ fi
+
+}
+
+find_sys_config() {
+ local possible_sys=$REL_DIR/sys.config
+ if [ -f "$possible_sys" ]; then
+ SYS_CONFIG="-config $possible_sys"
+ fi
+}
+
+find_erts_dir
+find_sys_config
+export ROOTDIR=$RELEASE_ROOT_DIR
+export BINDIR=$ERTS_DIR/bin
+export EMU=beam
+export PROGNAME=erl
+export LD_LIBRARY_PATH=$ERTS_DIR/lib:$LD_LIBRARY_PATH
+
+cd $ROOTDIR
+
+$BINDIR/erlexec $ERL_OPTS $SYS_CONFIG -boot $REL_DIR/$REL_NAME $@