|
Hi Peter, Below is an example I dug up from somewhere a while ago (I didn't write it but I believe it works fine). What it demonstrates it the use of the ShellExecuteA procedure within the SHELL32.dll (part of the Win32 API). This procedure is used to invoke an exe within the Windows environment. You can pass it flags and parameters to be passed to the invoked exe. The example will require you to create a window (WIN1) with a pushbutton (PSBRUN). Notepad will be executed when you click on the button. Once you get the idea you simply need to find out which dll contains the rand() function and prototype it using the *STDCALL linkage, as below. However, note the REALLY, REALLY useful ShellExecuteA procedure. An example I have (somewhere) is to load a VARPG subfile from the iSeries using server calls. The user can then click a button to "export to Excel". The VARPG app then uses ShellExecuteA to open a new named workbook, with a named worksheet and then uses DDE to populate the spreadsheet. The uses of dll linkage and DDE can be unbelievable. For example, you can read data from a subfile and it will automatically populate a spreadsheet (bar chart, pie chart, etc). Have fun Cheers Larry ********************************************************************* * * * Program ID . . : ShellExe.VPG * * * * Description . : Demonstrates using Win32API to run local *.EXE's * * * * Function . . . : * * * * Messages . . . : * * * * Files . . . . : * * * * Input . . . . : * * * * Output . . . . : * * * ********************************************************************* H*EXE H*NOMAIN * ------------------------------------------------------------------- * Windows DLL for executing commands on the PC * ------------------------------------------------------------------- DShellExecuteA PR 10u 0 ExtProc('ShellExecuteA') D DLL('SHELL32.dll') D Linkage(*StdCall) D 10U 0 Value Window Handle D * Value Operation D * Value File/Cmd/Path D * Value Parameters D * Value Directory D 10U 0 Value Show command *-------------------------------------------------------------------- * Work Variables for API *-------------------------------------------------------------------- D hWnd S 10U 0 Window handle D ulRc S 10U 0 Return Code D cParms S 2000a D cDir S 1000a D Operation S 7a Inz('open ') D lpOperation S * Inz(%Addr(Operation)) Operation Address D lpCmdStg S * Inz(%Addr(CommandString)) file name Address D lpcParms S * Inz(%Addr(cParms)) Parms Address D lpcDir S * Inz(%Addr(cDir)) Directory Name Address *------------------------------------------------------------------ * Local Work Variables *------------------------------------------------------------------ DCommandString S 2000a Inz('C:\WINNT\Notepad.exe') *++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ * * ShellCmd - Execute Windows Command * *++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ C ShellCmd Begsr * C Eval hWnd = %getatr('WIN1':'WIN1': C 'Handle') C Eval CommandString = %trim(CommandString) + x'00' C Eval Operation = %trim(Operation) + x'00' C Eval cParms = %trim(cParms) + x'00' C Eval ulRc = ShellExecutea(hWnd:lpOperation: C lpCmdStg:lpcParms:lpcDir:1) C Endsr ********************************************************************* * * Window . . : WIN1 * * Part . . . : PSBRUN * * Event . . : PRESS * * Description: User clicks on the Notepad.exe application * ********************************************************************* * C PSBRUN BEGACT PRESS WIN1 * C Exsr ShellCmd * C ENDACT
As an Amazon Associate we earn from qualifying purchases.
This mailing list archive is Copyright 1997-2025 by midrange.com and David Gibbs as a compilation work. Use of the archive is restricted to research of a business or technical nature. Any other uses are prohibited. Full details are available on our policy page. If you have questions about this, please contact [javascript protected email address].
Operating expenses for this site are earned using the Amazon Associate program and Google Adsense.