Commit b129a148 authored by Ferenc Wagner's avatar Ferenc Wagner Committed by Alexandre Julliard

Implement >> style (append) output redirection.

parent 643b7c97
...@@ -258,7 +258,7 @@ void WCMD_process_command (char *command) ...@@ -258,7 +258,7 @@ void WCMD_process_command (char *command)
{ {
char *cmd, *p; char *cmd, *p;
int status, i, len; int status, i, len;
DWORD count; DWORD count, creationDisposition;
HANDLE old_stdin = 0, old_stdout = 0, h; HANDLE old_stdin = 0, old_stdout = 0, h;
char *whichcmd; char *whichcmd;
SECURITY_ATTRIBUTES sa; SECURITY_ATTRIBUTES sa;
...@@ -307,16 +307,27 @@ void WCMD_process_command (char *command) ...@@ -307,16 +307,27 @@ void WCMD_process_command (char *command)
SetStdHandle (STD_INPUT_HANDLE, h); SetStdHandle (STD_INPUT_HANDLE, h);
} }
if ((p = strchr(cmd,'>')) != NULL) { if ((p = strchr(cmd,'>')) != NULL) {
h = CreateFile (WCMD_parameter (++p, 0, NULL), GENERIC_WRITE, 0, &sa, CREATE_ALWAYS, *p++ = '\0';
if ('>' == *p) {
creationDisposition = OPEN_ALWAYS;
p++;
}
else {
creationDisposition = CREATE_ALWAYS;
}
h = CreateFile (WCMD_parameter (p, 0, NULL), GENERIC_WRITE, 0, &sa, creationDisposition,
FILE_ATTRIBUTE_NORMAL, NULL); FILE_ATTRIBUTE_NORMAL, NULL);
if (h == INVALID_HANDLE_VALUE) { if (h == INVALID_HANDLE_VALUE) {
WCMD_print_error (); WCMD_print_error ();
HeapFree( GetProcessHeap(), 0, cmd ); HeapFree( GetProcessHeap(), 0, cmd );
return; return;
} }
if (SetFilePointer (h, 0, NULL, FILE_END) ==
INVALID_SET_FILE_POINTER) {
WCMD_print_error ();
}
old_stdout = GetStdHandle (STD_OUTPUT_HANDLE); old_stdout = GetStdHandle (STD_OUTPUT_HANDLE);
SetStdHandle (STD_OUTPUT_HANDLE, h); SetStdHandle (STD_OUTPUT_HANDLE, h);
*--p = '\0';
} }
if ((p = strchr(cmd,'<')) != NULL) *p = '\0'; if ((p = strchr(cmd,'<')) != NULL) *p = '\0';
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment