table of contents
SDL_ProcessIO(3type) | SDL3 DATATYPES | SDL_ProcessIO(3type) |
NAME¶
SDL_ProcessIO - Description of where standard I/O should be directed when creating a process.
SYNOPSIS¶
#include <SDL3/SDL_process.h>
typedef enum SDL_ProcessIO { SDL_PROCESS_STDIO_INHERITED, /**< The I/O stream is inherited from the application. */ SDL_PROCESS_STDIO_NULL, /**< The I/O stream is ignored. */ SDL_PROCESS_STDIO_APP, /**< The I/O stream is connected to a new SDL_IOStream that the application can read or write */ SDL_PROCESS_STDIO_REDIRECT /**< The I/O stream is redirected to an existing SDL_IOStream. */ } SDL_ProcessIO;
DESCRIPTION¶
If a standard I/O stream is set to SDL_PROCESS_STDIO_INHERITED, it will go to the same place as the application's I/O stream. This is the default for standard output and standard error.
If a standard I/O stream is set to SDL_PROCESS_STDIO_NULL, it is connected to NUL: on Windows and /dev/null on POSIX systems. This is the default for standard input.
If a standard I/O stream is set to SDL_PROCESS_STDIO_APP, it is connected to a new SDL_IOStream that is available to the application. Standard input will be available as SDL_PROP_PROCESS_STDIN_POINTER and allows SDL_GetProcessInput(), standard output will be available as SDL_PROP_PROCESS_STDOUT_POINTER and allows SDL_ReadProcess() and SDL_GetProcessOutput(), and standard error will be available as SDL_PROP_PROCESS_STDERR_POINTER in the properties for the created process.
If a standard I/O stream is set to SDL_PROCESS_STDIO_REDIRECT, it is connected to an existing SDL_IOStream provided by the application. Standard input is provided using SDL_PROP_PROCESS_CREATE_STDIN_POINTER, standard output is provided using SDL_PROP_PROCESS_CREATE_STDOUT_POINTER, and standard error is provided using SDL_PROP_PROCESS_CREATE_STDERR_POINTER in the creation properties. These existing streams should be closed by the application once the new process is created.
In order to use an SDL_IOStream with SDL_PROCESS_STDIO_REDIRECT, it must have SDL_PROP_IOSTREAM_WINDOWS_HANDLE_POINTER or SDL_PROP_IOSTREAM_FILE_DESCRIPTOR_NUMBER set. This is true for streams representing files and process I/O.
AVAILABILITY¶
This enum is available since SDL 3.2.0.
SEE ALSO¶
SDL_CreateProcessWithProperties(3), SDL_GetProcessProperties(3), SDL_ReadProcess(3), SDL_GetProcessInput(3), SDL_GetProcessOutput(3)
SDL 3.2.14 | Simple Directmedia Layer |