SABER SE UM PROGRAMA ESTA EM EXECUCAO

CAIO.FR.SP 21/01/2010 16:24:21
#332524
galera preciso de uma funçao que faça o seguinte: verifique se um programa esta em execução, se estiver ela aguarda ate que o programa seja finalizada para continuar.
aguem pode me ajudar.
F001E 21/01/2010 17:01:10
#332534
Faz esse teste ....isso aki tira o Programa da Lista de Processo do windows....dai vc Implementa o Resto...tenta ae

Private Declare Function FindWindow Lib [Ô]user32[Ô] Alias [Ô]FindWindowA[Ô] _
(ByVal ilClasse As String, ByVal lpWindowName As String) As Long
Private Declare Function ShowWindow Lib [Ô]user32[Ô] (ByVal hwnd As Long, _
ByVal nCmdShow As Long) As Long
Private Declare Function SetForegroundWindow Lib [Ô]user32[Ô] (ByVal hwnd As Long) As Long


Private Sub MDIForm_Unload(Cancel As Integer)
On Error GoTo Erro
Dim vhwnd As Long
Dim hSnapShot As Long, hProcess As Long
Dim uProcess As PROCESSENTRY32
Dim I As Long

31: vhwnd = FindWindow(vbNullString, [Ô]Magic - Controle Geral dos Sistemas[Ô])
32: Call ShowWindow(vhwnd, 3)
33: Call SetForegroundWindow(vhwnd)

[ô]Finaliza Winoldap na lista de Processos do Windows
1: hSnapShot = CreateToolhelpSnapshot(2, 0)
2: uProcess.dwSize = LenB(uProcess)
3: hProcess = Process32First(hSnapShot, uProcess)
4: Do While hProcess
5: hProcess = Process32Next(hSnapShot, uProcess)
6: If UCase(InStr(UCase(Replace(uProcess.szExeFile, Chr(0), [Ô][Ô])), [Ô]MFOLHA.EXE[Ô])) <> 0 Then
7: hProcess = OpenProcess(&H1F0FFF, 1, uProcess.th32ProcessID)
8: TerminateProcess hProcess, 0
9: Exit Sub
10: End If
11: Loop

Exit Sub
Erro:
TratarErro [Ô]frmPrincipal[Ô], [Ô]MDIForm_Unload[Ô], Err.Number, Err.Description, Erl
End Sub


CAIO.FR.SP 21/01/2010 18:10:25
#332543
é quase isso
so que nao posso finalizar o programa que esta em execução, eu tenho que espera ele finalizar sozinho.
F001E 22/01/2010 09:28:28
#332583
vixi kara....mas dependendo do .exe...nao finaliza Sozinho não....tive que montar esse Código pq o Processo não Finalizava...a não ser que Reiniciava o Pc,,,caso contrário...ficava rodando no Processo e não finalizava sozinho não...
CAIO.FR.SP 22/01/2010 12:00:41
#332604
nao mais este finaliza sim, é o seguinte criei um programa de compactação de arquivos tipo winzip, e uso ele como um modulo auxiliar nos meus outros projetos.
ai quando vou efetuar o backup em meus projetos xamo esse modulo de compactação via linha de comando. o que o modulo faz é apenas carregar, efetuar a compactação, e finalizar. tudo automatico. entao precisa apenas esperar que ele finalize para que eu volte a usar meu projeto com conexao ao db.
WEBMASTER 22/01/2010 13:02:49
#332613
Faz um while entao... e de preferencia use um timer.
MARCELO.TREZE 22/01/2010 13:13:55
#332616
Resposta escolhida
Caio veja se isto te ajuda

em um módulo cole

Public Type STARTUPINFO
cb As Long
lpReserved As String
lpDesktop As String
lpTitle As String
dwX As Long
dwY As Long
dwXSize As Long
dwYSize As Long
dwXCountChars As Long
dwYCountChars As Long
dwFillAttribute As Long
dwFlags As Long
wShowWindow As Integer
cbReserved2 As Integer
lpReserved2 As Long
hStdInput As Long
hStdOutput As Long
hStdError As Long
End Type

Public Type PROCESS_INFORMATION
hProcess As Long
hThread As Long
dwProcessID As Long
dwThreadID As Long
End Type

Public Declare Function WaitForSingleObject Lib _
[Ô]kernel32[Ô] (ByVal hHandle As Long, ByVal dwMilliseconds _
As Long) As Long

Declare Function CreateProcessA Lib [Ô]kernel32[Ô] _
(ByVal lpApplicationName As Long, ByVal lpCommandLine As _
String, ByVal lpProcessAttributes As Long, ByVal _
lpThreadAttributes As Long, ByVal bInheritHandles As Long, _
ByVal dwCreationFlags As Long, ByVal lpEnvironment As Long, _
ByVal lpCurrentDirectory As Long, lpStartupInfo As _
STARTUPINFO, lpProcessInformation As PROCESS_INFORMATION) _
As Long

Declare Function CloseHandle Lib [Ô]kernel32[Ô] (ByVal hObject _
As Long) As Long

Public Const NORMAL_PRIORITY_CLASS = &H20&
Public Const INFINITE = -1&


2-) A seguir insira o seguinte código no formulário padrão:

Public Sub ExecCmd(cmdline$)
Dim proc As PROCESS_INFORMATION
Dim start As STARTUPINFO

[ô]Inicia a strutura STARTUPINFO
start.cb = Len(start)

[ô]Inicia a aplicação escolhida para ser executada
ret& = CreateProcessA(0&, cmdline$, 0&, 0&, 1&, _
NORMAL_PRIORITY_CLASS, 0&, 0&, start, proc)

[ô]Aguarda a aplicação iniciada terminar
ret& = WaitForSingleObject(proc.hProcess, INFINITE)
ret& = CloseHandle(proc.hProcess)
End Sub


3-) Agora adicione um botão de comando - command1 - ao formulário e no evento click do botão digite o seguinte código:

Private Sub Command1_Click()

Call ExecCmd([Ô]c:\seu programa de zipar.exe[Ô])

MsgBox [Ô]O seu programa foi encerrado[Ô]

End Sub



bom vc irá chamar seu programa e quando ele for encerrado vc saberá
CAIO.FR.SP 23/01/2010 10:52:22
#332683
isso mesmo MARCELO, genial.
abraços a todos.
Tópico encerrado , respostas não são mais permitidas