-
Notifications
You must be signed in to change notification settings - Fork 65
/
ShellWait.bas
193 lines (166 loc) · 6.64 KB
/
ShellWait.bas
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
Attribute VB_Name = "ShellWait"
Option Explicit
#If Mac Then
Public Function Execute(ByVal CommandLine As String, StartupDir As String, Optional debugMode As Boolean = False, Optional WaitTime As Long = -1) As Long
Dim TeXExePath As String
TeXExePath = GetFolderFromPath(GetITSetting("TeXExePath", DEFAULT_TEX_EXE_PATH))
If TeXExePath <> vbNullString Then
TeXExePath = TeXExePath & ":"
End If
Dim TeXExtraPath As String
TeXExtraPath = GetITSetting("TeXExtraPath", DEFAULT_TEX_EXTRA_PATH)
If TeXExtraPath <> vbNullString Then
TeXExtraPath = TeXExtraPath & ":"
End If
If debugMode Then
ShowError vbNullString, CommandLine, "Debug mode", "Next command:", "Continue"
End If
Execute = CLng(AppleScriptTask("IguanaTex.scpt", "MacExecute", _
"export PATH=" & ShellEscape(TeXExePath) & ShellEscape(TeXExtraPath) & """$PATH""" & " && " & _
"cd " & ShellEscape(StartupDir) & " && " & _
CommandLine))
End Function
#Else
' Portions of code below taken from:
' http://www.mvps.org/access/api/api0004.htm
' Courtesy of Terry Kreft
Private Const STARTF_USESHOWWINDOW As Long = &H1
Private Const NORMAL_PRIORITY_CLASS = &H20&
Private Const INFINITE = -1&
Private 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
Private Type PROCESS_INFORMATION
hProcess As Long
hThread As Long
dwProcessID As Long
dwThreadId As Long
End Type
#If VBA7 Then
Private Declare PtrSafe Function WaitForSingleObject Lib "kernel32" (ByVal _
hHandle As Long, ByVal dwMilliseconds As Long) As Long
Private Declare PtrSafe 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 String, _
lpStartupInfo As STARTUPINFO, lpProcessInformation As _
PROCESS_INFORMATION) As Long
Private Declare PtrSafe Function CloseHandle Lib "kernel32" (ByVal _
hObject As Long) As Long
Private Declare PtrSafe Function GetExitCodeProcess Lib "kernel32" _
(ByVal hProcess As Long, lpExitCode As Long) As Long
Private Declare PtrSafe Function GetLastError Lib "kernel32" () As Long
Public Declare PtrSafe Function TerminateProcess Lib "kernel32" _
(ByVal hProcess As Long, ByVal uExitCode As Long) As Long
Public Declare PtrSafe Function ShellExecute Lib "shell32.dll" _
Alias "ShellExecuteA" (ByVal hWnd As Long, ByVal Operation As String, _
ByVal FileName As String, Optional ByVal Parameters As String, _
Optional ByVal directory As String, _
Optional ByVal WindowStyle As Long = vbMinimizedFocus _
) As Long
#Else
Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal _
hHandle As Long, ByVal dwMilliseconds As Long) As Long
Private 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 String, _
lpStartupInfo As STARTUPINFO, lpProcessInformation As _
PROCESS_INFORMATION) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal _
hObject As Long) As Long
Private Declare Function GetExitCodeProcess Lib "kernel32" _
(ByVal hProcess As Long, lpExitCode As Long) As Long
Private Declare Function GetLastError Lib "kernel32" () As Long
Public Declare Function TerminateProcess Lib "kernel32" _
(ByVal hProcess As Long, ByVal uExitCode As Long) As Long
Public Declare Function ShellExecute Lib "shell32.dll" _
Alias "ShellExecuteA" (ByVal hWnd As Long, ByVal Operation As String, _
ByVal Filename As String, Optional ByVal Parameters As String, _
Optional ByVal Directory As String, _
Optional ByVal WindowStyle As Long = vbMinimizedFocus _
) As Long
#End If
Public Function ShellWait(pathname As String, Optional StartupDir As String, Optional WindowStyle As Long, Optional WaitTime As Long = -1) As Long
Dim proc As PROCESS_INFORMATION
Dim start As STARTUPINFO
Dim ret As Long
Dim exitcode As Long
Dim lastError As Long
Dim retWait As Long
' Initialize the STARTUPINFO structure:
With start
.cb = Len(start)
If Not IsMissing(WindowStyle) Then
.dwFlags = STARTF_USESHOWWINDOW
.wShowWindow = WindowStyle
End If
End With
Dim sdir As String
If IsMissing(StartupDir) Then
sdir = vbNullString
Else
sdir = StartupDir
End If
' Start the shelled application:
ret& = CreateProcessA(0&, pathname, 0&, 0&, 1&, _
NORMAL_PRIORITY_CLASS, 0&, sdir, start, proc)
lastError& = GetLastError()
If (ret& = 0) Then
MsgBox "Could not start process: '" & pathname & "'. GetLastError returned " & Str$(lastError&)
ShellWait = 1
Exit Function
End If
' Wait for the shelled application to finish:
If WaitTime > 0 Then
retWait& = WaitForSingleObject(proc.hProcess, WaitTime)
Else
retWait& = WaitForSingleObject(proc.hProcess, INFINITE)
End If
' Get return value
exitcode& = 1234
ret& = GetExitCodeProcess(proc.hProcess, exitcode&)
If (ret& = 0) Then
lastError& = GetLastError()
MsgBox "GetExitCodeProcess returned " + Str$(ret&) + ", GetLastError returned " + Str$(lastError&)
End If
' Tidy up if time out
If (retWait& = 258) Then
ret& = TerminateProcess(proc.hProcess, 0)
End If
' Close handle
ret& = CloseHandle(proc.hProcess)
ShellWait = exitcode&
End Function
Public Function Execute(CommandLine As String, StartupDir As String, Optional debugMode As Boolean = False, Optional WaitTime As Long = -1) As Long
Dim RetVal As Long
If debugMode Then
' Clipboard CommandLine
' MsgBox CommandLine, , StartupDir
ShowError vbNullString, CommandLine, "Debug mode", "Next command:", "Continue"
RetVal = ShellWait(CommandLine, StartupDir, 1&, WaitTime)
Else
RetVal = ShellWait(CommandLine, StartupDir, , WaitTime)
End If
Execute = RetVal
End Function
#End If ' Mac