-
Notifications
You must be signed in to change notification settings - Fork 3
/
openWindow.BAK
39 lines (36 loc) · 1.14 KB
/
openWindow.BAK
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
OpenWindow("D:\DESARROLLO\MigDBFtoMySQL\migdbftomysql.exe", "Versión beta v102", _screen)
FUNCTION OpenWindow(tcEXE AS STRING, tcTitle AS STRING, toForm AS object)
IF !FILE(SUBSTR(tcEXE, 1, AT(".EXE", UPPER(tcEXE),1) + 4))
WAIT "La ruta o el nombre del archivo no son válidos!" WINDOW NOWAIT
RETURN .F.
ENDIF
LOCAL nHwnd AS INTEGER
nHwnd = 0
DECLARE INTEGER WinExec IN kernel32 STRING lpCmdLine, INTEGER nCmdShow
DECLARE INTEGER FindWindow IN user32 STRING lpClassName, STRING lpWindowName
DECLARE INTEGER SetParent IN user32 INTEGER hWndChild, INTEGER hWndNewParent
DO WHILE .T.
=WinExec(tcEXE, 1)
nHwnd = FindWindow(NULL, tcTitle)
nSec = SECONDS() + 5
DO WHILE EMPTY(nHwnd) AND SECONDS() < nSec
WAIT "Esperando por el archivo ejecutable... (" + ALLTRIM(STR(SECONDS())) + ")" WINDOW NOWAIT
IF nHwnd > 0
EXIT
ENDIF
ENDDO
IF EMPTY(nHwnd)
IF MESSAGEBOX("Parece que el archivo ejecutable no ha cargado correctamente." + CHR(13) + "¿Que desea realizar?",5 + 32, "Aviso") = 2
EXIT
ENDIF
ELSE
EXIT
ENDIF
ENDDO
IF nHwnd > 0
SetParent(nHwnd,toForm.HWND)
RETURN .T.
ELSE
RETURN .F.
ENDIF
ENDFUNC