diff options
author | Jordan Wilberding <[email protected]> | 2014-03-11 12:06:57 +0100 |
---|---|---|
committer | Jordan Wilberding <[email protected]> | 2014-03-11 12:06:57 +0100 |
commit | 6c962c924086fcfbc8b5e463aa6a50f1521a65f7 (patch) | |
tree | 4c24f70e61175744b6008a2f22331ef579a2cee8 /priv/templates/bin.dtl | |
parent | eeeef1ef2648fa9815f0f61acbfe9576b2884890 (diff) | |
parent | f32a0a44f2e0748122d90a708cbff0003762c2ba (diff) | |
download | relx-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.dtl | 44 |
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 $@ |