FSCORE-652

This commit is contained in:
Anthony Minessale 2010-08-26 12:34:24 -05:00
parent 6fe6e67573
commit f26a697242

View File

@ -272,6 +272,7 @@ int main(int argc, char *argv[])
const char *err = NULL; /* error value for return from freeswitch initialization */
#ifndef WIN32
int nf = 0; /* TRUE if we are running in nofork mode */
int bf = 0;
char *runas_user = NULL;
char *runas_group = NULL;
#else
@ -328,6 +329,7 @@ int main(int argc, char *argv[])
"\t-monotonic-clock -- use monotonic clock as timer source\n"
#else
"\t-nf -- no forking\n"
"\t-bf -- block until fully started, then fork\n"
"\t-u [user] -- specify user to switch to\n" "\t-g [group] -- specify group to switch to\n"
#endif
"\t-help -- this message\n" "\t-version -- print the version and exit\n"
@ -461,6 +463,11 @@ int main(int argc, char *argv[])
known_opt++;
}
if (local_argv[x] && !strcmp(local_argv[x], "-bf")) {
bf++;
known_opt++;
}
if (local_argv[x] && !strcmp(local_argv[x], "-version")) {
fprintf(stdout, "FreeSWITCH version: %s\n", SWITCH_VERSION_FULL);
return 0;
@ -523,8 +530,14 @@ int main(int argc, char *argv[])
}
if (local_argv[x] && !strcmp(local_argv[x], "-nc")) {
nc++;
known_opt++;
if (!nf) {
nc++;
known_opt++;
} else {
/* The flags -nc and -nf are mutually exclusive. Ignoring -nc. */
nc = 0;
known_opt++;
}
}
if (local_argv[x] && !strcmp(local_argv[x], "-c")) {
@ -685,7 +698,7 @@ int main(int argc, char *argv[])
#ifdef WIN32
FreeConsole();
#else
if (!nf) {
if (!nf && !bf) {
daemonize();
}
#endif
@ -800,6 +813,10 @@ int main(int argc, char *argv[])
return 255;
}
if(bf) {
daemonize();
}
switch_core_runtime_loop(nc);
destroy_status = switch_core_destroy();