else if (editing) RegDeleteValue(key, NSSM_REG_ROTATE_BYTES_LOW);\r
if (service->rotate_bytes_high) set_number(key, NSSM_REG_ROTATE_BYTES_HIGH, service->rotate_bytes_high);\r
else if (editing) RegDeleteValue(key, NSSM_REG_ROTATE_BYTES_HIGH);\r
+ if (service->no_console) set_number(key, NSSM_REG_NO_CONSOLE, 1);\r
+ else if (editing) RegDeleteValue(key, NSSM_REG_NO_CONSOLE);\r
\r
/* Environment */\r
if (service->env) {\r
/* Environment variables to add to existing rather than replace - may fail. */\r
get_environment(service->name, key, NSSM_REG_ENV_EXTRA, &service->env_extra, &service->env_extralen);\r
\r
- if (si) {\r
- if (service->env_extra) {\r
- TCHAR *env;\r
- unsigned long envlen;\r
-\r
- /* Copy our environment for the application. */\r
- if (! service->env) {\r
- TCHAR *rawenv = GetEnvironmentStrings();\r
- env = rawenv;\r
- if (env) {\r
- /*\r
- The environment block starts with variables of the form\r
- =C:=C:\Windows\System32 which we ignore.\r
- */\r
- while (*env == _T('=')) {\r
- for ( ; *env; env++);\r
- env++;\r
- }\r
- envlen = 0;\r
- if (*env) {\r
- while (true) {\r
- for ( ; env[envlen]; envlen++);\r
- if (! env[++envlen]) break;\r
- }\r
- envlen++;\r
-\r
- service->envlen = envlen * sizeof(TCHAR);\r
- service->env = (TCHAR *) HeapAlloc(GetProcessHeap(), 0, service->envlen);\r
- memmove(service->env, env, service->envlen);\r
- FreeEnvironmentStrings(rawenv);\r
- }\r
- }\r
- }\r
-\r
- /* Append extra variables to configured variables. */\r
- if (service->env) {\r
- envlen = service->envlen + service->env_extralen - sizeof(TCHAR)/*?*/;\r
- env = (TCHAR *) HeapAlloc(GetProcessHeap(), 0, envlen);\r
- if (env) {\r
- memmove(env, service->env, service->envlen - sizeof(TCHAR));\r
- /* envlen is in bytes but env[i] is in characters. */\r
- memmove(env + (service->envlen / sizeof(TCHAR)) - 1, service->env_extra, service->env_extralen);\r
-\r
- HeapFree(GetProcessHeap(), 0, service->env);\r
- HeapFree(GetProcessHeap(), 0, service->env_extra);\r
- service->env = env;\r
- service->envlen = envlen;\r
- }\r
- else log_event(EVENTLOG_ERROR_TYPE, NSSM_EVENT_OUT_OF_MEMORY, _T("environment"), _T("get_parameters()"), 0);\r
- }\r
- else {\r
- /* Huh? No environment at all? */\r
- service->env = service->env_extra;\r
- service->envlen = service->env_extralen;\r
- }\r
- }\r
-\r
- service->env_extra = 0;\r
- service->env_extralen = 0;\r
- }\r
-\r
/* Try to get priority - may fail. */\r
unsigned long priority;\r
if (get_number(key, NSSM_REG_PRIORITY, &priority, false) == 1) {\r
if (get_number(key, NSSM_REG_ROTATE_BYTES_LOW, &service->rotate_bytes_low, false) != 1) service->rotate_bytes_low = 0;\r
if (get_number(key, NSSM_REG_ROTATE_BYTES_HIGH, &service->rotate_bytes_high, false) != 1) service->rotate_bytes_high = 0;\r
\r
+ /* Try to get force new console setting - may fail. */\r
+ if (get_number(key, NSSM_REG_NO_CONSOLE, &service->no_console, false) != 1) service->no_console = 0;\r
+\r
/* Change to startup directory in case stdout/stderr are relative paths. */\r
TCHAR cwd[PATH_LENGTH];\r
GetCurrentDirectory(_countof(cwd), cwd);\r