OVH Cloud OVH Cloud

PB Fct ShellWait

1 réponse
Avatar
yohann
Mon problème est le suivant:
J'utilise la fonction suivante (qui se trouve sur ce site) qui permet de
lancer l'exécution d'une tâche et d'attendre la fin de celle-ci pour
continuer la procedure en cours. Cette fonction marche trés bien avec
n'importe qu'elle programme. Mais quand je veux exécuter un autre programme
access et que je ferme celle-ci, mon programme ne reprend pas. J'ai
l'impression que pour que l'exécution du programme reprenne, il faut qu'il
n'y ait plus aucun access ouvert (Ce qui est impossible puisque le programme
s'exécute à partir d'access).
Je comprend pas puisque la fonction AppExecuter se sert du handle et que
celui-ci est unique pour chaque access ouvert.

si quelqu'un à une idée.

Option Compare Database
Option Explicit

Private Const Priorité_Normale = &H20&
Private Const Infini = -1&
Dim Name_Process As Info_Process
Dim Name_Initial As Info_Initiale
Dim ProcessOK As Long

Private Declare Function AppFermer Lib "kernel32" Alias "CloseHandle" _
(hObject As Long) As Boolean

Private Declare Function AppExecuter Lib "kernel32" Alias
"WaitForSingleObject" _
(ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long

Private Declare Function AppProcess Lib "kernel32" Alias "CreateProcessA" _
(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, _
lpInfo_Initiale As Info_Initiale, _
lpProcessInformation As Info_Process) As Long

Private Type Info_Initiale
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

Private Type Info_Process
hProcess As Long
hThread As Long
dwProcessId As Long
dwThreadID As Long
End Type

Public Function ShellWait(AppName As String) As Boolean
Name_Initial.cb = Len(Name_Initial)
ProcessOK = AppProcess(0&, AppName, 0&, 0&, 1&, _
Priorité_Normale, 0&, 0&, Name_Initial, Name_Process)
If ProcessOK <> 0 Then
Call AppExecuter(Name_Process.hProcess, Infini)
Call AppFermer(Name_Process.hProcess)
ShellWait = True
Else
ShellWait = False
End If
End Function

1 réponse

Avatar
Raymond [mvp]
Bonsoir.

la commande Shellwait envoie un paramètre msaccess.exe qui est identique au
process appelant et déjà, ici, windows se mélange les pattes.
Il a toujours été convenu qu'une application access devait être lancée par
shell ou par automation. le shell n'apportant rien à une autre application
access, il est d'usage de toujours communiquer access-access par automation,
ce qui apporte un plus important à une application.

--
@+
Raymond Access MVP
http://OfficeSystem.Access.free.fr/
http://users.skynet.be/mpfa/ pour débuter sur le forum


"yohann" a écrit dans le message de news:

Mon problème est le suivant:
J'utilise la fonction suivante (qui se trouve sur ce site) qui permet de
lancer l'exécution d'une tâche et d'attendre la fin de celle-ci pour
continuer la procedure en cours. Cette fonction marche trés bien avec
n'importe qu'elle programme. Mais quand je veux exécuter un autre
programme
access et que je ferme celle-ci, mon programme ne reprend pas. J'ai
l'impression que pour que l'exécution du programme reprenne, il faut qu'il
n'y ait plus aucun access ouvert (Ce qui est impossible puisque le
programme
s'exécute à partir d'access).
Je comprend pas puisque la fonction AppExecuter se sert du handle et que
celui-ci est unique pour chaque access ouvert.

si quelqu'un à une idée.

Option Compare Database
Option Explicit

Private Const Priorité_Normale = &H20&
Private Const Infini = -1&
Dim Name_Process As Info_Process
Dim Name_Initial As Info_Initiale
Dim ProcessOK As Long

Private Declare Function AppFermer Lib "kernel32" Alias "CloseHandle" _
(hObject As Long) As Boolean

Private Declare Function AppExecuter Lib "kernel32" Alias
"WaitForSingleObject" _
(ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long

Private Declare Function AppProcess Lib "kernel32" Alias "CreateProcessA"
_
(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, _
lpInfo_Initiale As Info_Initiale, _
lpProcessInformation As Info_Process) As Long

Private Type Info_Initiale
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

Private Type Info_Process
hProcess As Long
hThread As Long
dwProcessId As Long
dwThreadID As Long
End Type

Public Function ShellWait(AppName As String) As Boolean
Name_Initial.cb = Len(Name_Initial)
ProcessOK = AppProcess(0&, AppName, 0&, 0&, 1&, _
Priorité_Normale, 0&, 0&, Name_Initial, Name_Process)
If ProcessOK <> 0 Then
Call AppExecuter(Name_Process.hProcess, Infini)
Call AppFermer(Name_Process.hProcess)
ShellWait = True
Else
ShellWait = False
End If
End Function