All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.jna.platform.win32.WinBase Maven / Gradle / Ivy

/* Copyright (c) 2010 Daniel Doubrovkine, All Rights Reserved
 * 
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 * 
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.  
 */
package com.sun.jna.platform.win32;

import java.util.Arrays;
import java.util.Date;
import java.util.List;

import com.sun.jna.Callback;
import com.sun.jna.Platform;
import com.sun.jna.Pointer;
import com.sun.jna.Structure;
import com.sun.jna.Union;
import com.sun.jna.platform.win32.WinNT.HANDLE;
import com.sun.jna.ptr.ByteByReference;
import com.sun.jna.win32.StdCallLibrary;

/**
 * Ported from Winbase.h (kernel32.dll/kernel services).
 * Microsoft Windows SDK 6.0A.
 * @author dblock[at]dblock.org
 */
public interface WinBase extends StdCallLibrary, WinDef, BaseTSD {

    /** Constant value representing an invalid HANDLE. */
    HANDLE INVALID_HANDLE_VALUE =
        new HANDLE(Pointer.createConstant(Pointer.SIZE == 8
                                          ? -1 : 0xFFFFFFFFL));

    int WAIT_FAILED = 0xFFFFFFFF;
    int WAIT_OBJECT_0 = ((NTStatus.STATUS_WAIT_0 ) + 0 );
    int WAIT_ABANDONED = ((NTStatus.STATUS_ABANDONED_WAIT_0 ) + 0 );
    int WAIT_ABANDONED_0 = ((NTStatus.STATUS_ABANDONED_WAIT_0 ) + 0 );
	
    /**
     * Maximum computer name length.
     * The value is 15 on Mac, 31 on everything else.
     */
    int MAX_COMPUTERNAME_LENGTH = Platform.isMac() ? 15 : 31;
	
    /**
     * This logon type is intended for users who will be interactively using the computer, such 
     * as a user being logged on by a terminal server, remote shell, or similar process. This 
     * logon type has the additional expense of caching logon information for disconnected operations; 
     * therefore, it is inappropriate for some client/server applications, such as a mail server. 
     */
    int LOGON32_LOGON_INTERACTIVE = 2;
    /**
     * This logon type is intended for high performance servers to authenticate plaintext passwords. 
     * The LogonUser function does not cache credentials for this logon type.
     */
    int LOGON32_LOGON_NETWORK = 3;
    /**
     * This logon type is intended for batch servers, where processes may be executing on behalf 
     * of a user without their direct intervention. This type is also for higher performance servers 
     * that process many plaintext authentication attempts at a time, such as mail or Web servers. 
     * The LogonUser function does not cache credentials for this logon type.
     */
    int LOGON32_LOGON_BATCH = 4;
    /**
     * Indicates a service-type logon. The account provided must have the service privilege enabled.
     */
    int LOGON32_LOGON_SERVICE = 5;
    /**
     * This logon type is for GINA DLLs that log on users who will be interactively using the computer. 
     * This logon type can generate a unique audit record that shows when the workstation was unlocked.
     */
    int LOGON32_LOGON_UNLOCK = 7;
    /**
     * This logon type preserves the name and password in the authentication package, which allows the 
     * server to make connections to other network servers while impersonating the client. A server can 
     * accept plaintext credentials from a client, call LogonUser, verify that the user can access the 
     * system across the network, and still communicate with other servers.
     */
    int LOGON32_LOGON_NETWORK_CLEARTEXT = 8;
    /**
     * This logon type allows the caller to clone its current token and specify new credentials for 
     * outbound connections. The new logon session has the same local identifier but uses different 
     * credentials for other network connections. This logon type is supported only by the 
     * LOGON32_PROVIDER_WINNT50 logon provider.
     */
    int LOGON32_LOGON_NEW_CREDENTIALS = 9;

    /**
     * Use the standard logon provider for the system. The default security provider is negotiate, 
     * unless you pass NULL for the domain name and the user name is not in UPN format. In this case, 
     * the default provider is NTLM. 
     */
    int LOGON32_PROVIDER_DEFAULT = 0;
	
    /**
     * Use the Windows NT 3.5 logon provider.
     */
    int LOGON32_PROVIDER_WINNT35 = 1;
    /**
     * Use the NTLM logon provider.
     */
    int LOGON32_PROVIDER_WINNT40 = 2;
    /**
     * Use the negotiate logon provider.
     */
    int LOGON32_PROVIDER_WINNT50 = 3;	
	
    /**
     * If this flag is set, a child process created with the bInheritHandles parameter of
     * CreateProcess set to TRUE will inherit the object handle.
     */
    int HANDLE_FLAG_INHERIT = 1;
	
    /**
     * If this flag is set, calling the {@link Kernel32#CloseHandle} function will not
     * close the object handle.
     */
    int HANDLE_FLAG_PROTECT_FROM_CLOSE = 2;

    // STARTUPINFO flags
    int STARTF_USESHOWWINDOW = 0x001;
    int STARTF_USESIZE = 0x002;
    int STARTF_USEPOSITION = 0x004;
    int STARTF_USECOUNTCHARS = 0x008;
    int STARTF_USEFILLATTRIBUTE = 0x010;
    int STARTF_RUNFULLSCREEN = 0x020;
    int STARTF_FORCEONFEEDBACK = 0x040;
    int STARTF_FORCEOFFFEEDBACK = 0x080;
    int STARTF_USESTDHANDLES = 0x100;
	
    // Process Creation flags
    int DEBUG_PROCESS = 0x00000001;
    int DEBUG_ONLY_THIS_PROCESS = 0x00000002;
    int CREATE_SUSPENDED = 0x00000004;
    int DETACHED_PROCESS = 0x00000008;
    int CREATE_NEW_CONSOLE = 0x00000010;
    int CREATE_NEW_PROCESS_GROUP = 0x00000200;
    int CREATE_UNICODE_ENVIRONMENT = 0x00000400;
    int CREATE_SEPARATE_WOW_VDM = 0x00000800;
    int CREATE_SHARED_WOW_VDM = 0x00001000;
    int CREATE_FORCEDOS = 0x00002000;
    int INHERIT_PARENT_AFFINITY = 0x00010000;
    int CREATE_PROTECTED_PROCESS = 0x00040000;
    int EXTENDED_STARTUPINFO_PRESENT = 0x00080000;
    int CREATE_BREAKAWAY_FROM_JOB = 0x01000000;
    int CREATE_PRESERVE_CODE_AUTHZ_LEVEL = 0x02000000;
    int CREATE_DEFAULT_ERROR_MODE = 0x04000000;
    int CREATE_NO_WINDOW = 0x08000000;

