1'************************************************************************* 2' 3' Licensed to the Apache Software Foundation (ASF) under one 4' or more contributor license agreements. See the NOTICE file 5' distributed with this work for additional information 6' regarding copyright ownership. The ASF licenses this file 7' to you under the Apache License, Version 2.0 (the 8' "License"); you may not use this file except in compliance 9' with the License. You may obtain a copy of the License at 10' 11' http://www.apache.org/licenses/LICENSE-2.0 12' 13' Unless required by applicable law or agreed to in writing, 14' software distributed under the License is distributed on an 15' "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY 16' KIND, either express or implied. See the License for the 17' specific language governing permissions and limitations 18' under the License. 19' 20'************************************************************************* 21'### Support Module for running macros in Word. Excel and PowerPoint 22'### using automation 23 24CONST CDA_TITLE = "Document Analysis Run Macro" 25CONST CDA_ANALYSIS_INI = "analysis.ini" 26Const CDA_ERR_STD_DELAY = 10 27Const CDA_APPNAME_WORD = "Word" 28Const CDA_APPNAME_EXCEL = "Excel" 29Const CDA_APPNAME_POWERPOINT = "PowerPoint" 30 31Dim daWrd 32Dim daDoc 33Dim daXl 34Dim daWb 35Dim daPP 36Dim daPres 37Dim daWshShell 38Dim daFso 39Dim daTitle 40 41daTitle = CDA_TITLE 42 43'# Setup Scripting objects 44set daFso = WScript.CreateObject("Scripting.FileSystemObject") 45set daWshShell = Wscript.CreateObject("Wscript.Shell") 46 47 48'##### Run Macro FUNCTIONS ###### 49 50'###################### 51Sub DASetTitle(newTitle) 52 daTitle = newTitle 53End Sub 54 55'###################### 56Sub DAsetupWrdServer 57 58On Error Resume Next 59 60Set daWrd = wscript.CreateObject("Word.Application") 61If Err.Number <> 0 Then 62 DAErrMsg "Failed to create Word Automation server: " & vbLf & vbLf & "Error: " _ 63 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 64 FinalExit 65End If 66 67End Sub 68 69'###################### 70Sub DAOpenWrdDriver(driver) 71Dim sWordDriverDocPath 72 73On Error Resume Next 74daWrd.Visible = False 75 76'# Open a driver doc 77sWordDriverDocPath = daFso.GetAbsolutePathName(driver) 78'DAdiagMsg "sWordDriverDocPath : " & sWordDriverDocPath , CDIAG_STD_DELAY 79 80If Not daFso.FileExists(sWordDriverDocPath) Then 81 DAErrMsg "Driver doc does not exist: " & sWordDriverDocPath, CDA_ERR_STD_DELAY 82 FinalExit 83End If 84 85Set daDoc = daWrd.Documents.Open(sWordDriverDocPath) 86If Err.Number <> 0 Then 87 DAErrMsg "Failed to open driver doc: " & vbLf & sWordDriverDocPath & vbLf & vbLf & "Error: " _ 88 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 89 FinalExit 90End If 91 92End Sub 93 94'###################### 95Function DArunWrdDriver(driver, macro) 96 97On Error Resume Next 98'# Run macro 99DArunWrdDriver = True 100daWrd.Run ("AnalysisTool." & macro) 101If Err.Number <> 0 Then 102 DAErrMsg "Failed to run macro: " & macro & vbLf & vbLf & "Error: " _ 103 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 104 DArunWrdDriver = False 105End If 106 107End Function 108 109'###################### 110Sub DAsaveWrdDriver(saveDriver) 111'DAdiagMsg "saveDriver : " & saveDriver , CDIAG_STD_DELAY 112'DAdiagMsg "Abs(saveDriver) : " & daFso.GetAbsolutePathName( saveDriver) , CDIAG_STD_DELAY 113 daDoc.SaveAs daFso.GetAbsolutePathName( saveDriver) 114End Sub 115 116'###################### 117Sub DAsetupExcelServer 118 119On Error Resume Next 120 121Set daXl = wscript.CreateObject("Excel.Application") 122If Err.Number <> 0 Then 123 DAErrMsg "Failed to create Excel Automation server: " & vbLf & vbLf & "Error: " _ 124 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 125 FinalExit 126End If 127 128End Sub 129 130'###################### 131Sub DAOpenExcelDriver(driver) 132 Dim sExcelDriverDocPath 133 134 On Error Resume Next 135 daXl.Visible = False 136 137 '# Open driver doc 138 sExcelDriverDocPath = daFso.GetAbsolutePathName(driver) 139 If Not daFso.FileExists(sExcelDriverDocPath) Then 140 DAErrMsg "Driver doc does not exist: " & sExcelDriverDocPath, CDA_ERR_STD_DELAY 141 FinalExit 142 End If 143 144 Set daWb = daXl.Workbooks.Open(sExcelDriverDocPath) 145 If Err.Number <> 0 Then 146 DAErrMsg "Failed to open driver doc: " & vbLf & sExcelDriverDocPath & vbLf & vbLf & "Error: " _ 147 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 148 FinalExit 149 End If 150 151End Sub 152 153'###################### 154Function DArunExcelDriver(driver, macro) 155On Error Resume Next 156 157'# Run macro 158DArunExcelDriver = True 159daXl.Run ("AnalysisTool." & macro) 160If Err.Number <> 0 Then 161 DAErrMsg "Failed to run macro: " & macro & vbLf & vbLf & "Error: " _ 162 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 163 DArunExcelDriver = False 164End If 165 166End Function 167 168'###################### 169Sub DAsaveExcelDriver(saveDriver) 170 '# Not overwritting - Excel hangs, need to remove file first 171 if daFso.FileExists(daFso.GetAbsolutePathName(saveDriver)) Then 172 daFso.DeleteFile(daFso.GetAbsolutePathName(saveDriver)) 173 End If 174 daWb.SaveAs daFso.GetAbsolutePathName(saveDriver) 175End Sub 176 177'###################### 178Sub DAsetupPPServer 179 180On Error Resume Next 181 182Set daPP = wscript.CreateObject("PowerPoint.Application") 183If Err.Number <> 0 Then 184 DAErrMsg "Failed to create PowerPoint Automation server: " & vbLf & vbLf & "Error: " _ 185 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 186 FinalExit 187End If 188 189End Sub 190 191'###################### 192Sub DAOpenPPDriver(driver) 193Dim sPPDriverDocPath 194 195On Error Resume Next 196 197 198'# Open driver doc 199sPPDriverDocPath = daFso.GetAbsolutePathName(driver) 200If Not daFso.FileExists(sPPDriverDocPath ) Then 201 DAErrMsg "Driver doc does not exist: " & sPPDriverDocPath, CDA_ERR_STD_DELAY 202 FinalExit 203End If 204 205 206'## MS: KB Article 155073 ## 207'# PPT7: OLE Automation Error Using Open Method 208'# MUST show the PowerPoint application window at least once before calling the Application.Presentations.Open method 209daPP.Visible = True 210daPP.WindowState = 2 'Minimize PowerPoint 211 212daPP.Presentations.Open sPPDriverDocPath 213If Err.Number <> 0 Then 214 DAErrMsg "Failed to open driver doc: " & vbLf & sPPDriverDocPath & vbLf & vbLf & "Error: " _ 215 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 216 FinalExit 217End If 218 219set daPres = daPP.Presentations(1) 220 221End Sub 222 223'###################### 224Function DArunPPDriver(driver, macro) 225 226On Error Resume Next 227'# Run macro 228DArunPPDriver = True 229daPP.Run (daFso.GetFileName(driver) & "!" & macro) 230If Err.Number <> 0 Then 231 DAErrMsg "Failed to run macro: " & macro & vbLf & vbLf & "Error: " _ 232 & CStr(Err.Number) & " " & Err.Description, CDA_ERR_STD_DELAY 233 DArunPPDriver = False 234End If 235 236End Function 237 238'###################### 239Sub DAsavePPDriver(saveDriver) 240 daPres.SaveAs daFso.GetAbsolutePathName(saveDriver) 241End Sub 242 243 244'###################### 245 246Sub DACloseApps() 247 '# Quit apps 248 On Error Resume Next 249 If Not daWrd Is Nothing Then 250 daDoc.Close wdDoNotSaveChanges 251 daWrd.Quit 252 End If 253 If Not daXl Is Nothing Then 254 daWb.Close False 255 daXl.Quit 256 End If 257 If Not daPP Is Nothing Then 258 daPres.Close 259 daPP.Quit 260 End If 261 262 Set daDoc = Nothing 263 Set daWb = Nothing 264 Set daPres = Nothing 265 266 Set daWrd = Nothing 267 Set daXl = Nothing 268 Set daPP = Nothing 269End Sub 270 271'###################### 272 273Sub DACleanUp() 274 '# Quit apps 275 On Error Resume Next 276 277 DACloseApps 278 279 Set daFso = Nothing 280 Set daWshShell = Nothing 281End Sub 282 283 284'###################### 285Sub DAdiagMsg( msg, delay) 286 '# WSHShell.echo: Popup if run with Wscript.exe, command line output if run with Cscript.exe 287 WScript.Echo msg 288 289 'WSHShell.popup msg, delay, daTitle, 64 290End Sub 291 292'###################### 293Sub DAErrMsg( msg, delay) 294 daWshShell.Popup msg, delay, daTitle, 16 295 296 'WScript.Echo msg 297End Sub 298 299 300'###################### 301Sub DAVerifyAnalysisIni() 302 if daFso.FileExists(daFso.GetAbsolutePathName(".\" & CDA_ANALYSIS_INI)) Then Exit Sub 303 304 DAErrMsg CDA_ANALYSIS_INI & " does not exist. " & vbLf & vbLf & _ 305 "You need to create it manually or use the DocAnalysisWizard to create one for you." & vbLf & _ 306 "Once this is done you can rerun the Document Analysis command line.", CDA_ERR_STD_DELAY 307 FinalExit 308End Sub 309 310'###################### 311Sub DAExportFile(fileName, projectFile, app_name) 312 On Error Resume Next 313 314 Dim myProject 315 316 '# Setup App Specifc VB Project 317 Set myProject = DAgetProject(fileName, projectFile, app_name) 318 319 Dim myComponent 320 Set myComponent = myProject.VBComponents(projectFile) 321 If Err.Number <> 0 Then 322 DAErrMsg "Missing Project File [" & projectFile & "] - Path:" & vbLf & vbLf & fileName, CERR_STD_DELAY 323 Set myComponent = Nothing 324 Set myProject = Nothing 325 FinalExit 326 End If 327 328 myProject.VBComponents(projectFile).Export fileName 329 If Err.Number <> 0 Then 330 DAErrMsg "Error exporting Project File [" & projectFile & "] - Path:" & vbLf & vbLf & fileName, CERR_STD_DELAY 331 Set myComponent = Nothing 332 Set myProject = Nothing 333 FinalExit 334 End If 335 336 Set myComponent = Nothing 337 Set myProject = Nothing 338 339End Sub 340 341'###################### 342Sub DAImportFile(fileName, projectFile, app_name) 343 On Error Resume Next 344 345 Dim myProject 346 347 '# Setup App Specifc VB Project 348 Set myProject = DAgetProject(fileName, projectFile, app_name) 349 350 '# Check if module already exists raise error 351 Dim myComponent 352 Set myComponent = myProject.VBComponents(projectFile) 353 If Err.Number = 0 Then 354 DAErrMsg "Duplicate Project File [" & projectFile & "] - Path:" & vbLf & vbLf & fileName, CERR_STD_DELAY 355 Set myComponent = Nothing 356 Set myProject = Nothing 357 FinalExit 358 End If 359 360 '#If module not there need to clear out of index error 361 Err.Clear 362 363 If Not daFso.FileExists(fileName) Then 364 DAErrMsg "Missing File " & fileName, CERR_STD_DELAY 365 Set myComponent = Nothing 366 Set myProject = Nothing 367 FinalExit 368 End If 369 370 Call myProject.VBComponents.Import(fileName) 371 372 If Err.Number <> 0 Then 373 DAErrMsg "Error importing Project File [" & projectFile & "] - Path:" & vbLf & vbLf & fileName, CERR_STD_DELAY 374 Set myComponent = Nothing 375 Set myProject = Nothing 376 FinalExit 377 End If 378 379 Set myComponent = Nothing 380 Set myProject = Nothing 381End Sub 382 383'################# 384 385Sub DARemoveModule(fileName, projectFile, app_name) 386 On Error Resume Next 387 388 Dim myProject 389 390 '# Setup App Specifc VB Project 391 Set myProject = DAgetProject(fileName, projectFile, app_name) 392 393 '# Check if module already exists raise error 394 Dim myComponent 395 Set myComponent = myProject.VBComponents(projectFile) 396 397 398 myProject.VBComponents.Remove myComponent 399 400 If Err.Number <> 0 Then 401 DAErrMsg "Error removing Project File [" & projectFile & "] - Path:" & vbLf & vbLf & fileName, CERR_STD_DELAY 402 Set myComponent = Nothing 403 Set myProject = Nothing 404 FinalExit 405 End If 406 407 Set myComponent = Nothing 408 Set myProject = Nothing 409End Sub 410 411'###################### 412Function DAgetProject(fileName, projectFile, app_name) 413 On Error Resume Next 414 415 If app_name = CDA_APPNAME_WORD Then 416 Set DAgetProject = daWrd.ActiveDocument.VBProject 417 418 ElseIf app_name = CDA_APPNAME_EXCEL Then 419 Set DAgetProject = daXl.ActiveWorkbook.VBProject 420 421 ElseIf app_name = CDA_APPNAME_POWERPOINT Then 422 Set DAgetProject = daPP.ActivePresentation.VBProject 423 End If 424 425 If Err.Number <> 0 Then 426 DAErrMsg "Cannot access VBProject for Project File [" & projectFile & "] - Path:" & vbLf & vbLf & fileName, _ 427 CERR_STD_DELAY 428 Set DAgetProject = Nothing 429 FinalExit 430 End If 431 432End Function 433 434