summaryrefslogtreecommitdiff
path: root/cpp/src/Ice/Service.cpp
diff options
context:
space:
mode:
authorBernard Normier <bernard@zeroc.com>2007-01-30 16:25:28 +0000
committerBernard Normier <bernard@zeroc.com>2007-01-30 16:25:28 +0000
commitc012c9c84e116d7d236f91350fe269c2f88b04bc (patch)
tree42bb84a50e711eb4f7265cecc3c13df53ceb9197 /cpp/src/Ice/Service.cpp
parentbug 1705: acceptor can block indefinitely (diff)
downloadice-c012c9c84e116d7d236f91350fe269c2f88b04bc.tar.bz2
ice-c012c9c84e116d7d236f91350fe269c2f88b04bc.tar.xz
ice-c012c9c84e116d7d236f91350fe269c2f88b04bc.zip
Updated /etc/init.d scripts
Diffstat (limited to 'cpp/src/Ice/Service.cpp')
-rwxr-xr-xcpp/src/Ice/Service.cpp24
1 files changed, 15 insertions, 9 deletions
diff --git a/cpp/src/Ice/Service.cpp b/cpp/src/Ice/Service.cpp
index 9b2fbece80d..21f6a579eb5 100755
--- a/cpp/src/Ice/Service.cpp
+++ b/cpp/src/Ice/Service.cpp
@@ -400,14 +400,12 @@ Ice::Service::main(int& argc, char* argv[], const InitializationData& initData)
}
#else
//
- // Check for --daemon, --noclose, --nochdir and --pidfile=
+ // Check for --daemon, --noclose, --nochdir and --pidfile
//
bool daemonize = false;
bool closeFiles = true;
bool changeDirectory = true;
string pidFile;
- const char* pidFileArg = "--pidfile=";
- const size_t pidFileLen = strlen(pidFileArg);
int idx = 1;
while(idx < argc)
{
@@ -441,15 +439,23 @@ Ice::Service::main(int& argc, char* argv[], const InitializationData& initData)
changeDirectory = false;
}
- else if(strncmp(argv[idx], pidFileArg, pidFileLen) == 0)
+ else if(strcmp(argv[idx], "--pidfile") == 0)
{
- pidFile = argv[idx] + pidFileLen;
+ if(idx + 1 < argc)
+ {
+ pidFile = argv[idx + 1];
+ }
+ else
+ {
+ cerr << argv[0] << ": --pidfile must be followed by an argument" << endl;
+ return EXIT_FAILURE;
+ }
- for(int i = idx; i + 1 < argc; ++i)
+ for(int i = idx; i + 2 < argc; ++i)
{
- argv[i] = argv[i + 1];
+ argv[i] = argv[i + 2];
}
- argc -= 1;
+ argc -= 2;
}
else
{
@@ -465,7 +471,7 @@ Ice::Service::main(int& argc, char* argv[], const InitializationData& initData)
if(pidFile.size() > 0 && !daemonize)
{
- cerr << argv[0] << ": --pidfile=<file> must be used with --daemon" << endl;
+ cerr << argv[0] << ": --pidfile <file> must be used with --daemon" << endl;
return EXIT_FAILURE;
}