https://git.reactos.org/?p=reactos.git;a=commitdiff;h=2d47c3be2987662333573b...
commit 2d47c3be2987662333573b65051f498f92d90dc3 Author: Mark Jansen mark.jansen@reactos.org AuthorDate: Sat Oct 13 00:20:58 2018 +0200 Commit: Mark Jansen mark.jansen@reactos.org CommitDate: Sat Oct 13 20:30:07 2018 +0200
[CRT] spawn: define a unicode environment when needed CORE-9182 --- sdk/lib/crt/process/process.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-)
diff --git a/sdk/lib/crt/process/process.c b/sdk/lib/crt/process/process.c index f607c2eed3..ef6ad4d8fa 100644 --- a/sdk/lib/crt/process/process.c +++ b/sdk/lib/crt/process/process.c @@ -203,6 +203,7 @@ do_spawnT(int mode, const _TCHAR* cmdname, const _TCHAR* args, const _TCHAR* env BOOL bResult; DWORD dwExitCode; DWORD dwError; + DWORD dwFlags = 0;
TRACE(MK_STR(do_spawnT)"(%i,'%"sT"','%"sT"','%"sT"')",mode,cmdname,args,envp);
@@ -286,12 +287,20 @@ do_spawnT(int mode, const _TCHAR* cmdname, const _TCHAR* args, const _TCHAR* env
create_io_inherit_block(&StartupInfo.cbReserved2, &StartupInfo.lpReserved2);
+ if (mode == _P_DETACH) + { + dwFlags |= DETACHED_PROCESS; + } +#ifdef _UNICODE + dwFlags |= CREATE_UNICODE_ENVIRONMENT; +#endif + bResult = CreateProcess((_TCHAR *)cmdname, (_TCHAR *)args, NULL, NULL, TRUE, - mode == _P_DETACH ? DETACHED_PROCESS : 0, + dwFlags, (LPVOID)envp, NULL, &StartupInfo,