Class Kernel32Util

java.lang.Object
com.sun.jna.platform.win32.Kernel32Util
All Implemented Interfaces:
WinDef

public abstract class Kernel32Util extends Object implements WinDef
Kernel32 utility API.
Author:
dblock[at]dblock.org, markus[at]headcrashing[dot]eu, Andreas "PAX" Lück, onkelpax-git[at]yahoo.de
  • Field Details

  • Constructor Details

    • Kernel32Util

      public Kernel32Util()
  • Method Details

    • getComputerName

      public static String getComputerName()
      Get current computer NetBIOS name.
      Returns:
      Netbios name.
    • freeLocalMemory

      public static void freeLocalMemory(Pointer ptr)
      Invokes Kernel32.LocalFree(Pointer) and checks if it succeeded.
      Parameters:
      ptr - The Pointer to the memory to be released - ignored if NULL
      Throws:
      Win32Exception - if non-ERROR_SUCCESS code reported
    • freeGlobalMemory

      public static void freeGlobalMemory(Pointer ptr)
      Invokes Kernel32.GlobalFree(Pointer) and checks if it succeeded.
      Parameters:
      ptr - The Pointer to the memory to be released - ignored if NULL
      Throws:
      Win32Exception - if non-ERROR_SUCCESS code reported
    • closeHandleRefs

      public static void closeHandleRefs(WinNT.HANDLEByReference... refs)
      Closes all referenced handles. If an exception is thrown for a specific handle, then it is accumulated until all handles have been closed. If more than one exception occurs, then it is added as a suppressed exception to the first one. Once closed all handles, the accumulated exception (if any) is thrown
      Parameters:
      refs - The references to close
      See Also:
    • closeHandleRef

      public static void closeHandleRef(WinNT.HANDLEByReference ref)
      Closes the handle in the reference
      Parameters:
      ref - The handle reference - ignored if null
      See Also:
    • closeHandles

      public static void closeHandles(WinNT.HANDLE... handles)
      Invokes closeHandle(WinNT.HANDLE) on each handle. If an exception is thrown for a specific handle, then it is accumulated until all handles have been closed. If more than one exception occurs, then it is added as a suppressed exception to the first one. Once closed all handles, the accumulated exception (if any) is thrown
      Parameters:
      handles - The handles to be closed
      See Also:
    • closeHandle

      public static void closeHandle(WinNT.HANDLE h)
      Invokes Kernel32.CloseHandle(WinNT.HANDLE) and checks the success code. If not successful, then throws a Win32Exception with the GetLastError value
      Parameters:
      h - The handle to be closed - ignored if null
    • formatMessage

      public static String formatMessage(int code)
      Format a message from the value obtained from Kernel32.GetLastError() or Native.getLastError().
      Parameters:
      code - The error code
      Returns:
      Formatted message.
    • formatMessage

      public static String formatMessage(WinNT.HRESULT code)
      Format a message from an HRESULT.
      Parameters:
      code - HRESULT
      Returns:
      Formatted message.
    • formatMessageFromLastErrorCode

      public static String formatMessageFromLastErrorCode(int code)
      Format a system message from an error code.
      Parameters:
      code - Error code, typically a result of GetLastError.
      Returns:
      Formatted message.
    • getLastErrorMessage

      public static String getLastErrorMessage()
      Returns:
      Obtains the human-readable error message text from the last error that occurred by invocating Kernel32.GetLastError().
    • getTempPath

      public static String getTempPath()
      Return the path designated for temporary files.
      Returns:
      Path.
    • deleteFile

      public static void deleteFile(String filename)
    • getLogicalDriveStrings

      public static List<String> getLogicalDriveStrings()
      Returns valid drives in the system.
      Returns:
      A List of valid drives.
    • getFileAttributes

      public static int getFileAttributes(String fileName)
      Retrieves file system attributes for a specified file or directory.
      Parameters:
      fileName - The name of the file or directory.
      Returns:
      The attributes of the specified file or directory.
    • getFileType

      public static int getFileType(String fileName) throws FileNotFoundException
      Retrieves the result of GetFileType, provided the file exists.
      Parameters:
      fileName - file name
      Returns:
      file type
      Throws:
      FileNotFoundException - if file not found
    • getDriveType

      public static int getDriveType(String rootName)
      Parameters:
      rootName - name of root drive
      Returns:
      One of the WinBase.DRIVE_* constants.
    • getEnvironmentVariable

      public static String getEnvironmentVariable(String name)
      Get the value of an environment variable.
      Parameters:
      name - Name of the environment variable.
      Returns:
      Value of an environment variable.
    • getEnvironmentVariables

      public static Map<String,String> getEnvironmentVariables()
      Uses the Kernel32.GetEnvironmentStrings() to retrieve and parse the current process environment
      Returns:
      The current process environment as a Map.
      Throws:
      LastErrorException - if failed to get or free the environment data block
      See Also:
    • getEnvironmentVariables

      public static Map<String,String> getEnvironmentVariables(Pointer lpszEnvironmentBlock, long offset)
      Parameters:
      lpszEnvironmentBlock - The environment block as received from the GetEnvironmentStrings function
      offset - Offset within the block to parse the data
      Returns:
      A Map of the parsed name=value pairs. Note: if the environment block is null then null is returned instead of an empty map since we want to distinguish between the case that the data block is null and when there are no environment variables (as unlikely as it may be)
    • readEnvironmentStringBlockEntry

      public static String readEnvironmentStringBlockEntry(Pointer lpszEnvironmentBlock, long offset, boolean asWideChars)
      Parameters:
      lpszEnvironmentBlock - The environment block as received from the GetEnvironmentStrings function
      offset - Offset within the block to look for the entry
      asWideChars - If true then the block contains wchar_t instead of "plain old" chars
      Returns:
      A String containing the name=value pair or empty if reached end of block
      See Also:
    • findEnvironmentStringBlockEntryEnd

      public static long findEnvironmentStringBlockEntryEnd(Pointer lpszEnvironmentBlock, long offset, boolean asWideChars)
      Parameters:
      lpszEnvironmentBlock - The environment block as received from the GetEnvironmentStrings function
      offset - Offset within the block to look for the entry
      asWideChars - If true then the block contains wchar_t instead of "plain old" chars
      Returns:
      The offset of the first '\0' in the data block starting at the specified offset - can be the start offset itself if empty string.
      See Also:
    • isWideCharEnvironmentStringBlock

      public static boolean isWideCharEnvironmentStringBlock(Pointer lpszEnvironmentBlock, long offset)

      Attempts to determine whether the data block uses wchar_t instead of "plain old" chars. It does that by reading 2 bytes from the specified offset - the character value and its charset indicator - and examining them as follows:

      • If the charset indicator is non-zero then it is assumed to be a "plain old" chars data block. Note: the assumption is that the environment variable name (at least) is ASCII.
      • Otherwise (i.e., zero charset indicator), it is assumed to be a wchar_t
      Note: the code takes into account the ByteOrder even though only ByteOrder.LITTLE_ENDIAN is the likely one
      Parameters:
      lpszEnvironmentBlock - The environment block as received from the GetEnvironmentStrings function
      offset - offset
      Returns:
      true if the block contains wchar_t instead of "plain old" chars
    • getPrivateProfileInt

      public static final int getPrivateProfileInt(String appName, String keyName, int defaultValue, String fileName)
      Retrieves an integer associated with a key in the specified section of an initialization file.
      Parameters:
      appName - The name of the section in the initialization file.
      keyName - The name of the key whose value is to be retrieved. This value is in the form of a string; the Kernel32.GetPrivateProfileInt(java.lang.String, java.lang.String, int, java.lang.String) function converts the string into an integer and returns the integer.
      defaultValue - The default value to return if the key name cannot be found in the initialization file.
      fileName - The name of the initialization file. If this parameter does not contain a full path to the file, the system searches for the file in the Windows directory.
      Returns:
      The retrieved integer, or the default if not found.
    • getPrivateProfileString

      public static final String getPrivateProfileString(String lpAppName, String lpKeyName, String lpDefault, String lpFileName)
      Retrieves a string from the specified section in an initialization file.
      Parameters:
      lpAppName - The name of the section containing the key name. If this parameter is null, the Kernel32.GetPrivateProfileString(java.lang.String, java.lang.String, java.lang.String, char[], com.sun.jna.platform.win32.WinDef.DWORD, java.lang.String) function copies all section names in the file to the supplied buffer.
      lpKeyName - The name of the key whose associated string is to be retrieved. If this parameter is null, all key names in the section specified by the lpAppName parameter are returned.
      lpDefault - A default string. If the lpKeyName key cannot be found in the initialization file, Kernel32.GetPrivateProfileString(java.lang.String, java.lang.String, java.lang.String, char[], com.sun.jna.platform.win32.WinDef.DWORD, java.lang.String) returns the default. If this parameter is null, the default is an empty string, "".

      Avoid specifying a default string with trailing blank characters. The function inserts a null character in the lpReturnedString buffer to strip any trailing blanks.

      lpFileName - The name of the initialization file. If this parameter does not contain a full path to the file, the system searches for the file in the Windows directory.
      Returns:

      If neither lpAppName nor lpKeyName is null and the destination buffer is too small to hold the requested string, the string is truncated.

      If either lpAppName or lpKeyName is null and the destination buffer is too small to hold all the strings, the last string is truncated and followed by two null characters.

      In the event the initialization file specified by lpFileName is not found, or contains invalid values, this function will set errorno with a value of '0x2' (File Not Found). To retrieve extended error information, call Kernel32.GetLastError().

    • writePrivateProfileString

      public static final void writePrivateProfileString(String appName, String keyName, String string, String fileName)
    • getLogicalProcessorInformation

      public static final WinNT.SYSTEM_LOGICAL_PROCESSOR_INFORMATION[] getLogicalProcessorInformation()
      Convenience method to get the processor information. Takes care of auto-growing the array.
      Returns:
      the array of processor information.
    • getLogicalProcessorInformationEx

      public static final WinNT.SYSTEM_LOGICAL_PROCESSOR_INFORMATION_EX[] getLogicalProcessorInformationEx(int relationshipType)
      Convenience method to get the processor information. Takes care of auto-growing the array and populating variable-length arrays in structures.
      Parameters:
      relationshipType - The type of relationship to retrieve. This parameter can be one of the following values: WinNT.LOGICAL_PROCESSOR_RELATIONSHIP.RelationCache, WinNT.LOGICAL_PROCESSOR_RELATIONSHIP.RelationGroup, WinNT.LOGICAL_PROCESSOR_RELATIONSHIP.RelationNumaNode, WinNT.LOGICAL_PROCESSOR_RELATIONSHIP.RelationProcessorCore, WinNT.LOGICAL_PROCESSOR_RELATIONSHIP.RelationProcessorPackage, or WinNT.LOGICAL_PROCESSOR_RELATIONSHIP.RelationAll
      Returns:
      the array of processor information.
    • getPrivateProfileSection

      public static final String[] getPrivateProfileSection(String appName, String fileName)
      Retrieves all the keys and values for the specified section of an initialization file.

      Each string has the following format: key=string.

      This operation is atomic; no updates to the specified initialization file are allowed while this method is executed.

      Parameters:
      appName - The name of the section in the initialization file.
      fileName - The name of the initialization file. If this parameter does not contain a full path to the file, the system searches for the file in the Windows directory.
      Returns:
      The key name and value pairs associated with the named section.
    • getPrivateProfileSectionNames

      public static final String[] getPrivateProfileSectionNames(String fileName)
      Retrieves the names of all sections in an initialization file.

      This operation is atomic; no updates to the initialization file are allowed while this method is executed.

      Parameters:
      fileName - The name of the initialization file. If this parameter is NULL, the function searches the Win.ini file. If this parameter does not contain a full path to the file, the system searches for the file in the Windows directory.
      Returns:
      the section names associated with the named file.
    • writePrivateProfileSection

      public static final void writePrivateProfileSection(String appName, String[] strings, String fileName)
      Parameters:
      appName - The name of the section in which data is written. This section name is typically the name of the calling application.
      strings - The new key names and associated values that are to be written to the named section. Each entry must be of the form key=value.
      fileName - The name of the initialization file. If this parameter does not contain a full path for the file, the function searches the Windows directory for the file. If the file does not exist and lpFileName does not contain a full path, the function creates the file in the Windows directory.
    • queryDosDevice

      public static final List<String> queryDosDevice(String lpszDeviceName, int maxTargetSize)
      Invokes the Kernel32.QueryDosDevice(String, char[], int) method and parses the result
      Parameters:
      lpszDeviceName - The device name
      maxTargetSize - The work buffer size to use for the query
      Returns:
      The parsed result
    • getVolumePathNamesForVolumeName

      public static final List<String> getVolumePathNamesForVolumeName(String lpszVolumeName)
      Parameters:
      lpszVolumeName - The volume name
      Returns:
      The parsed result
      Throws:
      Win32Exception - If failed to retrieve the required information
    • extractVolumeGUID

      public static final String extractVolumeGUID(String volumeGUIDPath)
      Parses and returns the pure GUID value of a volume name obtained from Kernel32.FindFirstVolume(char[], int) or Kernel32.FindNextVolume(com.sun.jna.platform.win32.WinNT.HANDLE, char[], int) calls
      Parameters:
      volumeGUIDPath - The volume GUID path as returned by one of the above mentioned calls
      Returns:
      The pure GUID value after stripping the "\\?\" prefix and removing the trailing backslash.
      Throws:
      IllegalArgumentException - if bad format encountered
      See Also:
    • QueryFullProcessImageName

      public static final String QueryFullProcessImageName(WinNT.HANDLE hProcess, int dwFlags)
      This function retrieves the full path of the executable file of a given process.
      Parameters:
      hProcess - Handle for the running process
      dwFlags - 0 - The name should use the Win32 path format. 1(WinNT.PROCESS_NAME_NATIVE) - The name should use the native system path format.
      Returns:
      the full path of the process's executable file of null if failed. To get extended error information, call GetLastError.
    • getResource

      public static byte[] getResource(String path, String type, String name)
      Gets the specified resource out of the specified executable file
      Parameters:
      path - The path to the executable file
      type - The type of the resource (either a type name or type ID is allowed)
      name - The name or ID of the resource
      Returns:
      The resource bytes, or null if no such resource exists.
      Throws:
      IllegalStateException - if the call to LockResource fails
    • getResourceNames

      public static Map<String,List<String>> getResourceNames(String path)
      Gets a list of all resources from the specified executable file
      Parameters:
      path - The path to the executable file
      Returns:
      A map of resource type name/ID => resources.
      A map key + a single list item + the path to the executable can be handed off to getResource() to actually get the resource.
    • getModules

      public static List<Tlhelp32.MODULEENTRY32W> getModules(int processID)
      Returns all the executable modules for a given process ID.
      Parameters:
      processID - The process ID to get executable modules for
      Returns:
      All the modules in the process.
    • expandEnvironmentStrings

      public static String expandEnvironmentStrings(String input)
      Expands environment-variable strings and replaces them with the values defined for the current user.
      Parameters:
      input - A string that contains one or more environment-variable strings in the form: %variableName%. For each such reference, the %variableName% portion is replaced with the current value of that environment variable.

      Case is ignored when looking up the environment-variable name. If the name is not found, the %variableName% portion is left unexpanded.

      Note that this function does not support all the features that Cmd.exe supports. For example, it does not support %variableName:str1=str2% or %variableName:~offset,length%.

      Returns:
      the replaced string
      Throws:
      Win32Exception - if an error occurs