Solved

How do I get the errorlevel from a dos app?

Posted on 1997-06-09
3
566 Views
Last Modified: 2012-05-04
I want to run pkunzip from a VB5 and can't figure out how to get the errorlevel after it has run. Thanks
0
Comment
Question by:Breez
  • 2
3 Comments
 
LVL 5

Accepted Solution

by:
y96andha earned 100 total points
ID: 1427024
You can start it with CreateProcess and retrieve the errorlevel with GetExitCodeProcess.
0
 

Author Comment

by:Breez
ID: 1427025
umm, CreateProcess and GetExitCodeProccess seem to apply to C++. What would the VisualBasic equivalent be?

thanks
0
 
LVL 5

Expert Comment

by:y96andha
ID: 1427026
They can be used in VB as well.

This is code for declarations:

Private Const INFINITE = &HFFFF                    '  Infinite timeout
Private Const SW_SHOW = 5
Private Const STARTF_USESHOWWINDOW = &H1
Private Const NORMAL_PRIORITY_CLASS = &H20
Private Type STARTUPINFO
        cb As Long
        lpReserved As Long
        lpDesktop As Long
        lpTitle As Long
        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 Byte
        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
Private Declare Function CreateProcess Lib "kernel32" Alias "CreateProcessA" (ByVal lpApplicationName As String, ByVal lpCommandLine As String, ByVal lpProcessAttributes As String, ByVal lpThreadAttributes As String, ByVal bInheritHandles As Long, ByVal dwCreationFlags As Long, ByVal lpEnvironment As String, ByVal lpCurrentDirectory As String, lpStartupInfo As STARTUPINFO, lpProcessInformation As PROCESS_INFORMATION) As Long
Private Declare Function GetExitCodeProcess Lib "kernel32" (ByVal hProcess As Long, lpExitCode As Long) As Long
Private Declare Function CloseHandle Lib "kernel32" (ByVal hObject As Long) As Long
Private Declare Function WaitForSingleObject Lib "kernel32" (ByVal hHandle As Long, ByVal dwMilliseconds As Long) As Long

This is code to execute pkunzip:

    Dim sinfo As STARTUPINFO
    Dim pinfo As PROCESS_INFORMATION
    Dim success As Integer
    Dim ExitCode As Long
    sinfo.cb = Len(sinfo)
    sinfo.lpTitle = 0
    sinfo.lpReserved = 0
    sinfo.lpDesktop = 0
    sinfo.cbReserved2 = 0
    sinfo.lpReserved2 = 0
    sinfo.dwFlags = STARTF_USESHOWWINDOW
    sinfo.wShowWindow = SW_SHOW
   
   
    success = CreateProcess(vbNullString, "pkunzip c:\adsads.zip", vbNullString, vbNullString, False, NORMAL_PRIORITY_CLASS, vbNullString, vbNullString, sinfo, pinfo)
    If success = 0 Then
        Debug.Print "CreateProcess failed"
        Exit Sub
    End If
    WaitForSingleObject pinfo.hProcess, INFINITE
    success = GetExitCodeProcess(pinfo.hProcess, ExitCode)
    If success <> 0 Then
        Debug.Print "Exit code: "; ExitCode
    Else
        Debug.Print "GetExitCodeProcess failed"
    End If
    CloseHandle pinfo.hProcess
    CloseHandle pinfo.hThread


If you want to be able to do other things while pkunzip is running, the code can be easily modified to do that, just call GetExitCodeProcess regularly, and as long as the process is running it will return 259.





0

Featured Post

6 Surprising Benefits of Threat Intelligence

All sorts of threat intelligence is available on the web. Intelligence you can learn from, and use to anticipate and prepare for future attacks.

Join & Write a Comment

Introduction While answering a recent question about filtering a custom class collection, I realized that this could be accomplished with very little code by using the ScriptControl (SC) library.  This article will introduce you to the SC library a…
Background What I'm presenting in this article is the result of 2 conditions in my work area: We have a SQL Server production environment but no development or test environment; andWe have an MS Access front end using tables in SQL Server but we a…
Get people started with the utilization of class modules. Class modules can be a powerful tool in Microsoft Access. They allow you to create self-contained objects that encapsulate functionality. They can easily hide the complexity of a process from…
Show developers how to use a criteria form to limit the data that appears on an Access report. It is a common requirement that users can specify the criteria for a report at runtime. The easiest way to accomplish this is using a criteria form that a…

743 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

8 Experts available now in Live!

Get 1:1 Help Now