Advertisement
Guest User

verinfo.bas

a guest
Feb 20th, 2018
95
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1.  
  2. Option Explicit
  3.  
  4. ' file informations
  5. Public Filename     As String     ' file pathname
  6. Public StrucVer     As String     ' file info struct version
  7. Public FileVer      As String     ' file version
  8. Public ProdVer      As String     ' product version
  9. Public FileFlags    As String     ' file flags
  10. Public FileOS       As String     ' file OS
  11. Public FileType     As String     ' file type
  12. Public FileSubType  As String     ' file subtype
  13.  
  14. ' https://msdn.microsoft.com/en-us/library/windows/desktop/ms646997(v=vs.85).aspx
  15. Private Type VS_FIXEDFILEINFO
  16.    dwSignature As Long
  17.    dwStrucVersionl As Integer     '  e.g. = &h0000 = 0
  18.   dwStrucVersionh As Integer     '  e.g. = &h0042 = .42
  19.   dwFileVersionMSl As Integer    '  e.g. = &h0003 = 3
  20.   dwFileVersionMSh As Integer    '  e.g. = &h0075 = .75
  21.   dwFileVersionLSl As Integer    '  e.g. = &h0000 = 0
  22.   dwFileVersionLSh As Integer    '  e.g. = &h0031 = .31
  23.   dwProductVersionMSl As Integer '  e.g. = &h0003 = 3
  24.   dwProductVersionMSh As Integer '  e.g. = &h0010 = .1
  25.   dwProductVersionLSl As Integer '  e.g. = &h0000 = 0
  26.   dwProductVersionLSh As Integer '  e.g. = &h0031 = .31
  27.   dwFileFlagsMask As Long        '  = &h3F for version "0.42"
  28.   dwFileFlags As Long            '  e.g. VFF_DEBUG Or VFF_PRERELEASE
  29.   dwFileOS As Long               '  e.g. VOS_DOS_WINDOWS16
  30.   dwFileType As Long             '  e.g. VFT_DRIVER
  31.   dwFileSubtype As Long          '  e.g. VFT2_DRV_KEYBOARD
  32.   dwFileDateMS As Long           '  e.g. 0
  33.   dwFileDateLS As Long           '  e.g. 0
  34. End Type
  35.  
  36. ' version and support APIs
  37.  
  38. Private Declare Function GetFileVersionInfo Lib "Version.dll" Alias _
  39.    "GetFileVersionInfoA" (ByVal lptstrFilename As String, ByVal _
  40.    dwhandle As Long, ByVal dwlen As Long, lpData As Any) As Long
  41.    
  42. Private Declare Function GetFileVersionInfoSize Lib "Version.dll" Alias _
  43.    "GetFileVersionInfoSizeA" (ByVal lptstrFilename As String, _
  44.    lpdwHandle As Long) As Long
  45.    
  46. Private Declare Function VerQueryValue Lib "Version.dll" Alias _
  47.    "VerQueryValueA" (pBlock As Any, ByVal lpSubBlock As String, _
  48.    lplpBuffer As Any, puLen As Long) As Long
  49.    
  50. Private Declare Sub MoveMemory Lib "kernel32" Alias "RtlMoveMemory" _
  51.    (dest As Any, ByVal Source As Long, ByVal length As Long)
  52.  
  53. Private Declare Function GetSystemDirectory Lib "kernel32" Alias _
  54.    "GetSystemDirectoryA" (ByVal Path As String, _
  55.                           ByVal cbBytes As Long) As Long
  56.  
  57. ' ===== From Win32 Ver.h =================
  58.  
  59. ' ----- VS_VERSION.dwFileFlags -----
  60. Private Const VS_FFI_SIGNATURE = &HFEEF04BD
  61. Private Const VS_FFI_STRUCVERSION = &H10000
  62. Private Const VS_FFI_FILEFLAGSMASK = &H3F&
  63.  
  64. ' ----- VS_VERSION.dwFileFlags -----
  65. Private Const VS_FF_DEBUG = &H1
  66. Private Const VS_FF_PRERELEASE = &H2
  67. Private Const VS_FF_PATCHED = &H4
  68. Private Const VS_FF_PRIVATEBUILD = &H8
  69. Private Const VS_FF_INFOINFERRED = &H10
  70. Private Const VS_FF_SPECIALBUILD = &H20
  71.  
  72. ' ----- VS_VERSION.dwFileOS -----
  73. Private Const VOS_UNKNOWN = &H0
  74. Private Const VOS_DOS = &H10000
  75. Private Const VOS_OS216 = &H20000
  76. Private Const VOS_OS232 = &H30000
  77. Private Const VOS_NT = &H40000
  78.  
  79. Private Const VOS__BASE = &H0
  80. Private Const VOS__WINDOWS16 = &H1
  81. Private Const VOS__PM16 = &H2
  82. Private Const VOS__PM32 = &H3
  83. Private Const VOS__WINDOWS32 = &H4
  84.  
  85. Private Const VOS_DOS_WINDOWS16 = &H10001
  86. Private Const VOS_DOS_WINDOWS32 = &H10004
  87. Private Const VOS_OS216_PM16 = &H20002
  88. Private Const VOS_OS232_PM32 = &H30003
  89. Private Const VOS_NT_WINDOWS32 = &H40004
  90.  
  91. ' ----- VS_VERSION.dwFileType -----
  92. Private Const VFT_UNKNOWN = &H0
  93. Private Const VFT_APP = &H1
  94. Private Const VFT_DLL = &H2
  95. Private Const VFT_DRV = &H3
  96. Private Const VFT_FONT = &H4
  97. Private Const VFT_VXD = &H5
  98. Private Const VFT_STATIC_LIB = &H7
  99.  
  100. ' ----- VS_VERSION.dwFileSubtype for VFT_WINDOWS_DRV -----
  101. Private Const VFT2_UNKNOWN = &H0
  102. Private Const VFT2_DRV_PRINTER = &H1
  103. Private Const VFT2_DRV_KEYBOARD = &H2
  104. Private Const VFT2_DRV_LANGUAGE = &H3
  105. Private Const VFT2_DRV_DISPLAY = &H4
  106. Private Const VFT2_DRV_MOUSE = &H5
  107. Private Const VFT2_DRV_NETWORK = &H6
  108. Private Const VFT2_DRV_SYSTEM = &H7
  109. Private Const VFT2_DRV_INSTALLABLE = &H8
  110. Private Const VFT2_DRV_SOUND = &H9
  111. Private Const VFT2_DRV_COMM = &HA
  112.  
  113. ' fonts
  114. Private Const VFT_FONT_RASTER = &H1&
  115. Private Const VFT_FONT_VECTOR = &H2&
  116. Private Const VFT_FONT_TRUETYPE = &H3&
  117.  
  118. Public Function LoadVerInfo(ByVal sFileName As String) As Boolean
  119.    Dim rc                As Long
  120.    Dim lDummy            As Long
  121.    Dim sBuffer()         As Byte
  122.    Dim lBufferLen        As Long
  123.    Dim lVerPointer       As Long
  124.    Dim udtVerBuffer      As VS_FIXEDFILEINFO
  125.    Dim lVerbufferLen     As Long
  126.  
  127.    '*** Initialize ****
  128.   LoadVerInfo = False
  129.    Filename = sFileName
  130.  
  131.    '*** Get size ****
  132.   lBufferLen = GetFileVersionInfoSize(Filename, lDummy)
  133.    If lBufferLen < 1 Then
  134.       Exit Function
  135.    End If
  136.  
  137.    '**** Store info to udtVerBuffer struct ****
  138.   ReDim sBuffer(lBufferLen)
  139.    rc = GetFileVersionInfo(Filename, 0&, lBufferLen, sBuffer(0))
  140.    rc = VerQueryValue(sBuffer(0), "\", lVerPointer, lVerbufferLen)
  141.    MoveMemory udtVerBuffer, lVerPointer, Len(udtVerBuffer)
  142.  
  143.    '**** Determine Structure Version number - NOT USED ****
  144.   StrucVer = Format$(udtVerBuffer.dwStrucVersionh) & "." & _
  145.       Format$(udtVerBuffer.dwStrucVersionl)
  146.  
  147.    '**** Determine File Version number ****
  148.   FileVer = Format$(udtVerBuffer.dwFileVersionMSh) & "." & _
  149.       Format$(udtVerBuffer.dwFileVersionMSl) & "." & _
  150.       Format$(udtVerBuffer.dwFileVersionLSh) & "." & _
  151.       Format$(udtVerBuffer.dwFileVersionLSl)
  152.  
  153.    '**** Determine Product Version number ****
  154.   ProdVer = Format$(udtVerBuffer.dwProductVersionMSh) & "." & _
  155.       Format$(udtVerBuffer.dwProductVersionMSl) & "." & _
  156.       Format$(udtVerBuffer.dwProductVersionLSh) & "." & _
  157.       Format$(udtVerBuffer.dwProductVersionLSl)
  158.  
  159.    '**** Determine Boolean attributes of File ****
  160.   FileFlags = ""
  161.    If udtVerBuffer.dwFileFlags And VS_FF_DEBUG _
  162.       Then FileFlags = "Debug "
  163.    If udtVerBuffer.dwFileFlags And VS_FF_PRERELEASE _
  164.       Then FileFlags = FileFlags & "PreRel "
  165.    If udtVerBuffer.dwFileFlags And VS_FF_PATCHED _
  166.       Then FileFlags = FileFlags & "Patched "
  167.    If udtVerBuffer.dwFileFlags And VS_FF_PRIVATEBUILD _
  168.       Then FileFlags = FileFlags & "Private "
  169.    If udtVerBuffer.dwFileFlags And VS_FF_INFOINFERRED _
  170.       Then FileFlags = FileFlags & "Info "
  171.    If udtVerBuffer.dwFileFlags And VS_FF_SPECIALBUILD _
  172.       Then FileFlags = FileFlags & "Special "
  173.    If udtVerBuffer.dwFileFlags And VFT2_UNKNOWN _
  174.       Then FileFlags = FileFlags + "Unknown "
  175.  
  176.    '**** Determine OS for which file was designed ****
  177.   Select Case udtVerBuffer.dwFileOS
  178.       Case VOS_DOS_WINDOWS16
  179.         FileOS = "DOS-Win16"
  180.       Case VOS_DOS_WINDOWS32
  181.         FileOS = "DOS-Win32"
  182.       Case VOS_OS216_PM16
  183.         FileOS = "OS/2-16 PM-16"
  184.       Case VOS_OS232_PM32
  185.         FileOS = "OS/2-16 PM-32"
  186.       Case VOS_NT_WINDOWS32
  187.         FileOS = "NT-Win32"
  188.       Case Else
  189.         FileOS = "Unknown"
  190.    End Select
  191.    Select Case udtVerBuffer.dwFileType
  192.       Case VFT_APP
  193.          FileType = "App"
  194.       Case VFT_DLL
  195.          FileType = "DLL"
  196.       Case VFT_DRV
  197.          FileType = "Driver"
  198.          Select Case udtVerBuffer.dwFileSubtype
  199.             Case VFT2_DRV_PRINTER
  200.                FileSubType = "Printer drv"
  201.             Case VFT2_DRV_KEYBOARD
  202.                FileSubType = "Keyboard drv"
  203.             Case VFT2_DRV_LANGUAGE
  204.                FileSubType = "Language drv"
  205.             Case VFT2_DRV_DISPLAY
  206.                FileSubType = "Display drv"
  207.             Case VFT2_DRV_MOUSE
  208.                FileSubType = "Mouse drv"
  209.             Case VFT2_DRV_NETWORK
  210.                FileSubType = "Network drv"
  211.             Case VFT2_DRV_SYSTEM
  212.                FileSubType = "System drv"
  213.             Case VFT2_DRV_INSTALLABLE
  214.                FileSubType = "Installable"
  215.             Case VFT2_DRV_SOUND
  216.                FileSubType = "Sound drv"
  217.             Case VFT2_DRV_COMM
  218.                FileSubType = "Comm drv"
  219.             Case VFT2_UNKNOWN
  220.                FileSubType = "Unknown"
  221.          End Select
  222.       Case VFT_FONT
  223.          FileType = "Font"
  224.          Select Case udtVerBuffer.dwFileSubtype
  225.             Case VFT_FONT_RASTER
  226.                FileSubType = "Raster Font"
  227.             Case VFT_FONT_VECTOR
  228.                FileSubType = "Vector Font"
  229.             Case VFT_FONT_TRUETYPE
  230.                FileSubType = "TrueType Font"
  231.          End Select
  232.       Case VFT_VXD
  233.          FileType = "VxD"
  234.       Case VFT_STATIC_LIB
  235.          FileType = "Lib"
  236.       Case Else
  237.          FileType = "Unknown"
  238.    End Select
  239.    
  240.    LoadVerInfo = True
  241. End Function
  242.  
  243. ' usage sample
  244. Sub Main()
  245.   Dim sFileName
  246.   Dim sMsg
  247.  
  248.   If Len(Command) > 0 Then
  249.     ' use given pathname
  250.    sFileName = Command
  251.   Else
  252.     ' use default (ntdll.dll)
  253.    sFileName = Environ("SYSTEMROOT") & "\System32\ntdll.dll"
  254.   End If
  255.  
  256.   ' try loading version informations
  257.  If Not LoadVerInfo(sFileName) Then
  258.     sMsg = "Cannot read version informations from " & sFileName
  259.     MsgBox sMsg, vbOKOnly + vbExclamation, "Version Info"
  260.     Exit Sub
  261.   End If
  262.  
  263.   ' display informations
  264.  sMsg = "Filename : " & sFileName & vbCrLf & _
  265.          "File version : " & FileVer & vbCrLf & _
  266.          "Product version : " & ProdVer & vbCrLf & _
  267.          "File flags : " & FileFlags & vbCrLf & _
  268.          "File OS : " & FileOS & vbCrLf & _
  269.          "File type : " & FileType & vbCrLf & _
  270.          "File subtype : " & FileSubType & vbCrLf
  271.          
  272.   MsgBox sMsg, vbOKOnly + vbInformation, "Version Info"
  273. End Sub
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement