José Fonseca | 7ad4026 | 2009-09-30 17:17:12 +0100 | [diff] [blame] | 1 | ########################################################################## |
José Fonseca | 9544244 | 2008-07-08 10:32:53 +0900 | [diff] [blame] | 2 | # |
José Fonseca | 7ad4026 | 2009-09-30 17:17:12 +0100 | [diff] [blame] | 3 | # Copyright 2008-2009 VMware, Inc. |
| 4 | # All Rights Reserved. |
José Fonseca | 9544244 | 2008-07-08 10:32:53 +0900 | [diff] [blame] | 5 | # |
José Fonseca | 7ad4026 | 2009-09-30 17:17:12 +0100 | [diff] [blame] | 6 | # Permission is hereby granted, free of charge, to any person obtaining a copy |
| 7 | # of this software and associated documentation files (the "Software"), to deal |
| 8 | # in the Software without restriction, including without limitation the rights |
| 9 | # to use, copy, modify, merge, publish, distribute, sublicense, and/or sell |
| 10 | # copies of the Software, and to permit persons to whom the Software is |
| 11 | # furnished to do so, subject to the following conditions: |
José Fonseca | 9544244 | 2008-07-08 10:32:53 +0900 | [diff] [blame] | 12 | # |
José Fonseca | 7ad4026 | 2009-09-30 17:17:12 +0100 | [diff] [blame] | 13 | # The above copyright notice and this permission notice shall be included in |
| 14 | # all copies or substantial portions of the Software. |
José Fonseca | 9544244 | 2008-07-08 10:32:53 +0900 | [diff] [blame] | 15 | # |
José Fonseca | 7ad4026 | 2009-09-30 17:17:12 +0100 | [diff] [blame] | 16 | # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR |
| 17 | # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| 18 | # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE |
| 19 | # AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER |
| 20 | # LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
| 21 | # OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN |
| 22 | # THE SOFTWARE. |
José Fonseca | 9544244 | 2008-07-08 10:32:53 +0900 | [diff] [blame] | 23 | # |
José Fonseca | 7ad4026 | 2009-09-30 17:17:12 +0100 | [diff] [blame] | 24 | ##########################################################################/ |
José Fonseca | 9544244 | 2008-07-08 10:32:53 +0900 | [diff] [blame] | 25 | |
José Fonseca | f20c126 | 2010-11-25 11:39:57 +0000 | [diff] [blame] | 26 | """Win32 API type description.""" |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 27 | |
José Fonseca | 9a3468a | 2012-04-16 12:54:05 +0100 | [diff] [blame] | 28 | |
Piotr Podsiadły | 0b8b019 | 2019-01-03 20:39:55 +0100 | [diff] [blame] | 29 | from .stdapi import * |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 30 | |
José Fonseca | 9a3468a | 2012-04-16 12:54:05 +0100 | [diff] [blame] | 31 | |
José Fonseca | 51c1ef8 | 2010-11-15 16:09:14 +0000 | [diff] [blame] | 32 | SHORT = Alias("SHORT", Short) |
| 33 | USHORT = Alias("USHORT", UShort) |
| 34 | INT = Alias("INT", Int) |
| 35 | UINT = Alias("UINT", UInt) |
| 36 | LONG = Alias("LONG", Long) |
| 37 | ULONG = Alias("ULONG", ULong) |
| 38 | LONGLONG = Alias("LONGLONG", LongLong) |
Jose Fonseca | 503fde9 | 2015-07-16 17:00:30 +0100 | [diff] [blame] | 39 | ULONGLONG = Alias("ULONGLONG", ULongLong) |
José Fonseca | 51c1ef8 | 2010-11-15 16:09:14 +0000 | [diff] [blame] | 40 | FLOAT = Alias("FLOAT", Float) |
José Fonseca | 73f33cc | 2008-07-09 02:17:51 +0900 | [diff] [blame] | 41 | |
José Fonseca | af7d231 | 2011-07-07 10:16:57 +0100 | [diff] [blame] | 42 | INT8 = Alias("INT8", Int8) |
| 43 | UINT8 = Alias("UINT8", UInt8) |
| 44 | INT16 = Alias("INT16", Int16) |
| 45 | UINT16 = Alias("UINT16", UInt16) |
| 46 | INT32 = Alias("INT32", Int32) |
| 47 | UINT32 = Alias("UINT32", UInt32) |
| 48 | INT64 = Alias("INT64", Int64) |
| 49 | UINT64 = Alias("UINT64", UInt64) |
José Fonseca | 89daf56 | 2014-08-15 16:10:47 +0100 | [diff] [blame] | 50 | FLOAT32 = Alias("FLOAT32", Float) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 51 | |
José Fonseca | 7416346 | 2011-10-15 11:21:15 +0100 | [diff] [blame] | 52 | BYTE = Alias("BYTE", UInt8) |
| 53 | WORD = Alias("WORD", UInt16) |
| 54 | DWORD = Alias("DWORD", UInt32) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 55 | |
José Fonseca | 9a40d9e | 2012-07-25 20:31:30 +0100 | [diff] [blame] | 56 | UCHAR = Alias("UCHAR", UChar) |
José Fonseca | 2f2ea48 | 2011-10-15 15:10:06 +0100 | [diff] [blame] | 57 | WCHAR = Alias("WCHAR", Short) |
José Fonseca | 8384ccb | 2011-05-25 10:12:02 +0100 | [diff] [blame] | 58 | |
José Fonseca | 851bbaf | 2012-04-16 19:37:25 +0100 | [diff] [blame] | 59 | BOOL = Enum("BOOL", [ |
| 60 | "FALSE", |
| 61 | "TRUE", |
| 62 | ]) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 63 | |
Jose Fonseca | f7a7130 | 2015-08-13 16:10:06 +0100 | [diff] [blame] | 64 | PSTR = Alias("PSTR", CString) |
| 65 | PCSTR = Alias("PCSTR", ConstCString) |
| 66 | PWSTR = Alias("PWSTR", WString) |
| 67 | PCWSTR = Alias("PCWSTR", ConstWString) |
| 68 | |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 69 | LPLONG = Pointer(LONG) |
| 70 | LPWORD = Pointer(WORD) |
| 71 | LPDWORD = Pointer(DWORD) |
| 72 | LPBOOL = Pointer(BOOL) |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 73 | |
José Fonseca | 5f81c3a | 2010-11-24 08:42:22 +0000 | [diff] [blame] | 74 | LPSTR = CString |
José Fonseca | bcfc81b | 2012-08-07 21:07:22 +0100 | [diff] [blame] | 75 | LPCSTR = ConstCString |
José Fonseca | e54e411 | 2009-06-25 13:56:18 +0100 | [diff] [blame] | 76 | LPWSTR = WString |
José Fonseca | bcfc81b | 2012-08-07 21:07:22 +0100 | [diff] [blame] | 77 | LPCWSTR = ConstWString |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 78 | |
José Fonseca | 51c1ef8 | 2010-11-15 16:09:14 +0000 | [diff] [blame] | 79 | LARGE_INTEGER = Struct("LARGE_INTEGER", [ |
| 80 | (LONGLONG, 'QuadPart'), |
| 81 | ]) |
| 82 | |
José Fonseca | 0b8fea1 | 2009-09-28 11:33:36 +0100 | [diff] [blame] | 83 | SIZE_T = Alias("SIZE_T", SizeT) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 84 | |
José Fonseca | e02bb2a | 2010-11-24 16:19:16 +0000 | [diff] [blame] | 85 | VOID = Void |
José Fonseca | d93791e | 2012-04-20 07:15:38 +0100 | [diff] [blame] | 86 | PVOID = OpaquePointer(VOID) |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 87 | LPVOID = PVOID |
José Fonseca | 467a42a | 2012-05-04 11:49:19 +0100 | [diff] [blame] | 88 | LPCVOID = OpaquePointer(Const(VOID)) |
José Fonseca | 87b5183 | 2012-04-05 19:57:45 +0100 | [diff] [blame] | 89 | |
| 90 | def DECLARE_HANDLE(expr): |
| 91 | return Handle(expr, IntPointer(expr)) |
| 92 | |
Jose Fonseca | 559b5f8 | 2015-07-17 16:58:50 +0100 | [diff] [blame] | 93 | # XXX: HANDLE type is often used for disjoint handle namespaces |
| 94 | RAW_HANDLE = IntPointer("HANDLE") |
| 95 | HANDLE = Handle("HANDLE", RAW_HANDLE) |
| 96 | |
José Fonseca | 87b5183 | 2012-04-05 19:57:45 +0100 | [diff] [blame] | 97 | HWND = DECLARE_HANDLE("HWND") |
| 98 | HDC = DECLARE_HANDLE("HDC") |
| 99 | HMONITOR = DECLARE_HANDLE("HMONITOR") |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 100 | |
José Fonseca | 8a56d14 | 2008-07-09 12:18:08 +0900 | [diff] [blame] | 101 | GUID = Struct("GUID", [ |
| 102 | (DWORD, "Data1"), |
| 103 | (WORD, "Data2"), |
| 104 | (WORD, "Data3"), |
José Fonseca | 4475665 | 2011-10-15 10:26:30 +0100 | [diff] [blame] | 105 | (Array(BYTE, 8), "Data4"), |
José Fonseca | 8a56d14 | 2008-07-09 12:18:08 +0900 | [diff] [blame] | 106 | ]) |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 107 | LPGUID = Pointer(GUID) |
José Fonseca | 8a56d14 | 2008-07-09 12:18:08 +0900 | [diff] [blame] | 108 | |
José Fonseca | b89c593 | 2012-04-01 22:47:11 +0200 | [diff] [blame] | 109 | REFGUID = Alias("REFGUID", Reference(GUID)) |
José Fonseca | 8a56d14 | 2008-07-09 12:18:08 +0900 | [diff] [blame] | 110 | |
| 111 | IID = Alias("IID", GUID) |
José Fonseca | b89c593 | 2012-04-01 22:47:11 +0200 | [diff] [blame] | 112 | REFIID = Alias("REFIID", Reference(IID)) |
José Fonseca | 8a56d14 | 2008-07-09 12:18:08 +0900 | [diff] [blame] | 113 | |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 114 | CLSID = Alias("CLSID", GUID) |
José Fonseca | b89c593 | 2012-04-01 22:47:11 +0200 | [diff] [blame] | 115 | REFCLSID = Alias("REFCLSID", Reference(CLSID)) |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 116 | |
José Fonseca | 8a56d14 | 2008-07-09 12:18:08 +0900 | [diff] [blame] | 117 | LUID = Struct("LUID", [ |
| 118 | (DWORD, "LowPart"), |
| 119 | (LONG, "HighPart"), |
| 120 | ]) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 121 | |
| 122 | POINT = Struct("POINT", ( |
| 123 | (LONG, "x"), |
| 124 | (LONG, "y"), |
| 125 | )) |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 126 | LPPOINT = Pointer(POINT) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 127 | |
José Fonseca | 8384ccb | 2011-05-25 10:12:02 +0100 | [diff] [blame] | 128 | SIZE = Struct("SIZE", ( |
| 129 | (LONG, "cx"), |
| 130 | (LONG, "cy"), |
| 131 | )) |
| 132 | LPSIZE = Pointer(SIZE) |
| 133 | |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 134 | RECT = Struct("RECT", ( |
| 135 | (LONG, "left"), |
| 136 | (LONG, "top"), |
| 137 | (LONG, "right"), |
| 138 | (LONG, "bottom"), |
| 139 | )) |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 140 | LPRECT = Pointer(RECT) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 141 | |
| 142 | PALETTEENTRY = Struct("PALETTEENTRY", ( |
| 143 | (BYTE, "peRed"), |
| 144 | (BYTE, "peGreen"), |
| 145 | (BYTE, "peBlue"), |
| 146 | (BYTE, "peFlags"), |
| 147 | )) |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 148 | LPPALETTEENTRY = Pointer(PALETTEENTRY) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 149 | |
José Fonseca | 8a56d14 | 2008-07-09 12:18:08 +0900 | [diff] [blame] | 150 | |
| 151 | RGNDATAHEADER = Struct("RGNDATAHEADER", [ |
| 152 | (DWORD, "dwSize"), |
| 153 | (DWORD, "iType"), |
| 154 | (DWORD, "nCount"), |
| 155 | (DWORD, "nRgnSize"), |
| 156 | (RECT, "rcBound"), |
| 157 | ]) |
| 158 | |
| 159 | RGNDATA = Struct("RGNDATA", [ |
| 160 | (RGNDATAHEADER, "rdh"), |
| 161 | #(Char, "Buffer[1]"), |
| 162 | ]) |
José Fonseca | c569f87 | 2009-01-04 16:45:17 +0000 | [diff] [blame] | 163 | LPRGNDATA = Pointer(RGNDATA) |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 164 | |
José Fonseca | ea79919 | 2012-11-13 21:37:24 +0000 | [diff] [blame] | 165 | HMODULE = IntPointer("HMODULE") |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 166 | |
José Fonseca | b9ac058 | 2012-02-03 19:06:50 +0000 | [diff] [blame] | 167 | FILETIME = Struct("FILETIME", [ |
| 168 | (DWORD, "dwLowDateTime"), |
| 169 | (DWORD, "dwHighDateTime"), |
| 170 | ]) |
| 171 | |
| 172 | COLORREF = Alias("COLORREF", DWORD) |
| 173 | |
| 174 | LOGFONTW = Struct("LOGFONTW", [ |
| 175 | (LONG, "lfHeight"), |
| 176 | (LONG, "lfWidth"), |
| 177 | (LONG, "lfEscapement"), |
| 178 | (LONG, "lfOrientation"), |
| 179 | (LONG, "lfWeight"), |
| 180 | (BYTE, "lfItalic"), |
| 181 | (BYTE, "lfUnderline"), |
| 182 | (BYTE, "lfStrikeOut"), |
| 183 | (BYTE, "lfCharSet"), |
| 184 | (BYTE, "lfOutPrecision"), |
| 185 | (BYTE, "lfClipPrecision"), |
| 186 | (BYTE, "lfQuality"), |
| 187 | (BYTE, "lfPitchAndFamily"), |
| 188 | (WString, "lfFaceName"), |
| 189 | ]) |
| 190 | |
Jeff Muizelaar | cd3f69e | 2013-03-11 15:56:30 -0400 | [diff] [blame] | 191 | SECURITY_ATTRIBUTES = Struct("SECURITY_ATTRIBUTES", [ |
| 192 | (DWORD, "nLength"), |
| 193 | (LPVOID, "lpSecurityDescriptor"), |
| 194 | (BOOL, "bInheritHandle"), |
| 195 | ]) |
José Fonseca | 9a3468a | 2012-04-16 12:54:05 +0100 | [diff] [blame] | 196 | |
| 197 | # http://msdn.microsoft.com/en-us/library/ff485842.aspx |
José Fonseca | 289c213 | 2015-02-19 20:25:13 +0000 | [diff] [blame] | 198 | # http://blogs.msdn.com/b/kirillosenkov/archive/2012/05/14/a-list-of-common-hresult-error-codes.aspx |
| 199 | HRESULT = Enum("HRESULT", [ |
| 200 | "S_OK", # 0x00000000 |
| 201 | "S_FALSE", # 0x00000001 |
| 202 | "E_PENDING", # 0x8000000A |
| 203 | "E_NOTIMPL", # 0x80004001 |
| 204 | "E_NOINTERFACE", # 0x80004002 |
| 205 | "E_POINTER", # 0x80004003 |
| 206 | "E_ABORT", # 0x80004004 |
| 207 | "E_FAIL", # 0x80004005 |
| 208 | "E_UNEXPECTED", # 0x8000FFFF |
| 209 | "E_ACCESSDENIED", # 0x80070005 |
| 210 | "E_HANDLE", # 0x80070006 |
| 211 | "E_OUTOFMEMORY", # 0x8007000E |
| 212 | "E_INVALIDARG", # 0x80070057 |
| 213 | ]) |
| 214 | |
José Fonseca | 73841ad | 2012-04-16 20:47:56 +0100 | [diff] [blame] | 215 | def MAKE_HRESULT(errors, ok = "S_OK", false = "S_FALSE"): |
José Fonseca | 289c213 | 2015-02-19 20:25:13 +0000 | [diff] [blame] | 216 | # Always update global HRESULT |
| 217 | HRESULT.values.extend(errors) |
| 218 | if ok == "S_OK" and false == "S_FALSE": |
| 219 | # Just return global HRESULT |
| 220 | return HRESULT |
| 221 | else: |
| 222 | # Return a variation |
| 223 | values = [ok, false] |
| 224 | assert HRESULT.values[0] == "S_OK" |
| 225 | assert HRESULT.values[1] == "S_FALSE" |
| 226 | values.extend(HRESULT.values[2:]) |
| 227 | return Enum("HRESULT", values) |
José Fonseca | 9a3468a | 2012-04-16 12:54:05 +0100 | [diff] [blame] | 228 | |
| 229 | IUnknown = Interface("IUnknown") |
| 230 | |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 231 | IUnknown.methods = ( |
José Fonseca | 467a42a | 2012-05-04 11:49:19 +0100 | [diff] [blame] | 232 | StdMethod(HRESULT, "QueryInterface", ((REFIID, "riid"), Out(Pointer(ObjPointer(Void)), "ppvObj"))), |
José Fonseca | a936afc | 2013-02-19 13:28:24 +0000 | [diff] [blame] | 233 | StdMethod(ULONG, "AddRef", ()), |
José Fonseca | 467a42a | 2012-05-04 11:49:19 +0100 | [diff] [blame] | 234 | StdMethod(ULONG, "Release", ()), |
José Fonseca | d626cf4 | 2008-07-07 07:43:16 +0900 | [diff] [blame] | 235 | ) |
| 236 | |
| 237 | |