    /* File encryption status */
    int FILE_ENCRYPTABLE = 0;
    int FILE_IS_ENCRYPTED = 1;
    int FILE_SYSTEM_ATTR = 2;
    int FILE_ROOT_DIR = 3;
    int FILE_SYSTEM_DIR = 4;
    int FILE_UNKNOWN = 5;
    int FILE_SYSTEM_NOT_SUPPORT = 6;
    int FILE_USER_DISALLOWED = 7;
    int FILE_READ_ONLY = 8;
    int FILE_DIR_DISALOWED = 9;
    
    /* Open encrypted files raw flags */
    int CREATE_FOR_IMPORT = 1;
    int CREATE_FOR_DIR = 2;
    int OVERWRITE_HIDDEN = 4;
    
    /* Invalid return values */
    int INVALID_FILE_SIZE           = 0xFFFFFFFF;
    int INVALID_SET_FILE_POINTER    = 0xFFFFFFFF;
    int INVALID_FILE_ATTRIBUTES     = 0xFFFFFFFF;
	
    /**
     * Return code for a process still active.
     */
    int STILL_ACTIVE = WinNT.STATUS_PENDING;

    /**
     * The FILETIME structure is a 64-bit value representing the number of 
     * 100-nanosecond intervals since January 1, 1601 (UTC).
     * Conversion code in this class Copyright 2002-2004 Apache Software Foundation.
     * @author Rainer Klute ([email protected]) for the Apache Software Foundation (org.apache.poi.hpsf)
     */
    public static class FILETIME extends Structure {
        public int dwLowDateTime;
        public int dwHighDateTime;
        
        protected List getFieldOrder() {
            return Arrays.asList(new String[] { "dwLowDateTime", "dwHighDateTime" });
        }

        public static class ByReference extends FILETIME implements Structure.ByReference {
            public ByReference() {
            }

            public ByReference(Pointer memory) {
                super(memory);
            }
        }

        public FILETIME(Date date) {
            long rawValue = dateToFileTime(date);
            dwHighDateTime = (int)(rawValue >> 32 & 0xffffffffL);
            dwLowDateTime = (int)(rawValue & 0xffffffffL);
        }

        public FILETIME() {
        }

        public FILETIME(Pointer memory) {
            super(memory);
            read();
        }

