#! /bin/sh
#set -x
#=========================================================================
# Copyright (C) GemTalk Systems 1986-2014.  All Rights Reserved..
#
# Name - runpgsvrmain.sh
#
# Purpose - script to set environment and start pgsvrmain.
#
# $Id: runpgsvrmain.sh 32752 2014-02-28 22:11:10Z stever $
#
#=========================================================================

if [ "a$GEMSTONE" = "a" ]; then
  echo "ERROR: GemStone scripts require a GEMSTONE environment variable."
  echo "       Please set it to the directory where GemStone resides."
  exit 1
fi

# default PATH
if [ "x$PATH" = "x" ]; then PATH=:/bin:/usr/bin:/usr/ucb; export PATH; fi 
					
comid="runpgsvrmain"

Syntax="Usage: runpgsvrmain <protocol> <wellknown> <timeout>
OR   runpgsvrmain <monName> <numPages> <numProcs> <memLock> <spinLockCount>
              <targetFreeFrames> <numFreeFrameServers> <numSharedCounters>
              <shrPcMonPort> <spcPerms> <spcMemPolicy> <protocol> <wellknown> 
              <timeout>
OR   runpgsvrmain <monName> <serverNum> <numServers> <freeFrameCacheSize>
OR   runpgsvrmain -h|-H|help

	monName		    - name of shared page cache monitor
	numPages	    - number of memory pages for monitor
	numProcs	    - number of process slots for monitor
	memLock		    - true if monitor's memory should be locked in place
	spinLockCount	    - spin count for shared locks
	protocol	    - network protocol for connection, such as \"TCP\"
	wellknown	    - bound network address, such as a TCP/IP port number
	timeout		    - how long, in seconds, to wait for connection
        targetFreeFrames    - target free frame limit for the cache
        numFreeFrameServers - number of free frame page servers to start
        numSharedCounters   - number of shared counters to create
        serverNum           - number of this free frame page server, zero based
        numServers          - total number of free frame page servers started
        shrPcMonPort        - port number to be used by the SPC monitor process
        spcPerms            - permissions for the shared memory segment
        spcMemPolicy        - policy for large memory pages

This Bourne shell script is invoked by a netldi in reponse to a
request of the netldi to provide GemStone database file I/O. By
default, netldi uses the file $GEMSTONE/bin/services.dat to translate the
name runpgsvrmain to a command that executes this script.  If no such
translation is found, the command \$HOME/runpgsvrmain is executed by
netldi instead.
"

# give a little help
if [ "x$1" = "x-h" ] || [ "x$1" = "x-H" ] || [ "x$1" = "xhelp" ]; then
  echo "$Syntax"; exit
fi

# error control - do no allow hup
trap '' 1

# pgsvrmain is required
if [ ! -x "$GEMSTONE/sys/pgsvrmain" ]; then
  echo "${comid}[Error]:   cannot find file $GEMSTONE/sys/pgsvrmain"
  exit 1 
fi

# show what we have
echo "runpgsvr[Info]:     Description of arguments:"
# bug 40199 - determine correct location for uname
if [ -f "/bin/uname" ]; then
  UNAME="/bin/uname"
elif [ -f "/usr/bin/uname" ]; then
  UNAME="/usr/bin/uname"
else
# Weird case.  Let's just hope it's in the path...
  UNAME="uname"
fi
hName=`$UNAME -n`

echo "   the hostname is:     $hName"
echo "   GEMSTONE is:         $GEMSTONE"
echo "   pgsvr arguments are: $*"

# The default behaviour is to delete this process's log file if it exits
# normally. If you want to keep this process's log file even on normal exit
# then uncomment the following
# export GEMSTONE_KEEP_LOG=1

#PgsvrTraceMode=1
#export PgsvrTraceMode

# start pgsvrmain - pgsvrmain needs GEMSTONE

# By default a pgsvrmain will raise its number of descriptors to whatever the
# hard limit is. By setting GEMSTONE_MAX_FD to a positive number the
# pgsvrmain will only raise its descriptors to that number.
# If GEMSTONE_MAX_FD is set to 0 then the pgsvr will not modify its descriptor
# limit
# export GEMSTONE_MAX_FD=?

# start a server; ignore timeout (last arg)
exec "$GEMSTONE/sys/pgsvrmain" "$@"
# with the above exec nothing after this is ever executed
