CreateProcessEx

Runs an external process using the CreateProcessEx API including the ability to redirect output to a file and Wait for completion.

CreateProcessEx has a number of advantages over using the RUN command including a much longer command line limit and the ability to understand long filenames correctly.

CreateProcessEx provides the ability to pipe output into an output file - a feature that is not available for the simpler CreateProcess function.

CreateProcessEx(lcExe, lcCommandLine, 
                lcStartDirectory, lnShowWindow, 
                llWaitForCompletion,
                lcStdOutputFilename)

.t. or .f.

Parameters

lcExe
Full path to the EXE file. You need a full path even if the file lives in the SYSTEM directory.

lcCommandLine
Optional - Command line arguments for the application.

lcStartDirectory
Optional - The directory that the application runs out of. Don't pass to use the current directory.

lnShowWindow
Optional - The display mode/sizing of how the window is displayed. Uses a numeric value that comes from standard Windows API values:

foxpro
foxpro
SW_HIDE 0 SW_SHOWNORMAL 1 SW_NORMAL 1 SW_SHOWMINIMIZED 2 SW_SHOWMAXIMIZED 3 SW_MAXIMIZE 3 SW_SHOWNOACTIVATE 4 SW_SHOW 5 SW_MINIMIZE 6 SW_SHOWMINNOACTIVE 7 SW_SHOWNA 8 SW_RESTORE 9 SW_SHOWDEFAULT 10 SW_FORCEMINIMIZE 11 SW_MAX 11

llWaitForCompletion
If .T. waits for the process to complete before control returns back to FoxPro. This is a common requirement for execution so you can capture output and determine success of an operation. Note: internally handled via WaitHandles to get around CreateProcess' asynchronous nature.

lcStdOutputFileName
Allows you to specify a file that captures the Standard Output results. Great for capturing output from Console applications directly to a file.

Remarks

This function is a standalone function and not a member of the wwAPI class.

This function requires wwIpstuff.dll.

Example

foxpro
foxpro
FUNCTION SetACL(lcPath,lcUser,lcAccess,llInherit,llReplace) LOCAL lcCommand, lcFile, lcParms *** Strip off any trailing backslashes IF RIGHT(lcPath,1)="\" AND LEN(lcPath) > 1 lcPath = SUBSTR(lcPath,1,LEN(lcPath)-1) ENDIF lcParms = ShortPath( lcPath) IF llInherit lcParms = lcParms + " /T " ENDIF IF !llReplace lcParms = lcParms + " /E " ENDIF lcParms = lcParms + " /P " + lcUser + ":" + lcAccess *** Use CreateProcessEx if wwIPStuff is available *** so we don't get flashing DOS Windows LOCAL oAPI oAPI = CREATEOBJECT("wwAPI") CreateProcessEx( oAPI.GetSystemDir() + "cacls.exe",ALLTRIM(lcParms),0,.t.,; FULLPATH("cacls.txt"))

See also

Class wwAPI

© West Wind Technologies, 2025 • Updated: 2025-03-12
Comment or report problem with topic