        /**
         * 

The difference between the Windows epoch (1601-01-01 * 00:00:00) and the Unix epoch (1970-01-01 00:00:00) in * milliseconds: 11644473600000L. (Use your favorite spreadsheet * program to verify the correctness of this value. By the way, * did you notice that you can tell from the epochs which * operating system is the modern one? :-))

*/ private static final long EPOCH_DIFF = 11644473600000L; /** *

Converts a Windows FILETIME into a {@link Date}. The Windows * FILETIME structure holds a date and time associated with a * file. The structure identifies a 64-bit integer specifying the * number of 100-nanosecond intervals which have passed since * January 1, 1601. This 64-bit value is split into the two double * words stored in the structure.

* * @param high The higher double word of the FILETIME structure. * @param low The lower double word of the FILETIME structure. * @return The Windows FILETIME as a {@link Date}. */ public static Date filetimeToDate(final int high, final int low) { final long filetime = (long) high << 32 | low & 0xffffffffL; final long ms_since_16010101 = filetime / (1000 * 10); final long ms_since_19700101 = ms_since_16010101 - EPOCH_DIFF; return new Date(ms_since_19700101); } /** *

Converts a {@link Date} into a filetime.

* * @param date The date to be converted * @return The filetime * * @see #filetimeToDate */ public static long dateToFileTime(final Date date) { final long ms_since_19700101 = date.getTime(); final long ms_since_16010101 = ms_since_19700101 + EPOCH_DIFF; return ms_since_16010101 * 1000 * 10; } public Date toDate() { return filetimeToDate(dwHighDateTime, dwLowDateTime); } public long toLong() { return toDate().getTime(); } public String toString() { return super.toString() + ": " + toDate().toString(); //$NON-NLS-1$ } } /* Local Memory Flags */ int LMEM_FIXED = 0x0000; int LMEM_MOVEABLE = 0x0002; int LMEM_NOCOMPACT = 0x0010; int LMEM_NODISCARD = 0x0020; int LMEM_ZEROINIT = 0x0040; int LMEM_MODIFY = 0x0080; int LMEM_DISCARDABLE = 0x0F00; int LMEM_VALID_FLAGS = 0x0F72; int LMEM_INVALID_HANDLE = 0x8000; int LHND = (LMEM_MOVEABLE | LMEM_ZEROINIT); int LPTR = (LMEM_FIXED | LMEM_ZEROINIT); /* Flags returned by LocalFlags (in addition to LMEM_DISCARDABLE) */ int LMEM_DISCARDED = 0x4000; int LMEM_LOCKCOUNT = 0x00FF; /** * Specifies a date and time, using individual members for the month, * day, year, weekday, hour, minute, second, and millisecond. The time * is either in coordinated universal time (UTC) or local time, depending * on the function that is being called. * http://msdn.microsoft.com/en-us/library/ms724950(VS.85).aspx */ public static class SYSTEMTIME extends Structure { // The year. The valid values for this member are 1601 through 30827. public short wYear; // The month. The valid values for this member are 1 through 12. public short wMonth; // The day of the week. The valid values for this member are 0 through 6. public short wDayOfWeek; // The day of the month. The valid values for this member are 1 through 31. public short wDay; // The hour. The valid values for this member are 0 through 23. public short wHour; // The minute. The valid values for this member are 0 through 59. public short wMinute; // The second. The valid values for this member are 0 through 59. public short wSecond; // The millisecond. The valid values for this member are 0 through 999. public short wMilliseconds; protected List getFieldOrder() { return Arrays.asList(new String[] { "wYear", "wMonth", "wDayOfWeek", "wDay", "wHour", "wMinute", "wSecond", "wMilliseconds" }); } } /** * Specifies settings for a time zone. * http://msdn.microsoft.com/en-us/library/windows/desktop/ms725481(v=vs.85).aspx */ public static class TIME_ZONE_INFORMATION extends Structure { public LONG Bias; public String StandardName; public SYSTEMTIME StandardDate; public LONG StandardBias; public String DaylightName; public SYSTEMTIME DaylightDate; public LONG DaylightBias; protected List getFieldOrder() { return Arrays.asList(new String[] { "Bias", "StandardName", "StandardDate", "StandardBias", "DaylightName", "DaylightDate", "DaylightBias" }); } } /** * The lpBuffer parameter is a pointer to a PVOID pointer, and that the nSize * parameter specifies the minimum number of TCHARs to allocate for an output * message buffer. The function allocates a buffer large enough to hold the * formatted message, and places a pointer to the allocated buffer at the address * specified by lpBuffer. The caller should use the LocalFree function to free * the buffer when it is no longer needed. */ int FORMAT_MESSAGE_ALLOCATE_BUFFER = 0x00000100; /** * Insert sequences in the message definition are to be ignored and passed through * to the output buffer unchanged. This flag is useful for fetching a message for * later formatting. If this flag is set, the Arguments parameter is ignored. */ int FORMAT_MESSAGE_IGNORE_INSERTS = 0x00000200; /** * The lpSource parameter is a pointer to a null-terminated message definition. * The message definition may contain insert sequences, just as the message text * in a message table resource may. Cannot be used with FORMAT_MESSAGE_FROM_HMODULE * or FORMAT_MESSAGE_FROM_SYSTEM. */ int FORMAT_MESSAGE_FROM_STRING = 0x00000400; /** * The lpSource parameter is a module handle containing the message-table * resource(s) to search. If this lpSource handle is NULL, the current process's * application image file will be searched. Cannot be used with * FORMAT_MESSAGE_FROM_STRING. */ int FORMAT_MESSAGE_FROM_HMODULE = 0x00000800; /** * The function should search the system message-table resource(s) for the * requested message. If this flag is specified with FORMAT_MESSAGE_FROM_HMODULE, * the function searches the system message table if the message is not found in * the module specified by lpSource. Cannot be used with FORMAT_MESSAGE_FROM_STRING. * If this flag is specified, an application can pass the result of the * GetLastError function to retrieve the message text for a system-defined error. */ int FORMAT_MESSAGE_FROM_SYSTEM = 0x00001000; /** * The Arguments parameter is not a va_list structure, but is a pointer to an array * of values that represent the arguments. This flag cannot be used with 64-bit * argument values. If you are using 64-bit values, you must use the va_list * structure. */ int FORMAT_MESSAGE_ARGUMENT_ARRAY = 0x00002000; /** * The drive type cannot be determined. */ int DRIVE_UNKNOWN = 0; /** * The root path is invalid, for example, no volume is mounted at the path. */ int DRIVE_NO_ROOT_DIR = 1; /** * The drive is a type that has removable media, for example, a floppy drive * or removable hard disk. */ int DRIVE_REMOVABLE = 2; /** * The drive is a type that cannot be removed, for example, a fixed hard drive. */ int DRIVE_FIXED = 3; /** * The drive is a remote (network) drive. */ int DRIVE_REMOTE = 4; /** * The drive is a CD-ROM drive. */ int DRIVE_CDROM = 5; /** * The drive is a RAM disk. */ int DRIVE_RAMDISK = 6; /** * The OVERLAPPED structure contains information used in * asynchronous (or overlapped) input and output (I/O). */ public static class OVERLAPPED extends Structure { public ULONG_PTR Internal; public ULONG_PTR InternalHigh; public int Offset; public int OffsetHigh; public HANDLE hEvent; protected List getFieldOrder() { return Arrays.asList(new String[] { "Internal", "InternalHigh", "Offset", "OffsetHigh", "hEvent" }); } } int INFINITE = 0xFFFFFFFF; /** * Contains information about the current computer system. This includes the architecture and * type of the processor, the number of processors in the system, the page size, and other such * information. */ public static class SYSTEM_INFO extends Structure { /** Unnamed inner structure. */ public static class PI extends Structure { public static class ByReference extends PI implements Structure.ByReference { } /** * System's processor architecture. * This value can be one of the following values: * * PROCESSOR_ARCHITECTURE_UNKNOWN * PROCESSOR_ARCHITECTURE_INTEL * PROCESSOR_ARCHITECTURE_IA64 * PROCESSOR_ARCHITECTURE_AMD64 */ public WORD wProcessorArchitecture; /** * Reserved for future use. */ public WORD wReserved; protected List getFieldOrder() { return Arrays.asList(new String[] { "wProcessorArchitecture", "wReserved" }); } } /** Unnamed inner union. */ public static class UNION extends Union { public static class ByReference extends UNION implements Structure.ByReference { } /** * An obsolete member that is retained for compatibility with Windows NT 3.5 and earlier. * New applications should use the wProcessorArchitecture branch of the union. * Windows Me/98/95: The system always sets this member to zero, the value defined * for PROCESSOR_ARCHITECTURE_INTEL. */ public DWORD dwOemID; /** * Processor architecture (unnamed struct). */ public PI pi; } /** * Processor architecture (unnamed union). */ public UNION processorArchitecture; /** * Page size and the granularity of page protection and commitment. */ public DWORD dwPageSize; /** * Pointer to the lowest memory address accessible to applications and dynamic-link libraries (DLLs). */ public Pointer lpMinimumApplicationAddress; /** * Pointer to the highest memory address accessible to applications and DLLs. */ public Pointer lpMaximumApplicationAddress; /** * Mask representing the set of processors configured into the system. Bit 0 is processor 0; bit 31 is processor 31. */ public DWORD_PTR dwActiveProcessorMask; /** * Number of processors in the system. */ public DWORD dwNumberOfProcessors; /** * An obsolete member that is retained for compatibility with Windows NT 3.5 and Windows Me/98/95. * Use the wProcessorArchitecture, wProcessorLevel, and wProcessorRevision members to determine * the type of processor. * PROCESSOR_INTEL_386 * PROCESSOR_INTEL_486 * PROCESSOR_INTEL_PENTIUM */ public DWORD dwProcessorType; /** * Granularity for the starting address at which virtual memory can be allocated. */ public DWORD dwAllocationGranularity; /** * System's architecture-dependent processor level. It should be used only for display purposes. * To determine the feature set of a processor, use the IsProcessorFeaturePresent function. * If wProcessorArchitecture is PROCESSOR_ARCHITECTURE_INTEL, wProcessorLevel is defined by the CPU vendor. * If wProcessorArchitecture is PROCESSOR_ARCHITECTURE_IA64, wProcessorLevel is set to 1. */ public WORD wProcessorLevel; /** * Architecture-dependent processor revision. */ public WORD wProcessorRevision; protected List getFieldOrder() { return Arrays.asList(new String[] { "processorArchitecture", "dwPageSize", "lpMinimumApplicationAddress", "lpMaximumApplicationAddress", "dwActiveProcessorMask", "dwNumberOfProcessors", "dwProcessorType", "dwAllocationGranularity", "wProcessorLevel", "wProcessorRevision"}); } } /** * Contains information about the current state of both physical and virtual memory, including * extended memory. The GlobalMemoryStatusEx function stores information in this structure. */ public static class MEMORYSTATUSEX extends Structure { /** * The size of the structure, in bytes. */ public DWORD dwLength; /** * A number between 0 and 100 that specifies the approximate percentage of physical memory * that is in use (0 indicates no memory use and 100 indicates full memory use). */ public DWORD dwMemoryLoad; /** * The amount of actual physical memory, in bytes. */ public DWORDLONG ullTotalPhys; /** * The amount of physical memory currently available, in bytes. This is the amount of physical * memory that can be immediately reused without having to write its contents to disk first. * It is the sum of the size of the standby, free, and zero lists. */ public DWORDLONG ullAvailPhys; /** * The current committed memory limit for the system or the current process, whichever is smaller, in bytes. */ public DWORDLONG ullTotalPageFile; /** * The maximum amount of memory the current process can commit, in bytes. This value is equal to or smaller * than the system-wide available commit value. */ public DWORDLONG ullAvailPageFile; /** * The size of the user-mode portion of the virtual address space of the calling process, in bytes. */ public DWORDLONG ullTotalVirtual; /** * The amount of unreserved and uncommitted memory currently in the user-mode portion of the * virtual address space of the calling process, in bytes. */ public DWORDLONG ullAvailVirtual; /** * Reserved. This value is always 0. */ public DWORDLONG ullAvailExtendedVirtual; protected List getFieldOrder() { return Arrays.asList(new String[] { "dwLength", "dwMemoryLoad", "ullTotalPhys", "ullAvailPhys", "ullTotalPageFile", "ullAvailPageFile", "ullTotalVirtual", "ullAvailVirtual", "ullAvailExtendedVirtual" }); } public MEMORYSTATUSEX() { dwLength = new DWORD(size()); } }; /** * The SECURITY_ATTRIBUTES structure contains the security descriptor for an * object and specifies whether the handle retrieved by specifying this * structure is inheritable. This structure provides security settings for * objects created by various functions, such as {@link Kernel32#CreateFile}, * {@link Kernel32#CreatePipe}, or {@link Advapi32#RegCreateKeyEx}. */ public static class SECURITY_ATTRIBUTES extends Structure { /** * The size of the structure, in bytes. */ public DWORD dwLength; /** * A pointer to a SECURITY_DESCRIPTOR structure that controls access to the object. */ public Pointer lpSecurityDescriptor; /** * A Boolean value that specifies whether the returned handle is inherited when * a new process is created */ public boolean bInheritHandle; protected List getFieldOrder() { return Arrays.asList(new String[] { "dwLength", "lpSecurityDescriptor", "bInheritHandle" }); } public SECURITY_ATTRIBUTES() { dwLength = new DWORD(size()); } } /** * Specifies the window station, desktop, standard handles, and appearance of the main * window for a process at creation time. */ public static class STARTUPINFO extends Structure { /** * The size of the structure, in bytes. */ public DWORD cb; /** * Reserved; must be NULL. */ public String lpReserved; /** * The name of the desktop, or the name of both the desktop and window station for this process. * A backslash in the string indicates that the string includes both the desktop and window * station names. For more information, see Thread Connection to a Desktop. */ public String lpDesktop; /** * For console processes, this is the title displayed in the title bar * if a new console window is created. If NULL, the name of the * executable file is used as the window title instead. This parameter * must be NULL for GUI or console processes that do not create a new * console window. */ public String lpTitle; /** * If dwFlags specifies STARTF_USEPOSITION, this member is the x offset * of the upper left corner of a window if a new window is created, in * pixels. Otherwise, this member is ignored. * * The offset is from the upper left corner of the screen. For GUI * processes, the specified position is used the first time the new * process calls CreateWindow to create an overlapped window if the x * parameter of CreateWindow is CW_USEDEFAULT. */ public DWORD dwX; /** * If dwFlags specifies STARTF_USEPOSITION, this member is the y offset * of the upper left corner of a window if a new window is created, in * pixels. Otherwise, this member is ignored. * * The offset is from the upper left corner of the screen. For GUI * processes, the specified position is used the first time the new * process calls CreateWindow to create an overlapped window if the y * parameter of CreateWindow is CW_USEDEFAULT. */ public DWORD dwY; /** * If dwFlags specifies STARTF_USESIZE, this member is the width of the * window if a new window is created, in pixels. Otherwise, this member * is ignored. * * For GUI processes, this is used only the first time the new process * calls CreateWindow to create an overlapped window if the nWidth * parameter of CreateWindow is CW_USEDEFAULT. */ public DWORD dwXSize; /** * If dwFlags specifies STARTF_USESIZE, this member is the height of the * window if a new window is created, in pixels. Otherwise, this member * is ignored. * * For GUI processes, this is used only the first time the new process * calls CreateWindow to create an overlapped window if the nHeight * parameter of CreateWindow is CW_USEDEFAULT. */ public DWORD dwYSize; /** * If dwFlags specifies STARTF_USECOUNTCHARS, if a new console window is * created in a console process, this member specifies the screen buffer * width, in character columns. Otherwise, this member is ignored. */ public DWORD dwXCountChars; /** * If dwFlags specifies STARTF_USECOUNTCHARS, if a new console window is * created in a console process, this member specifies the screen buffer * height, in character rows. Otherwise, this member is ignored. */ public DWORD dwYCountChars; /** * If dwFlags specifies STARTF_USEFILLATTRIBUTE, this member is the * initial text and background colors if a new console window is created * in a console application. Otherwise, this member is ignored. * * This value can be any combination of the following values: * FOREGROUND_BLUE, FOREGROUND_GREEN, FOREGROUND_RED, * FOREGROUND_INTENSITY, BACKGROUND_BLUE, BACKGROUND_GREEN, * BACKGROUND_RED, and BACKGROUND_INTENSITY. For example, the following * combination of values produces red text on a white background: * * FOREGROUND_RED| BACKGROUND_RED| BACKGROUND_GREEN| BACKGROUND_BLUE */ public DWORD dwFillAttribute; /** * A bit field that determines whether certain STARTUPINFO members are * used when the process creates a window. */ public int dwFlags; /** * If dwFlags specifies STARTF_USESHOWWINDOW, this member can be any of * the values that can be specified in the nCmdShow parameter for the * ShowWindow function, except for SW_SHOWDEFAULT. Otherwise, this * member is ignored. * * For GUI processes, the first time ShowWindow is called, its nCmdShow * parameter is ignored wShowWindow specifies the default value. In * subsequent calls to ShowWindow, the wShowWindow member is used if the * nCmdShow parameter of ShowWindow is set to SW_SHOWDEFAULT. */ public WORD wShowWindow; /** * Reserved for use by the C Run-time; must be zero. */ public WORD cbReserved2; /** * Reserved for use by the C Run-time; must be NULL. */ public ByteByReference lpReserved2; /** * If dwFlags specifies STARTF_USESTDHANDLES, this member is the * standard input handle for the process. If STARTF_USESTDHANDLES is not * specified, the default for standard input is the keyboard buffer. * * If dwFlags specifies STARTF_USEHOTKEY, this member specifies a hotkey * value that is sent as the wParam parameter of a WM_SETHOTKEY message * to the first eligible top-level window created by the application * that owns the process. If the window is created with the WS_POPUP * window style, it is not eligible unless the WS_EX_APPWINDOW extended * window style is also set. For more information, see CreateWindowEx. * * Otherwise, this member is ignored. */ public HANDLE hStdInput; /** * If dwFlags specifies STARTF_USESTDHANDLES, this member is the * standard output handle for the process. Otherwise, this member is * ignored and the default for standard output is the console window's * buffer. */ public HANDLE hStdOutput; /** * If dwFlags specifies STARTF_USESTDHANDLES, this member is the * standard error handle for the process. Otherwise, this member is * ignored and the default for standard error is the console window's * buffer. */ public HANDLE hStdError; protected List getFieldOrder() { return Arrays.asList(new String[] { "cb", "lpReserved", "lpDesktop", "lpTitle", "dwX", "dwY", "dwXSize", "dwYSize", "dwXCountChars", "dwYCountChars", "dwFillAttribute", "dwFlags", "wShowWindow", "cbReserved2", "lpReserved2", "hStdInput", "hStdOutput", "hStdError" }); } public STARTUPINFO() { cb = new DWORD(size()); } } /** * Contains information about a newly created process and its primary * thread. It is used with the CreateProcess, CreateProcessAsUser, * CreateProcessWithLogonW, or CreateProcessWithTokenW function. */ public static class PROCESS_INFORMATION extends Structure { /** * A handle to the newly created process. The handle is used to specify * the process in all functions that perform operations on the process * object. */ public HANDLE hProcess; /** * A handle to the primary thread of the newly created process. The * handle is used to specify the thread in all functions that perform * operations on the thread object. */ public HANDLE hThread; /** * A value that can be used to identify a process. The value is valid * from the time the process is created until all handles to the process * are closed and the process object is freed; at this point, the * identifier may be reused. */ public DWORD dwProcessId; /** * A value that can be used to identify a thread. The value is valid * from the time the thread is created until all handles to the thread * are closed and the thread object is freed; at this point, the * identifier may be reused. */ public DWORD dwThreadId; protected List getFieldOrder() { return Arrays.asList(new String[] { "hProcess", "hThread", "dwProcessId", "dwThreadId" }); } public static class ByReference extends PROCESS_INFORMATION implements Structure.ByReference { public ByReference() { } public ByReference(Pointer memory) { super(memory); } } public PROCESS_INFORMATION() { } public PROCESS_INFORMATION(Pointer memory) { super(memory); read(); } } /** * If the file is to be moved to a different volume, the function simulates the move by using the CopyFile and DeleteFile functions. * * This value cannot be used with MOVEFILE_DELAY_UNTIL_REBOOT. */ int MOVEFILE_COPY_ALLOWED = 0x2; /** * Reserved for future use. */ int MOVEFILE_CREATE_HARDLINK = 0x10; /** * The system does not move the file until the operating system is restarted. The system moves the file immediately * after AUTOCHK is executed, but before creating any paging files. Consequently, this parameter enables the * function to delete paging files from previous startups. * * This value can be used only if the process is in the context of a user who belongs to the administrators group or * the LocalSystem account. * * This value cannot be used with MOVEFILE_COPY_ALLOWED. * * Windows Server 2003 and Windows XP: For information about special situations where this functionality can fail, * and a suggested workaround solution, see Files are not exchanged when Windows Server 2003 restarts if you use the * MoveFileEx function to schedule a replacement for some files in the Help and Support Knowledge Base. * * Windows 2000: If you specify the MOVEFILE_DELAY_UNTIL_REBOOT flag for dwFlags, you cannot also prepend the file * name that is specified by lpExistingFileName with "\\?". */ int MOVEFILE_DELAY_UNTIL_REBOOT = 0x4; /** * The function fails if the source file is a link source, but the file cannot be tracked after the move. This * situation can occur if the destination is a volume formatted with the FAT file system. */ int MOVEFILE_FAIL_IF_NOT_TRACKABLE = 0x20; /** * If a file named lpNewFileName exists, the function replaces its contents with the contents of the * lpExistingFileName file, provided that security requirements regarding access control lists (ACLs) are met. For * more information, see the Remarks section of this topic. * * This value cannot be used if lpNewFileName or lpExistingFileName names a directory. */ int MOVEFILE_REPLACE_EXISTING = 0x1; /** * The function does not return until the file is actually moved on the disk. * * Setting this value guarantees that a move performed as a copy and delete operation is flushed to disk before the * function returns. The flush occurs at the end of the copy operation. * * This value has no effect if MOVEFILE_DELAY_UNTIL_REBOOT is set. */ int MOVEFILE_WRITE_THROUGH = 0x8; /** * Represents a thread entry point local to this process, as a Callback. */ public interface THREAD_START_ROUTINE extends Callback{ public DWORD apply( LPVOID lpParameter ); } /** * Represents a thread entry point in another process. Can only be expressed as a pointer, as * the location has no meaning in the Java process. */ public class FOREIGN_THREAD_START_ROUTINE extends Structure { LPVOID foreignLocation; @Override protected List getFieldOrder() { return Arrays.asList(new String[] { "foreignLocation" }); } } /** * Specifies a type of computer name to be retrieved by the GetComputerNameEx function */ public static interface COMPUTER_NAME_FORMAT { /** * The NetBIOS name of the local computer or the cluster associated with the local * computer. This name is limited to MAX_COMPUTERNAME_LENGTH + 1 characters and may * be a truncated version of the DNS host name. For example, if the DNS host name is * "corporate-mail-server", the NetBIOS name would be "corporate-mail-"". */ int ComputerNameNetBIOS = 0; /** * The DNS name of the local computer or the cluster associated with the local computer. */ int ComputerNameDnsHostname = 1; /** * The name of the DNS domain assigned to the local computer or the cluster associated * with the local computer. */ int ComputerNameDnsDomain = 2; /** * The fully qualified DNS name that uniquely identifies the local computer or the cluster * associated with the local computer. This name is a combination of the DNS host name and * the DNS domain name, using the form HostName.DomainName. For example, if the DNS host * name is "corporate-mail-server" and the DNS domain name is "microsoft.com", * the fully qualified DNS name is "corporate-mail-server.microsoft.com". */ int ComputerNameDnsFullyQualified = 3; /** * The NetBIOS name of the local computer. On a cluster, this is the NetBIOS name of the * local node on the cluster. */ int ComputerNamePhysicalNetBIOS = 4; /** * The DNS host name of the local computer. On a cluster, this is the DNS host name of the * local node on the cluster. */ int ComputerNamePhysicalDnsHostname = 5; /** * The name of the DNS domain assigned to the local computer. On a cluster, this is the DNS * domain of the local node on the cluster. */ int ComputerNamePhysicalDnsDomain = 6; /** * The fully qualified DNS name that uniquely identifies the computer. On a cluster, this is * the fully qualified DNS name of the local node on the cluster. The fully qualified DNS name * is a combination of the DNS host name and the DNS domain name, using the form HostName.DomainName. */ int ComputerNamePhysicalDnsFullyQualified = 7; /** * Note used - serves as an upper limit in case one wants to go through all the values */ int ComputerNameMax = 8; } /** * An application-defined callback function used with ReadEncryptedFileRaw. * The system calls ExportCallback one or more times, each time with a block * of the encrypted file's data, until it has received all of the file data. * ExportCallback writes the encrypted file's data to another storage media, * usually for purposes of backing up the file. */ public interface FE_EXPORT_FUNC extends Callback { public DWORD callback(ByteByReference pbData, Pointer pvCallbackContext, ULONG ulLength); } /** * An application-defined callback function used with WriteEncryptedFileRaw. * The system calls ImportCallback one or more times, each time to retrieve a * portion of a backup file's data. ImportCallback reads the data from a * backup file sequentially and restores the data, and the system continues * calling it until it has read all of the backup file data. */ public interface FE_IMPORT_FUNC extends Callback { public DWORD callback(ByteByReference pbData, Pointer pvCallbackContext, ULONGByReference ulLength); } int PIPE_CLIENT_END=0x00000000; int PIPE_SERVER_END=0x00000001; /* Pipe open mode values */ int PIPE_ACCESS_DUPLEX=0x00000003; int PIPE_ACCESS_INBOUND=0x00000001; int PIPE_ACCESS_OUTBOUND=0x00000002; /* Pipe type values */ int PIPE_TYPE_BYTE=0x00000000; int PIPE_TYPE_MESSAGE=0x00000004; /* Pipe read modes */ int PIPE_READMODE_BYTE=0x00000000; int PIPE_READMODE_MESSAGE=0x00000002; /* Pipe wait modes */ int PIPE_WAIT=0x00000000; int PIPE_NOWAIT=0x00000001; int PIPE_ACCEPT_REMOTE_CLIENTS=0x00000000; int PIPE_REJECT_REMOTE_CLIENTS=0x00000008; int PIPE_UNLIMITED_INSTANCES=255; /* Named pipe pre-defined timeout values */ int NMPWAIT_USE_DEFAULT_WAIT=0x00000000; int NMPWAIT_NOWAIT=0x00000001; int NMPWAIT_WAIT_FOREVER=0xffffffff; /** * * Contains the time-out parameters for a communications device. The * parameters determine the behavior of * {@link Kernel32#ReadFile(com.sun.jna.platform.win32.WinNT.HANDLE, java.nio.Buffer, int, com.sun.jna.ptr.IntByReference, com.sun.jna.platform.win32.WinBase.OVERLAPPED)} * , {@link Kernel32#WriteFile(com.sun.jna.platform.win32.WinNT.HANDLE, * byte[], int, com.sun.jna.ptr.IntByReference, * com.sun.jna.platform.win32.WinBase.OVERLAPPED))}, ReadFileEx, and * WriteFileEx operations on the device.
*
* * Remarks
* If an application sets ReadIntervalTimeout and ReadTotalTimeoutMultiplier * to MAXDWORD and sets ReadTotalTimeoutConstant to a value greater than * zero and less than MAXDWORD, one of the following occurs when the * ReadFile function is called: *
  • If there are any bytes in the input buffer, ReadFile returns * immediately with the bytes in the buffer.
  • *
  • If there are no bytes in the input buffer, ReadFile waits until a * byte arrives and then returns immediately.
  • *
  • If no bytes arrive within the time specified by * ReadTotalTimeoutConstant, ReadFile times out.
  • * * @author Markus * */ public static class COMMTIMEOUTS extends Structure { /** * * The maximum time allowed to elapse before the arrival of the next * byte on the communications line, in milliseconds. If the interval * between the arrival of any two bytes exceeds this amount, the * {@link Kernel32#ReadFile(com.sun.jna.platform.win32.WinNT.HANDLE, java.nio.Buffer, int, com.sun.jna.ptr.IntByReference, com.sun.jna.platform.win32.WinBase.OVERLAPPED)} * operation is completed and any buffered data is returned. A value of * zero indicates that interval time-outs are not used. * * A value of MAXDWORD, combined with zero values for both the * {@link COMMTIMEOUTS#ReadTotalTimeoutConstant} and * {@link COMMTIMEOUTS#ReadTotalTimeoutMultiplier} members, specifies * that the read operation is to return immediately with the bytes that * have already been received, even if no bytes have been received. * */ public DWORD ReadIntervalTimeout; /** * The multiplier used to calculate the total time-out period for read * operations, in milliseconds. For each read operation, this value is * multiplied by the requested number of bytes to be read. */ public DWORD ReadTotalTimeoutMultiplier; /** * A constant used to calculate the total time-out period for read * operations, in milliseconds. For each read operation, this value is * added to the product of the * {@link COMMTIMEOUTS#ReadTotalTimeoutMultiplier} member and the * requested number of bytes. * * A value of zero for both the * {@link COMMTIMEOUTS#ReadTotalTimeoutMultiplier} and * {@link COMMTIMEOUTS#ReadTotalTimeoutConstant} members indicates that * total time-outs are not used for read operations. */ public DWORD ReadTotalTimeoutConstant; /** * The multiplier used to calculate the total time-out period for write * operations, in milliseconds. For each write operation, this value is * multiplied by the number of bytes to be written. */ public DWORD WriteTotalTimeoutMultiplier; /** * A constant used to calculate the total time-out period for write * operations, in milliseconds. For each write operation, this value is * added to the product of the * {@link COMMTIMEOUTS#WriteTotalTimeoutMultiplier} member and the * number of bytes to be written. * * A value of zero for both the * {@link COMMTIMEOUTS#WriteTotalTimeoutMultiplier} and * {@link COMMTIMEOUTS#WriteTotalTimeoutConstant} members indicates that * total time-outs are not used for write operations. * */ public DWORD WriteTotalTimeoutConstant; protected List getFieldOrder() { return Arrays.asList(new String[] { "ReadIntervalTimeout", "ReadTotalTimeoutMultiplier", "ReadTotalTimeoutConstant", "WriteTotalTimeoutMultiplier", "WriteTotalTimeoutConstant" }); } } /** * Defines the control setting for a serial communications device. */ public static class DCB extends Structure { /** * Type is used to handle the bitfield of the DBC structure. */ public static class DCBControllBits extends DWORD { private static final long serialVersionUID = 8574966619718078579L; @Override public String toString() { final StringBuilder stringBuilder = new StringBuilder(); stringBuilder.append('<'); stringBuilder.append("fBinary:1="); stringBuilder.append(getfBinary() ? '1' : '0'); stringBuilder.append(", fParity:1="); stringBuilder.append(getfParity() ? '1' : '0'); stringBuilder.append(", fOutxCtsFlow:1="); stringBuilder.append(getfOutxCtsFlow() ? '1' : '0'); stringBuilder.append(", fOutxDsrFlow:1="); stringBuilder.append(getfOutxDsrFlow() ? '1' : '0'); stringBuilder.append(", fDtrControl:2="); stringBuilder.append(getfDtrControl()); stringBuilder.append(", fDsrSensitivity:1="); stringBuilder.append(getfDsrSensitivity() ? '1' : '0'); stringBuilder.append(", fTXContinueOnXoff:1="); stringBuilder.append(getfTXContinueOnXoff() ? '1' : '0'); stringBuilder.append(", fOutX:1="); stringBuilder.append(getfOutX() ? '1' : '0'); stringBuilder.append(", fInX:1="); stringBuilder.append(getfInX() ? '1' : '0'); stringBuilder.append(", fErrorChar:1="); stringBuilder.append(getfErrorChar() ? '1' : '0'); stringBuilder.append(", fNull:1="); stringBuilder.append(getfNull() ? '1' : '0'); stringBuilder.append(", fRtsControl:2="); stringBuilder.append(getfRtsControl()); stringBuilder.append(", fAbortOnError:1="); stringBuilder.append(getfAbortOnError() ? '1' : '0'); stringBuilder.append(", fDummy2:17="); stringBuilder.append(getfDummy2()); stringBuilder.append('>'); return stringBuilder.toString(); } public boolean getfAbortOnError() { return (this.intValue() & (0x01 << 14)) != 0x00; } public boolean getfBinary() { return (this.intValue() & 0x01) != 0x00; } public boolean getfDsrSensitivity() { return (this.intValue() & (0x01 << 6)) != 0x00; } public int getfDtrControl() { return (this.intValue() >>> 4) & 0x03; } public boolean getfErrorChar() { return (this.intValue() & (0x01 << 10)) != 0x00; } public boolean getfInX() { return (this.intValue() & (0x01 << 9)) != 0x00; } public boolean getfNull() { return (this.intValue() & (0x01 << 11)) != 0x00; } public boolean getfOutX() { return (this.intValue() & (0x01 << 8)) != 0x00; } public boolean getfOutxCtsFlow() { return (this.intValue() & (0x01 << 2)) != 0x00; } public boolean getfOutxDsrFlow() { return (this.intValue() & (0x01 << 3)) != 0x00; } public boolean getfParity() { return (this.intValue() & (0x01 << 1)) != 0x00; } public int getfRtsControl() { return (this.intValue() >>> 12) & 0x03; } public int getfDummy2() { return (this.intValue()>>>15) & 0x1FFFF; } public boolean getfTXContinueOnXoff() { return (this.intValue() & (0x01 << 7)) != 0x00; } /** * If this member is TRUE, the driver terminates all read and write * operations with an error status if an error occurs.
    * The driver will not accept any further communications operations * until the application has acknowledged the error by calling the * ClearCommError function. * * @param fAbortOnError */ public void setfAbortOnError(boolean fAbortOnError) { int tmp = leftShiftMask(fAbortOnError ? 1 : 0, (byte)14, 0x01, this.intValue()); this.setValue(tmp); } /** * If this member is TRUE, binary mode is enabled.
    * Windows does not support nonbinary mode transfers, so this member * must be TRUE. * * @param fBinary */ public void setfBinary(boolean fBinary) { int tmp = leftShiftMask(fBinary ? 1 : 0, (byte)0, 0x01, this.intValue()); this.setValue(tmp); } /** * If this member is TRUE, the communications driver is sensitive to the * state of the DSR signal.
    * The driver ignores any bytes received, unless the DSR modem input * line is high. * * @param fDsrSensitivity */ public void setfDsrSensitivity(boolean fDsrSensitivity) { int tmp = leftShiftMask(fDsrSensitivity ? 1 : 0, (byte)6, 0x01, this.intValue()); this.setValue(tmp); } /** * The DTR (data-terminal-ready) flow control. This member can be one of * the following values. *
  • {@link WinBase#DTR_CONTROL_DISABLE}
  • *
  • {@link WinBase#DTR_CONTROL_ENABLE}
  • *
  • {@link WinBase#DTR_CONTROL_HANDSHAKE}
  • * * @param fOutxDsrFlow * value to set */ public void setfDtrControl(int fOutxDsrFlow) { int tmp = leftShiftMask(fOutxDsrFlow, (byte)4, 0x03, this.intValue()); this.setValue(tmp); } /** * Indicates whether bytes received with parity errors are replaced with * the character specified by the ErrorChar member.
    * If this member is TRUE and the fParity member is TRUE, replacement * occurs. * * @param fErrorChar */ public void setfErrorChar(boolean fErrorChar) { int tmp = leftShiftMask(fErrorChar ? 1 : 0, (byte)10, 0x01, this.intValue()); this.setValue(tmp); } /** * Indicates whether XON/XOFF flow control is used during reception.
    * If this member is TRUE, the XoffChar character is sent when the input * buffer comes within XoffLim bytes of being full, and the XonChar * character is sent when the input buffer comes within XonLim bytes of * being empty. * * @param fInX */ public void setfInX(boolean fInX) { int tmp = leftShiftMask(fInX ? 1 : 0, (byte)9, 0x01, this.intValue()); this.setValue(tmp); } /** * If this member is TRUE, null bytes are discarded when received. * * @param fNull */ public void setfNull(boolean fNull) { int tmp = leftShiftMask(fNull ? 1 : 0, (byte)11, 0x01, this.intValue()); this.setValue(tmp); } /** * Indicates whether XON/XOFF flow control is used during transmission. *
    * If this member is TRUE, transmission stops when the XoffChar * character is received and starts again when the XonChar character is * received. * * @param fOutX */ public void setfOutX(boolean fOutX) { int tmp = leftShiftMask(fOutX ? 1 : 0, (byte)8, 0x01, this.intValue()); this.setValue(tmp); } /** * If this member is TRUE, the CTS (clear-to-send) signal is monitored * for output flow control.
    * If this member is TRUE and CTS is turned off, output is suspended * until CTS is sent again. * * @param fOutxCtsFlow */ public void setfOutxCtsFlow(boolean fOutxCtsFlow) { int tmp = leftShiftMask(fOutxCtsFlow ? 1 : 0, (byte)2, 0x01, this.intValue()); this.setValue(tmp); } /** * If this member is TRUE, the DSR (data-set-ready) signal is monitored * for output flow control.
    * If this member is TRUE and DSR is turned off, output is suspended * until DSR is sent again. * * @param fOutxDsrFlow */ public void setfOutxDsrFlow(boolean fOutxDsrFlow) { int tmp = leftShiftMask(fOutxDsrFlow ? 1 : 0, (byte)3, 0x01, this.intValue()); this.setValue(tmp); } /** * If this member is TRUE, parity checking is performed and errors are * reported. * * @param fParity */ public void setfParity(boolean fParity) { int tmp = leftShiftMask(fParity ? 1 : 0, (byte)1, 0x01, this.intValue()); this.setValue(tmp); } /** * * The RTS (request-to-send) flow control. This member can be one of the * following values. *
  • {@link WinBase#RTS_CONTROL_DISABLE}
  • *
  • {@link WinBase#RTS_CONTROL_ENABLE}
  • *
  • {@link WinBase#RTS_CONTROL_HANDSHAKE}
  • *
  • {@link WinBase#RTS_CONTROL_TOGGLE}
  • * * @param fRtsControl */ public void setfRtsControl(int fRtsControl) { int tmp = leftShiftMask(fRtsControl, (byte)12, 0x03, this.intValue()); this.setValue(tmp); } /** * If this member is TRUE, transmission continues after the input buffer * has come within XoffLim bytes of being full and the driver has * transmitted the XoffChar character to stop receiving bytes.
    * If this member is FALSE, transmission does not continue until the * input buffer is within XonLim bytes of being empty and the driver has * transmitted the XonChar character to resume reception. * * @param fTXContinueOnXoff */ public void setfTXContinueOnXoff(boolean fTXContinueOnXoff) { int tmp = leftShiftMask(fTXContinueOnXoff ? 1 : 0, (byte)7, 0x01, this.intValue()); this.setValue(tmp); } private static int leftShiftMask(int valuetoset, byte shift, int mask, int storage) { int tmp = storage; tmp &= ~(mask << shift); tmp |= ((valuetoset & mask) << shift); return tmp; } } /** * The length of the structure, in bytes. The caller must set this * member to sizeof(DCB). */ public DWORD DCBlength; /** * * The baud rate at which the communications device operates. This * member can be an actual baud rate value, or one of the following * indexes. *
  • {@link WinBase#CBR_110}
  • *
  • {@link WinBase#CBR_300}
  • *
  • {@link WinBase#CBR_600}
  • *
  • {@link WinBase#CBR_1200}
  • *
  • {@link WinBase#CBR_2400}
  • *
  • {@link WinBase#CBR_4800}
  • *
  • {@link WinBase#CBR_9600}
  • *
  • {@link WinBase#CBR_14400}
  • *
  • {@link WinBase#CBR_19200}
  • *
  • {@link WinBase#CBR_38400}
  • *
  • {@link WinBase#CBR_56000}
  • *
  • {@link WinBase#CBR_128000}
  • *
  • {@link WinBase#CBR_256000}
  • * */ public DWORD BaudRate; /** * Contains all the bit wise setting entries. */ public DCBControllBits controllBits; /** * Reserved; must be zero. */ public WORD wReserved; /** * The minimum number of bytes in use allowed in the input buffer before * flow control is activated to allow transmission by the sender. This * assumes that either XON/XOFF, RTS, or DTR input flow control is * specified in the fInX, fRtsControl, or fDtrControl members. */ public WORD XonLim; /** * The minimum number of free bytes allowed in the input buffer before * flow control is activated to inhibit the sender. Note that the sender * may transmit characters after the flow control signal has been * activated, so this value should never be zero. This assumes that * either XON/XOFF, RTS, or DTR input flow control is specified in the * fInX, fRtsControl, or fDtrControl members. The maximum number of * bytes in use allowed is calculated by subtracting this value from the * size, in bytes, of the input buffer. */ public WORD XoffLim; /** * The number of bits in the bytes transmitted and received. */ public BYTE ByteSize; /** * * The parity scheme to be used. This member can be one of the following * values. *
  • {@link WinBase#EVENPARITY}
  • *
  • {@link WinBase#ODDPARITY}
  • *
  • {@link WinBase#NOPARITY}
  • *
  • {@link WinBase#SPACEPARITY}
  • *
  • {@link WinBase#MARKPARITY}
  • */ public BYTE Parity; /** * The number of stop bits to be used. This member can be one of the * following values. *
  • {@link WinBase#ONESTOPBIT}
  • *
  • {@link WinBase#ONE5STOPBITS}
  • *
  • {@link WinBase#TWOSTOPBITS}
  • */ public BYTE StopBits; /** * The value of the XON character for both transmission and reception. */ public char XonChar; /** * The value of the XOFF character for both transmission and reception. */ public char XoffChar; /** * The value of the character used to replace bytes received with a * parity error. */ public char ErrorChar; /** * The value of the character used to signal the end of data. */ public char EofChar; /** * The value of the character used to signal an event. */ public char EvtChar; /** * Reserved; do not use. */ public WORD wReserved1; public DCB() { DCBlength = new DWORD(size()); } protected List getFieldOrder() { return Arrays.asList(new String[] { "DCBlength", "BaudRate", "controllBits", "wReserved", "XonLim", "XoffLim", "ByteSize", "Parity", "StopBits", "XonChar", "XoffChar", "ErrorChar", "EofChar", "EvtChar", "wReserved1" }); } } /** * No parity. */ int NOPARITY = 0; /** * Odd parity. */ int ODDPARITY = 1; /** * Even parity. */ int EVENPARITY = 2; /** * Mark parity. */ int MARKPARITY = 3; /** * Space parity. */ int SPACEPARITY = 4; /** * 1 stop bit. */ int ONESTOPBIT = 0; /** * 1.5 stop bits. */ int ONE5STOPBITS = 1; /** * 2 stop bits. */ int TWOSTOPBITS = 2; /** * 110 bps. */ int CBR_110 = 110; /** * 300 bps. */ int CBR_300 = 300; /** * 600 bps. */ int CBR_600 = 600; /** * 1200 bps. */ int CBR_1200 = 1200; /** * 2400 bps. */ int CBR_2400 = 2400; /** * 4800 bps. */ int CBR_4800 = 4800; /** * 9600 bps. */ int CBR_9600 = 9600; /** * 14400 bps. */ int CBR_14400 = 14400; /** * 19200 bps. */ int CBR_19200 = 19200; /** * 38400 bps. */ int CBR_38400 = 38400; /** * 56000 bps. */ int CBR_56000 = 56000; /** * 128000 bps. */ int CBR_128000 = 128000; /** * 256000 bps. */ int CBR_256000 = 256000; /** * Disables the DTR line when the device is opened and leaves it disabled. */ int DTR_CONTROL_DISABLE = 0; /** * Enables the DTR line when the device is opened and leaves it on. */ int DTR_CONTROL_ENABLE = 1; /** * Enables DTR handshaking.
    * If handshaking is enabled, it is an error for the application to adjust * the line by using the EscapeCommFunction function. */ int DTR_CONTROL_HANDSHAKE = 2; /** * Disables the RTS line when the device is opened and leaves it disabled. */ int RTS_CONTROL_DISABLE = 0; /** * Enables the RTS line when the device is opened and leaves it on. */ int RTS_CONTROL_ENABLE = 1; /** * Enables RTS handshaking.
    * The driver raises the RTS line when the "type-ahead" (input) buffer is * less than one-half full and lowers the RTS line when the buffer is more * than three-quarters full.
    * If handshaking is enabled, it is an error for the application to adjust * the line by using the EscapeCommFunction function. */ int RTS_CONTROL_HANDSHAKE = 2; /** * Specifies that the RTS line will be high if bytes are available for * transmission.
    * After all buffered bytes have been sent, the RTS line will be low. */ int RTS_CONTROL_TOGGLE = 3;; }




    © 2015 - 2025 Weber Informatics LLC | Privacy Policy