kernel32.odin 44 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277
  1. #+build windows
  2. package sys_windows
  3. foreign import kernel32 "system:Kernel32.lib"
  4. foreign import one_core "system:OneCore.lib"
  5. FOREGROUND_BLUE :: WORD(0x0001)
  6. FOREGROUND_GREEN :: WORD(0x0002)
  7. FOREGROUND_RED :: WORD(0x0004)
  8. FOREGROUND_INTENSITY :: WORD(0x0008)
  9. BACKGROUND_BLUE :: WORD(0x0010)
  10. BACKGROUND_GREEN :: WORD(0x0020)
  11. BACKGROUND_RED :: WORD(0x0040)
  12. BACKGROUND_INTENSITY :: WORD(0x0080)
  13. COMMON_LVB_LEADING_BYTE :: WORD(0x0100)
  14. COMMON_LVB_TRAILING_BYTE :: WORD(0x0200)
  15. COMMON_LVB_GRID_HORIZONTAL :: WORD(0x0400)
  16. COMMON_LVB_GRID_LVERTICAL :: WORD(0x0800)
  17. COMMON_LVB_GRID_RVERTICAL :: WORD(0x1000)
  18. COMMON_LVB_REVERSE_VIDEO :: WORD(0x4000)
  19. COMMON_LVB_UNDERSCORE :: WORD(0x8000)
  20. COMMON_LVB_SBCSDBCS :: WORD(0x0300)
  21. EV_BREAK :: DWORD(0x0040)
  22. EV_CTS :: DWORD(0x0008)
  23. EV_DSR :: DWORD(0x0010)
  24. EV_ERR :: DWORD(0x0080)
  25. EV_RING :: DWORD(0x0100)
  26. EV_RLSD :: DWORD(0x0020)
  27. EV_RXCHAR :: DWORD(0x0001)
  28. EV_RXFLAG :: DWORD(0x0002)
  29. EV_TXEMPTY :: DWORD(0x0004)
  30. @(default_calling_convention="system")
  31. foreign kernel32 {
  32. OutputDebugStringA :: proc(lpOutputString: LPCSTR) --- // The only A thing that is allowed
  33. OutputDebugStringW :: proc(lpOutputString: LPCWSTR) ---
  34. ReadConsoleW :: proc(hConsoleInput: HANDLE,
  35. lpBuffer: LPVOID,
  36. nNumberOfCharsToRead: DWORD,
  37. lpNumberOfCharsRead: LPDWORD,
  38. pInputControl: PCONSOLE_READCONSOLE_CONTROL) -> BOOL ---
  39. WriteConsoleW :: proc(hConsoleOutput: HANDLE,
  40. lpBuffer: LPCVOID,
  41. nNumberOfCharsToWrite: DWORD,
  42. lpNumberOfCharsWritten: LPDWORD,
  43. lpReserved: LPVOID) -> BOOL ---
  44. PeekConsoleInputW :: proc(hConsoleInput: HANDLE,
  45. lpBuffer: ^INPUT_RECORD,
  46. nLength: DWORD,
  47. lpNumberOfEventsRead: LPDWORD) -> BOOL ---
  48. ReadConsoleInputW :: proc(hConsoleInput: HANDLE,
  49. lpBuffer: ^INPUT_RECORD,
  50. nLength: DWORD,
  51. lpNumberOfEventsRead: LPDWORD) -> BOOL ---
  52. // https://learn.microsoft.com/en-us/windows/console/getnumberofconsoleinputevents
  53. GetNumberOfConsoleInputEvents :: proc(hConsoleInput: HANDLE, lpcNumberOfEvents: LPDWORD) -> BOOL ---
  54. GetConsoleMode :: proc(hConsoleHandle: HANDLE, lpMode: LPDWORD) -> BOOL ---
  55. SetConsoleMode :: proc(hConsoleHandle: HANDLE, dwMode: DWORD) -> BOOL ---
  56. SetConsoleCursorPosition :: proc(hConsoleHandle: HANDLE, dwCursorPosition: COORD) -> BOOL ---
  57. SetConsoleTextAttribute :: proc(hConsoleOutput: HANDLE, wAttributes: WORD) -> BOOL ---
  58. GetConsoleCP :: proc() -> CODEPAGE ---
  59. SetConsoleCP :: proc(wCodePageID: CODEPAGE) -> BOOL ---
  60. GetConsoleOutputCP :: proc() -> CODEPAGE ---
  61. SetConsoleOutputCP :: proc(wCodePageID: CODEPAGE) -> BOOL ---
  62. FlushConsoleInputBuffer :: proc(hConsoleInput: HANDLE) -> BOOL ---
  63. GetFileInformationByHandle :: proc(hFile: HANDLE, lpFileInformation: LPBY_HANDLE_FILE_INFORMATION) -> BOOL ---
  64. SetHandleInformation :: proc(hObject: HANDLE,
  65. dwMask: DWORD,
  66. dwFlags: DWORD) -> BOOL ---
  67. SetFileInformationByHandle :: proc(hFile: HANDLE,
  68. FileInformationClass: FILE_INFO_BY_HANDLE_CLASS,
  69. lpFileInformation: LPVOID,
  70. dwBufferSize: DWORD) -> BOOL ---
  71. AddVectoredExceptionHandler :: proc(FirstHandler: ULONG, VectoredHandler: PVECTORED_EXCEPTION_HANDLER) -> LPVOID ---
  72. AddVectoredContinueHandler :: proc(FirstHandler: ULONG, VectoredHandler: PVECTORED_EXCEPTION_HANDLER) -> LPVOID ---
  73. RemoveVectoredExceptionHandler :: proc(Handle: LPVOID) -> DWORD ---
  74. RemoveVectoredContinueHandler :: proc(Handle: LPVOID) -> DWORD ---
  75. RaiseException :: proc(dwExceptionCode, dwExceptionFlags, nNumberOfArguments: DWORD, lpArguments: ^ULONG_PTR) -> ! ---
  76. SetUnhandledExceptionFilter :: proc(lpTopLevelExceptionFilter: LPTOP_LEVEL_EXCEPTION_FILTER) -> LPTOP_LEVEL_EXCEPTION_FILTER ---
  77. CreateHardLinkW :: proc(lpSymlinkFileName: LPCWSTR,
  78. lpTargetFileName: LPCWSTR,
  79. lpSecurityAttributes: LPSECURITY_ATTRIBUTES) -> BOOL ---
  80. CreateSymbolicLinkW :: proc(lpSymlinkFileName: LPCWSTR,
  81. lpTargetFileName: LPCWSTR,
  82. dwFlags: DWORD) -> BOOLEAN ---
  83. GetFileInformationByHandleEx :: proc(hFile: HANDLE,
  84. fileInfoClass: FILE_INFO_BY_HANDLE_CLASS,
  85. lpFileInformation: LPVOID,
  86. dwBufferSize: DWORD) -> BOOL ---
  87. InitializeCriticalSection :: proc(CriticalSection: ^CRITICAL_SECTION) ---
  88. InitializeCriticalSectionAndSpinCount :: proc(CriticalSection: ^CRITICAL_SECTION, dwSpinCount: DWORD) -> BOOL ---
  89. EnterCriticalSection :: proc(CriticalSection: ^CRITICAL_SECTION) ---
  90. TryEnterCriticalSection :: proc(CriticalSection: ^CRITICAL_SECTION) -> BOOLEAN ---
  91. LeaveCriticalSection :: proc(CriticalSection: ^CRITICAL_SECTION) ---
  92. DeleteCriticalSection :: proc(CriticalSection: ^CRITICAL_SECTION) ---
  93. RemoveDirectoryW :: proc(lpPathName: LPCWSTR) -> BOOL ---
  94. SetFileAttributesW :: proc(lpFileName: LPCWSTR, dwFileAttributes: DWORD) -> BOOL ---
  95. SetLastError :: proc(dwErrCode: DWORD) ---
  96. GetCommTimeouts :: proc(handle: HANDLE, timeouts: ^COMMTIMEOUTS) -> BOOL ---
  97. SetCommTimeouts :: proc(handle: HANDLE, timeouts: ^COMMTIMEOUTS) -> BOOL ---
  98. ClearCommError :: proc(hFile: HANDLE, lpErrors: ^Com_Error, lpStat: ^COMSTAT) -> BOOL ---
  99. GetCommState :: proc(handle: HANDLE, dcb: ^DCB) -> BOOL ---
  100. SetCommState :: proc(handle: HANDLE, dcb: ^DCB) -> BOOL ---
  101. SetCommMask :: proc(handle: HANDLE, dwEvtMap: DWORD) -> BOOL ---
  102. GetCommMask :: proc(handle: HANDLE, lpEvtMask: LPDWORD) -> BOOL ---
  103. WaitCommEvent :: proc(handle: HANDLE, lpEvtMask: LPDWORD, lpOverlapped: LPOVERLAPPED) -> BOOL ---
  104. GetCommandLineW :: proc() -> LPCWSTR ---
  105. GetTempPathW :: proc(nBufferLength: DWORD, lpBuffer: LPCWSTR) -> DWORD ---
  106. GetTempFileNameW :: proc(lpPathName: LPCWSTR, lpPrefixString: LPCWSTR, uUnique: c_int, lpTempFileName: LPWSTR) -> c_uint ---
  107. GetCurrentProcess :: proc() -> HANDLE ---
  108. GetCurrentProcessId :: proc() -> DWORD ---
  109. GetCurrentThread :: proc() -> HANDLE ---
  110. GetCurrentThreadId :: proc() -> DWORD ---
  111. GetProcessTimes :: proc(
  112. hProcess: HANDLE,
  113. lpCreationTime: LPFILETIME,
  114. lpExitTime: LPFILETIME,
  115. lpKernelTime: LPFILETIME,
  116. lpUserTime: LPFILETIME,
  117. ) -> BOOL ---
  118. GetStdHandle :: proc(which: DWORD) -> HANDLE ---
  119. ExitProcess :: proc(uExitCode: c_uint) -> ! ---
  120. DeviceIoControl :: proc(
  121. hDevice: HANDLE,
  122. dwIoControlCode: DWORD,
  123. lpInBuffer: LPVOID,
  124. nInBufferSize: DWORD,
  125. lpOutBuffer: LPVOID,
  126. nOutBufferSize: DWORD,
  127. lpBytesReturned: LPDWORD,
  128. lpOverlapped: LPOVERLAPPED,
  129. ) -> BOOL ---
  130. CreateThread :: proc(
  131. lpThreadAttributes: LPSECURITY_ATTRIBUTES,
  132. dwStackSize: SIZE_T,
  133. lpStartAddress: proc "system" (rawptr) -> DWORD,
  134. lpParameter: LPVOID,
  135. dwCreationFlags: DWORD,
  136. lpThreadId: LPDWORD,
  137. ) -> HANDLE ---
  138. CreateRemoteThread :: proc(
  139. hProcess: HANDLE,
  140. lpThreadAttributes: LPSECURITY_ATTRIBUTES,
  141. dwStackSize: SIZE_T,
  142. lpStartAddress: proc "system" (rawptr) -> DWORD,
  143. lpParameter: LPVOID,
  144. dwCreationFlags: DWORD,
  145. lpThreadId: LPDWORD,
  146. ) -> HANDLE ---
  147. SwitchToThread :: proc() -> BOOL ---
  148. ResumeThread :: proc(thread: HANDLE) -> DWORD ---
  149. GetThreadPriority :: proc(thread: HANDLE) -> c_int ---
  150. SetThreadPriority :: proc(thread: HANDLE, priority: c_int) -> BOOL ---
  151. GetThreadDescription :: proc(hThread: HANDLE, ppszThreadDescription: ^PCWSTR) -> HRESULT ---
  152. SetThreadDescription :: proc(hThread: HANDLE, lpThreadDescription: PCWSTR) -> HRESULT ---
  153. GetExitCodeThread :: proc(thread: HANDLE, exit_code: ^DWORD) -> BOOL ---
  154. TerminateThread :: proc(thread: HANDLE, exit_code: DWORD) -> BOOL ---
  155. SuspendThread :: proc(hThread: HANDLE) -> DWORD ---
  156. GetProcessAffinityMask :: proc(
  157. hProcess: HANDLE,
  158. lpProcessAffinityMask: PDWORD_PTR,
  159. lpSystemAffinityMask: PDWORD_PTR,
  160. ) -> BOOL ---
  161. SetProcessAffinityMask :: proc(
  162. hProcess: HANDLE,
  163. dwProcessAffinityMask: DWORD_PTR,
  164. ) -> BOOL ---
  165. SetThreadAffinityMask :: proc(
  166. hThread: HANDLE,
  167. dwThreadAffinityMask: DWORD_PTR,
  168. ) -> DWORD_PTR ---
  169. CreateSemaphoreW :: proc(attributes: LPSECURITY_ATTRIBUTES, initial_count, maximum_count: LONG, name: LPCWSTR) -> HANDLE ---
  170. ReleaseSemaphore :: proc(semaphore: HANDLE, release_count: LONG, previous_count: ^LONG) -> BOOL ---
  171. CreateWaitableTimerW :: proc(
  172. lpTimerAttributes: LPSECURITY_ATTRIBUTES,
  173. bManualReset: BOOL,
  174. lpTimerName: LPCWSTR,
  175. ) -> HANDLE ---
  176. CreateWaitableTimerExW :: proc(
  177. lpTimerAttributes: LPSECURITY_ATTRIBUTES,
  178. lpTimerName: LPCWSTR,
  179. dwFlags: DWORD,
  180. dwDesiredAccess: DWORD,
  181. ) -> HANDLE ---
  182. SetWaitableTimerEx :: proc(
  183. hTimer: HANDLE,
  184. lpDueTime: ^LARGE_INTEGER,
  185. lPeriod: LONG,
  186. pfnCompletionRoutine: PTIMERAPCROUTINE,
  187. lpArgToCompletionRoutine: LPVOID,
  188. WakeContext: PREASON_CONTEXT,
  189. TolerableDelay: ULONG,
  190. ) -> BOOL ---
  191. WaitForSingleObject :: proc(hHandle: HANDLE, dwMilliseconds: DWORD) -> DWORD ---
  192. WaitForSingleObjectEx :: proc(hHandle: HANDLE, dwMilliseconds: DWORD, bAlterable: BOOL) -> DWORD ---
  193. Sleep :: proc(dwMilliseconds: DWORD) ---
  194. GetProcessId :: proc(handle: HANDLE) -> DWORD ---
  195. CopyFileW :: proc(
  196. lpExistingFileName: LPCWSTR,
  197. lpNewFileName: LPCWSTR,
  198. bFailIfExists: BOOL,
  199. ) -> BOOL ---
  200. CopyFileExW :: proc(
  201. lpExistingFileName: LPCWSTR,
  202. lpNewFileName: LPCWSTR,
  203. lpProgressRoutine: LPPROGRESS_ROUTINE,
  204. lpData: LPVOID,
  205. pbCancel: LPBOOL,
  206. dwCopyFlags: DWORD,
  207. ) -> BOOL ---
  208. FormatMessageW :: proc(
  209. flags: DWORD,
  210. lpSrc: LPVOID,
  211. msgId: DWORD,
  212. langId: DWORD,
  213. buf: LPWSTR,
  214. nsize: DWORD,
  215. args: rawptr,
  216. ) -> DWORD ---
  217. TlsAlloc :: proc() -> DWORD ---
  218. TlsFree :: proc(dwTlsIndex: DWORD) -> BOOL ---
  219. TlsGetValue :: proc(dwTlsIndex: DWORD) -> LPVOID ---
  220. TlsSetValue :: proc(dwTlsIndex: DWORD, lpTlsvalue: LPVOID) -> BOOL ---
  221. GetLastError :: proc() -> DWORD ---
  222. QueryPerformanceFrequency :: proc(lpFrequency: ^LARGE_INTEGER) -> BOOL ---
  223. QueryPerformanceCounter :: proc(lpPerformanceCount: ^LARGE_INTEGER) -> BOOL ---
  224. GetExitCodeProcess :: proc(hProcess: HANDLE, lpExitCode: LPDWORD) -> BOOL ---
  225. TerminateProcess :: proc(hProcess: HANDLE, uExitCode: UINT) -> BOOL ---
  226. OpenProcess :: proc(dwDesiredAccess: DWORD, bInheritHandle: BOOL, dwProcessId: DWORD) -> HANDLE ---
  227. OpenThread :: proc(dwDesiredAccess: DWORD, bInheritHandle: BOOL, dwThreadId: DWORD) -> HANDLE ---
  228. GetThreadContext :: proc(
  229. hThread: HANDLE,
  230. lpContext: LPCONTEXT,
  231. ) -> BOOL ---
  232. SetThreadContext :: proc(
  233. hThread: HANDLE,
  234. lpContext: LPCONTEXT,
  235. ) -> BOOL ---
  236. CreateProcessW :: proc(
  237. lpApplicationName: LPCWSTR,
  238. lpCommandLine: LPCWSTR,
  239. lpProcessAttributes: LPSECURITY_ATTRIBUTES,
  240. lpThreadAttributes: LPSECURITY_ATTRIBUTES,
  241. bInheritHandles: BOOL,
  242. dwCreationFlags: DWORD,
  243. lpEnvironment: LPVOID,
  244. lpCurrentDirectory: LPCWSTR,
  245. lpStartupInfo: LPSTARTUPINFOW,
  246. lpProcessInformation: LPPROCESS_INFORMATION,
  247. ) -> BOOL ---
  248. GetStartupInfoW :: proc(lpStartupInfo: LPSTARTUPINFOW) ---
  249. GetEnvironmentVariableW :: proc(n: LPCWSTR, v: LPWSTR, nsize: DWORD) -> DWORD ---
  250. SetEnvironmentVariableW :: proc(n: LPCWSTR, v: LPCWSTR) -> BOOL ---
  251. GetEnvironmentStringsW :: proc() -> LPWCH ---
  252. FreeEnvironmentStringsW :: proc(env_ptr: LPWCH) -> BOOL ---
  253. ExpandEnvironmentStringsW :: proc(lpSrc: LPCWSTR, lpDst: LPWSTR, nSize: DWORD) -> DWORD ---
  254. GetModuleFileNameW :: proc(hModule: HMODULE, lpFilename: LPWSTR, nSize: DWORD) -> DWORD ---
  255. CreateDirectoryW :: proc(
  256. lpPathName: LPCWSTR,
  257. lpSecurityAttributes: LPSECURITY_ATTRIBUTES,
  258. ) -> BOOL ---
  259. DeleteFileW :: proc(lpPathName: LPCWSTR) -> BOOL ---
  260. GetCurrentDirectoryW :: proc(nBufferLength: DWORD, lpBuffer: LPWSTR) -> DWORD ---
  261. SetCurrentDirectoryW :: proc(lpPathName: LPCWSTR) -> BOOL ---
  262. WideCharToMultiByte :: proc(
  263. CodePage: UINT,
  264. dwFlags: DWORD,
  265. lpWideCharStr: LPCWSTR,
  266. cchWideChar: c_int,
  267. lpMultiByteStr: LPSTR,
  268. cbMultiByte: c_int,
  269. lpDefaultChar: LPCSTR,
  270. lpUsedDefaultChar: LPBOOL,
  271. ) -> c_int ---
  272. MultiByteToWideChar :: proc(
  273. CodePage: UINT,
  274. dwFlags: DWORD,
  275. lpMultiByteStr: LPSTR,
  276. cbMultiByte: c_int,
  277. lpWideCharStr: LPWSTR,
  278. cchWideChar: c_int,
  279. ) -> c_int ---
  280. DuplicateHandle :: proc(
  281. hSourceProcessHandle: HANDLE,
  282. hSourceHandle: HANDLE,
  283. hTargetProcessHandle: HANDLE,
  284. lpTargetHandle: LPHANDLE,
  285. dwDesiredAccess: DWORD,
  286. bInheritHandle: BOOL,
  287. dwOptions: DWORD,
  288. ) -> BOOL ---
  289. ReadFile :: proc(
  290. hFile: HANDLE,
  291. lpBuffer: LPVOID,
  292. nNumberOfBytesToRead: DWORD,
  293. lpNumberOfBytesRead: LPDWORD,
  294. lpOverlapped: LPOVERLAPPED,
  295. ) -> BOOL ---
  296. WriteFile :: proc(
  297. hFile: HANDLE,
  298. lpBuffer: LPVOID,
  299. nNumberOfBytesToWrite: DWORD,
  300. lpNumberOfBytesWritten: LPDWORD,
  301. lpOverlapped: LPOVERLAPPED,
  302. ) -> BOOL ---
  303. CloseHandle :: proc(hObject: HANDLE) -> BOOL ---
  304. MoveFileExW :: proc(lpExistingFileName: LPCWSTR, lpNewFileName: LPCWSTR, dwFlags: DWORD) -> BOOL ---
  305. SetFilePointerEx :: proc(
  306. hFile: HANDLE,
  307. liDistanceToMove: LARGE_INTEGER,
  308. lpNewFilePointer: PLARGE_INTEGER,
  309. dwMoveMethod: DWORD,
  310. ) -> BOOL ---
  311. FlushFileBuffers :: proc(hFile: HANDLE) -> BOOL ---
  312. CreateFileW :: proc(
  313. lpFileName: LPCWSTR,
  314. dwDesiredAccess: DWORD,
  315. dwShareMode: DWORD,
  316. lpSecurityAttributes: LPSECURITY_ATTRIBUTES,
  317. dwCreationDisposition: DWORD,
  318. dwFlagsAndAttributes: DWORD,
  319. hTemplateFile: HANDLE,
  320. ) -> HANDLE ---
  321. GetFileTime :: proc(
  322. hFile: HANDLE,
  323. lpCreationTime: LPFILETIME,
  324. lpLastAccessTime: LPFILETIME,
  325. lpLastWriteTime: LPFILETIME,
  326. ) -> BOOL ---
  327. CompareFileTime :: proc(lpFileTime1: LPFILETIME, lpFileTime2: LPFILETIME) -> LONG ---
  328. FindFirstFileW :: proc(fileName: LPCWSTR, findFileData: LPWIN32_FIND_DATAW) -> HANDLE ---
  329. FindNextFileW :: proc(findFile: HANDLE, findFileData: LPWIN32_FIND_DATAW) -> BOOL ---
  330. FindClose :: proc(findFile: HANDLE) -> BOOL ---
  331. GetModuleHandleW :: proc(lpModuleName: LPCWSTR) -> HMODULE ---
  332. GetModuleHandleA :: proc(lpModuleName: LPCSTR) -> HMODULE ---
  333. GetSystemTimeAsFileTime :: proc(lpSystemTimeAsFileTime: LPFILETIME) ---
  334. GetSystemTimePreciseAsFileTime :: proc(lpSystemTimeAsFileTime: LPFILETIME) ---
  335. FileTimeToSystemTime :: proc(lpFileTime: ^FILETIME, lpSystemTime: ^SYSTEMTIME) -> BOOL ---
  336. SystemTimeToTzSpecificLocalTime :: proc(
  337. lpTimeZoneInformation: ^TIME_ZONE_INFORMATION,
  338. lpUniversalTime: ^SYSTEMTIME,
  339. lpLocalTime: ^SYSTEMTIME,
  340. ) -> BOOL ---
  341. SystemTimeToFileTime :: proc(
  342. lpSystemTime: ^SYSTEMTIME,
  343. lpFileTime: LPFILETIME,
  344. ) -> BOOL ---
  345. CreateEventW :: proc(
  346. lpEventAttributes: LPSECURITY_ATTRIBUTES,
  347. bManualReset: BOOL,
  348. bInitialState: BOOL,
  349. lpName: LPCWSTR,
  350. ) -> HANDLE ---
  351. CreateEventExW :: proc(
  352. lpEventAttributes: LPSECURITY_ATTRIBUTES,
  353. lpName: LPCWSTR,
  354. dwFlags: DWORD,
  355. dwDesiredAccess: DWORD,
  356. ) -> HANDLE ---
  357. ResetEvent :: proc(hEvent: HANDLE) -> BOOL ---
  358. SetEvent :: proc(hEvent: HANDLE) -> BOOL ---
  359. WaitForMultipleObjects :: proc(
  360. nCount: DWORD,
  361. lpHandles: ^HANDLE,
  362. bWaitAll: BOOL,
  363. dwMilliseconds: DWORD,
  364. ) -> DWORD ---
  365. WaitForMultipleObjectsEx :: proc(
  366. nCount: DWORD,
  367. lpHandles: ^HANDLE,
  368. bWaitAll: BOOL,
  369. dwMilliseconds: DWORD,
  370. bAlterable: BOOL,
  371. ) -> DWORD ---
  372. CreateNamedPipeW :: proc(
  373. lpName: LPCWSTR,
  374. dwOpenMode: DWORD,
  375. dwPipeMode: DWORD,
  376. nMaxInstances: DWORD,
  377. nOutBufferSize: DWORD,
  378. nInBufferSize: DWORD,
  379. nDefaultTimeOut: DWORD,
  380. lpSecurityAttributes: LPSECURITY_ATTRIBUTES,
  381. ) -> HANDLE ---
  382. PeekNamedPipe :: proc(
  383. hNamedPipe: HANDLE,
  384. lpBuffer: rawptr,
  385. nBufferSize: u32,
  386. lpBytesRead: ^u32,
  387. lpTotalBytesAvail: ^u32,
  388. lpBytesLeftThisMessage: ^u32,
  389. ) -> BOOL ---
  390. CancelIo :: proc(handle: HANDLE) -> BOOL ---
  391. GetOverlappedResult :: proc(
  392. hFile: HANDLE,
  393. lpOverlapped: LPOVERLAPPED,
  394. lpNumberOfBytesTransferred: LPDWORD,
  395. bWait: BOOL,
  396. ) -> BOOL ---
  397. GetProcessHeap :: proc() -> HANDLE ---
  398. HeapAlloc :: proc(hHeap: HANDLE, dwFlags: DWORD, dwBytes: SIZE_T) -> LPVOID ---
  399. HeapReAlloc :: proc(hHeap: HANDLE, dwFlags: DWORD, lpMem: LPVOID, dwBytes: SIZE_T) -> LPVOID ---
  400. HeapFree :: proc(hHeap: HANDLE, dwFlags: DWORD, lpMem: LPVOID) -> BOOL ---
  401. LocalAlloc :: proc(flags: UINT, bytes: SIZE_T) -> LPVOID ---
  402. LocalReAlloc :: proc(mem: LPVOID, bytes: SIZE_T, flags: UINT) -> LPVOID ---
  403. LocalFree :: proc(mem: LPVOID) -> LPVOID ---
  404. GlobalAlloc :: proc(flags: UINT, bytes: SIZE_T) -> LPVOID ---
  405. GlobalReAlloc :: proc(mem: LPVOID, bytes: SIZE_T, flags: UINT) -> LPVOID ---
  406. GlobalFree :: proc(mem: LPVOID) -> LPVOID ---
  407. GlobalLock :: proc(hMem: HGLOBAL) -> LPVOID ---
  408. GlobalUnlock :: proc(hMem: HGLOBAL) -> BOOL ---
  409. ReadDirectoryChangesW :: proc(
  410. hDirectory: HANDLE,
  411. lpBuffer: LPVOID,
  412. nBufferLength: DWORD,
  413. bWatchSubtree: BOOL,
  414. dwNotifyFilter: DWORD,
  415. lpBytesReturned: LPDWORD,
  416. lpOverlapped: LPOVERLAPPED,
  417. lpCompletionRoutine: LPOVERLAPPED_COMPLETION_ROUTINE,
  418. ) -> BOOL ---
  419. FindFirstChangeNotificationW :: proc(
  420. lpPathName: LPWSTR,
  421. bWatchSubtree: BOOL,
  422. dwNotifyFilter: DWORD,
  423. ) -> HANDLE ---
  424. FindNextChangeNotification :: proc(hChangeHandle: HANDLE) -> BOOL ---
  425. FindCloseChangeNotification :: proc(hChangeHandle: HANDLE) -> BOOL ---
  426. InitializeSRWLock :: proc(SRWLock: ^SRWLOCK) ---
  427. AcquireSRWLockExclusive :: proc(SRWLock: ^SRWLOCK) ---
  428. TryAcquireSRWLockExclusive :: proc(SRWLock: ^SRWLOCK) -> BOOLEAN ---
  429. ReleaseSRWLockExclusive :: proc(SRWLock: ^SRWLOCK) ---
  430. AcquireSRWLockShared :: proc(SRWLock: ^SRWLOCK) ---
  431. TryAcquireSRWLockShared :: proc(SRWLock: ^SRWLOCK) -> BOOLEAN ---
  432. ReleaseSRWLockShared :: proc(SRWLock: ^SRWLOCK) ---
  433. InitializeConditionVariable :: proc(ConditionVariable: ^CONDITION_VARIABLE) ---
  434. WakeConditionVariable :: proc(ConditionVariable: ^CONDITION_VARIABLE) ---
  435. WakeAllConditionVariable :: proc(ConditionVariable: ^CONDITION_VARIABLE) ---
  436. SleepConditionVariableCS :: proc(ConditionVariable: ^CONDITION_VARIABLE, CriticalSection: ^CRITICAL_SECTION, dwMilliseconds: DWORD) -> BOOL ---
  437. SleepConditionVariableSRW :: proc(ConditionVariable: ^CONDITION_VARIABLE, SRWLock: ^SRWLOCK, dwMilliseconds: DWORD, Flags: LONG) -> BOOL ---
  438. GetFileType :: proc(file_handle: HANDLE) -> DWORD ---
  439. SetFilePointer :: proc(file_handle: HANDLE, distance_to_move: LONG, distance_to_move_high: ^LONG, move_method: DWORD) -> DWORD ---
  440. GetFileSizeEx :: proc(file_handle: HANDLE, file_size: ^LARGE_INTEGER) -> BOOL ---
  441. GetFileAttributesW :: proc(lpFileName: LPCWSTR) -> DWORD ---
  442. GetFileAttributesExW :: proc(lpFileName: LPCWSTR, fInfoLevelId: GET_FILEEX_INFO_LEVELS, lpFileInformation: LPVOID) -> BOOL ---
  443. GetSystemInfo :: proc(system_info: ^SYSTEM_INFO) ---
  444. GetVersionExW :: proc(osvi: ^OSVERSIONINFOEXW) ---
  445. GetSystemDirectoryW :: proc(lpBuffer: LPWSTR, uSize: UINT) -> UINT ---
  446. GetWindowsDirectoryW :: proc(lpBuffer: LPWSTR, uSize: UINT) -> UINT ---
  447. GetSystemDefaultLangID :: proc() -> LANGID ---
  448. GetSystemDefaultLCID :: proc() -> LCID ---
  449. GetSystemDefaultLocaleName :: proc(lpLocaleName: LPWSTR, cchLocaleName: INT) -> INT ---
  450. LCIDToLocaleName :: proc(Locale: LCID, lpName: LPWSTR, cchName: INT, dwFlags: DWORD) -> INT ---
  451. LocaleNameToLCID :: proc(lpName: LPCWSTR, dwFlags: DWORD) -> LCID ---
  452. SetDllDirectoryW :: proc(lpPathName: LPCWSTR) -> BOOL ---
  453. AddDllDirectory :: proc(NewDirectory: PCWSTR) -> rawptr ---
  454. RemoveDllDirectory :: proc(Cookie: rawptr) -> BOOL ---
  455. LoadLibraryW :: proc(c_str: LPCWSTR) -> HMODULE ---
  456. LoadLibraryExW :: proc(c_str: LPCWSTR, hFile: HANDLE, dwFlags: LoadLibraryEx_Flags) -> HMODULE ---
  457. FreeLibrary :: proc(h: HMODULE) -> BOOL ---
  458. GetProcAddress :: proc(h: HMODULE, c_str: LPCSTR) -> rawptr ---
  459. LoadResource :: proc(hModule: HMODULE, hResInfo: HRSRC) -> HGLOBAL ---
  460. FreeResource :: proc(hResData: HGLOBAL) -> BOOL ---
  461. LockResource :: proc(hResData: HGLOBAL) -> LPVOID ---
  462. SizeofResource :: proc(hModule: HMODULE, hResInfo: HRSRC) -> DWORD ---
  463. FindResourceW :: proc(hModule: HMODULE, lpName: LPCWSTR, lpType: LPCWSTR) -> HRSRC ---
  464. FindResourceExW :: proc(hModule: HMODULE, lpType: LPCWSTR, lpName: LPCWSTR, wLanguage: LANGID) -> HRSRC ---
  465. EnumResourceNamesW :: proc(hModule: HMODULE, lpType: LPCWSTR, lpEnumFunc: ENUMRESNAMEPROCW, lParam: LONG_PTR) -> BOOL ---
  466. EnumResourceNamesExW :: proc(hModule: HMODULE, lpType: LPCWSTR, lpEnumFunc: ENUMRESNAMEPROCW, lParam: LONG_PTR, dwFlags: DWORD, LangId: LANGID) -> BOOL ---
  467. EnumResourceTypesExW :: proc(hModule: HMODULE, lpEnumFunc: ENUMRESTYPEPROCW, lParam: LONG_PTR, dwFlags: DWORD, LangId: LANGID) -> BOOL ---
  468. EnumResourceLanguagesExW :: proc(hModule: HMODULE, lpType: LPCWSTR, lpName: LPCWSTR, lpEnumFunc: ENUMRESLANGPROCW, lParam: LONG_PTR, dwFlags: DWORD, LangId: LANGID) -> BOOL ---
  469. LookupIconIdFromDirectory :: proc(presbits: PBYTE, fIcon: BOOL) -> INT ---
  470. LookupIconIdFromDirectoryEx :: proc(presbits: PBYTE, fIcon: BOOL, cxDesired: INT, cyDesired: INT, Flags: UINT) -> INT ---
  471. CreateIconFromResourceEx :: proc(presbits: PBYTE, dwResSize: DWORD, fIcon: BOOL, dwVer: DWORD, cxDesired: INT, cyDesired: INT, Flags: UINT) -> HICON ---
  472. GetFullPathNameW :: proc(filename: LPCWSTR, buffer_length: DWORD, buffer: LPCWSTR, file_part: ^LPCWSTR) -> DWORD ---
  473. GetLongPathNameW :: proc(short, long: LPCWSTR, len: DWORD) -> DWORD ---
  474. GetShortPathNameW :: proc(long, short: LPCWSTR, len: DWORD) -> DWORD ---
  475. GetFinalPathNameByHandleW :: proc(hFile: HANDLE, lpszFilePath: LPCWSTR, cchFilePath: DWORD, dwFlags: DWORD) -> DWORD ---
  476. SetEndOfFile :: proc(hFile: HANDLE) -> BOOL ---
  477. CreatePipe :: proc(hReadPipe, hWritePipe: ^HANDLE, lpPipeAttributes: LPSECURITY_ATTRIBUTES, nSize: DWORD) -> BOOL ---
  478. ConnectNamedPipe :: proc(hNamedPipe: HANDLE, lpOverlapped: LPOVERLAPPED) -> BOOL ---
  479. DisconnectNamedPipe :: proc(hNamedPipe: HANDLE) -> BOOL ---
  480. WaitNamedPipeW :: proc(lpNamedPipeName: LPCWSTR, nTimeOut: DWORD) -> BOOL ---
  481. AllocConsole :: proc() -> BOOL ---
  482. AttachConsole :: proc(dwProcessId: DWORD) -> BOOL ---
  483. SetConsoleCtrlHandler :: proc(HandlerRoutine: PHANDLER_ROUTINE, Add: BOOL) -> BOOL ---
  484. GenerateConsoleCtrlEvent :: proc(dwCtrlEvent: DWORD, dwProcessGroupId: DWORD) -> BOOL ---
  485. FreeConsole :: proc() -> BOOL ---
  486. GetConsoleWindow :: proc() -> HWND ---
  487. GetConsoleScreenBufferInfo :: proc(hConsoleOutput: HANDLE, lpConsoleScreenBufferInfo: PCONSOLE_SCREEN_BUFFER_INFO) -> BOOL ---
  488. SetConsoleScreenBufferSize :: proc(hConsoleOutput: HANDLE, dwSize: COORD) -> BOOL ---
  489. SetConsoleWindowInfo :: proc(hConsoleOutput: HANDLE, bAbsolute: BOOL, lpConsoleWindow: ^SMALL_RECT) -> BOOL ---
  490. GetConsoleCursorInfo :: proc(hConsoleOutput: HANDLE, lpConsoleCursorInfo: PCONSOLE_CURSOR_INFO) -> BOOL ---
  491. SetConsoleCursorInfo :: proc(hConsoleOutput: HANDLE, lpConsoleCursorInfo: PCONSOLE_CURSOR_INFO) -> BOOL ---
  492. GetDiskFreeSpaceExW :: proc(
  493. lpDirectoryName: LPCWSTR,
  494. lpFreeBytesAvailableToCaller: PULARGE_INTEGER,
  495. lpTotalNumberOfBytes: PULARGE_INTEGER,
  496. lpTotalNumberOfFreeBytes: PULARGE_INTEGER,
  497. ) -> BOOL ---
  498. GetLogicalProcessorInformation :: proc(buffer: ^SYSTEM_LOGICAL_PROCESSOR_INFORMATION, returnedLength: PDWORD) -> BOOL ---
  499. // [MS-Docs](https://learn.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-setfilecompletionnotificationmodes)
  500. SetFileCompletionNotificationModes :: proc(FileHandle: HANDLE, Flags: u8) -> BOOL ---
  501. // [MS-Docs](https://learn.microsoft.com/en-us/windows/win32/api/ioapiset/nf-ioapiset-createiocompletionport)
  502. CreateIoCompletionPort :: proc(FileHandle: HANDLE, ExistingCompletionPort: HANDLE, CompletionKey: ULONG_PTR, NumberOfConcurrentThreads: DWORD) -> HANDLE ---
  503. //[MS-Docs](https://learn.microsoft.com/en-us/windows/win32/api/ioapiset/nf-ioapiset-getqueuedcompletionstatus)
  504. GetQueuedCompletionStatus :: proc(CompletionPort: HANDLE, lpNumberOfBytesTransferred: ^DWORD, lpCompletionKey: PULONG_PTR, lpOverlapped: ^^OVERLAPPED, dwMilliseconds: DWORD) -> BOOL ---
  505. // [MS-Docs](https://learn.microsoft.com/en-us/windows/win32/api/ioapiset/nf-ioapiset-getqueuedcompletionstatusex)
  506. GetQueuedCompletionStatusEx :: proc(CompletionPort: HANDLE, lpCompletionPortEntries: ^OVERLAPPED_ENTRY, ulCount: c_ulong, ulNumEntriesRemoved: ^c_ulong, dwMilliseconds: DWORD, fAlertable: BOOL) -> BOOL ---
  507. // [MS-Docs](https://learn.microsoft.com/en-us/windows/win32/api/ioapiset/nf-ioapiset-postqueuedcompletionstatus)
  508. PostQueuedCompletionStatus :: proc(CompletionPort: HANDLE, dwNumberOfBytesTransferred: DWORD, dwCompletionKey: c_ulong, lpOverlapped: ^OVERLAPPED) -> BOOL ---
  509. // [MS-Docs](https://learn.microsoft.com/en-us/windows/win32/api/handleapi/nf-handleapi-gethandleinformation)
  510. GetHandleInformation :: proc(hObject: HANDLE, lpdwFlags: ^DWORD) -> BOOL ---
  511. RtlCaptureStackBackTrace :: proc(FramesToSkip: ULONG, FramesToCapture: ULONG, BackTrace: [^]PVOID, BackTraceHash: PULONG) -> USHORT ---
  512. GetSystemPowerStatus :: proc(lpSystemPowerStatus: ^SYSTEM_POWER_STATUS) -> BOOL ---
  513. }
  514. DEBUG_PROCESS :: 0x00000001
  515. DEBUG_ONLY_THIS_PROCESS :: 0x00000002
  516. CREATE_SUSPENDED :: 0x00000004
  517. DETACHED_PROCESS :: 0x00000008
  518. CREATE_NEW_CONSOLE :: 0x00000010
  519. NORMAL_PRIORITY_CLASS :: 0x00000020
  520. IDLE_PRIORITY_CLASS :: 0x00000040
  521. HIGH_PRIORITY_CLASS :: 0x00000080
  522. REALTIME_PRIORITY_CLASS :: 0x00000100
  523. CREATE_NEW_PROCESS_GROUP :: 0x00000200
  524. CREATE_UNICODE_ENVIRONMENT :: 0x00000400
  525. CREATE_SEPARATE_WOW_VDM :: 0x00000800
  526. CREATE_SHARED_WOW_VDM :: 0x00001000
  527. CREATE_FORCEDOS :: 0x00002000
  528. BELOW_NORMAL_PRIORITY_CLASS :: 0x00004000
  529. ABOVE_NORMAL_PRIORITY_CLASS :: 0x00008000
  530. INHERIT_PARENT_AFFINITY :: 0x00010000
  531. INHERIT_CALLER_PRIORITY :: 0x00020000 // Deprecated
  532. CREATE_PROTECTED_PROCESS :: 0x00040000
  533. EXTENDED_STARTUPINFO_PRESENT :: 0x00080000
  534. PROCESS_MODE_BACKGROUND_BEGIN :: 0x00100000
  535. PROCESS_MODE_BACKGROUND_END :: 0x00200000
  536. CREATE_SECURE_PROCESS :: 0x00400000
  537. CREATE_BREAKAWAY_FROM_JOB :: 0x01000000
  538. CREATE_PRESERVE_CODE_AUTHZ_LEVEL :: 0x02000000
  539. CREATE_DEFAULT_ERROR_MODE :: 0x04000000
  540. CREATE_NO_WINDOW :: 0x08000000
  541. PROFILE_USER :: 0x10000000
  542. PROFILE_KERNEL :: 0x20000000
  543. PROFILE_SERVER :: 0x40000000
  544. CREATE_IGNORE_SYSTEM_DEFAULT :: 0x80000000
  545. THREAD_BASE_PRIORITY_LOWRT :: 15 // value that gets a thread to LowRealtime-1
  546. THREAD_BASE_PRIORITY_MAX :: 2 // maximum thread base priority boost
  547. THREAD_BASE_PRIORITY_MIN :: (-2) // minimum thread base priority boost
  548. THREAD_BASE_PRIORITY_IDLE :: (-15) // value that gets a thread to idle
  549. THREAD_PRIORITY_LOWEST :: THREAD_BASE_PRIORITY_MIN
  550. THREAD_PRIORITY_BELOW_NORMAL :: (THREAD_PRIORITY_LOWEST+1)
  551. THREAD_PRIORITY_NORMAL :: 0
  552. THREAD_PRIORITY_HIGHEST :: THREAD_BASE_PRIORITY_MAX
  553. THREAD_PRIORITY_ABOVE_NORMAL :: (THREAD_PRIORITY_HIGHEST-1)
  554. THREAD_PRIORITY_ERROR_RETURN :: (MAXLONG)
  555. THREAD_PRIORITY_TIME_CRITICAL :: THREAD_BASE_PRIORITY_LOWRT
  556. THREAD_PRIORITY_IDLE :: THREAD_BASE_PRIORITY_IDLE
  557. THREAD_MODE_BACKGROUND_BEGIN :: 0x00010000
  558. THREAD_MODE_BACKGROUND_END :: 0x00020000
  559. PROCESS_ALL_ACCESS :: 0x000F0000 | SYNCHRONIZE | 0xFFFF
  560. PROCESS_CREATE_PROCESS :: 0x0080
  561. PROCESS_CREATE_THREAD :: 0x0002
  562. PROCESS_DUP_HANDLE :: 0x0040
  563. PROCESS_QUERY_INFORMATION :: 0x0400
  564. PROCESS_QUERY_LIMITED_INFORMATION :: 0x1000
  565. PROCESS_SET_INFORMATION :: 0x0200
  566. PROCESS_SET_QUOTA :: 0x0100
  567. PROCESS_SUSPEND_RESUME :: 0x0800
  568. PROCESS_TERMINATE :: 0x0001
  569. PROCESS_VM_OPERATION :: 0x0008
  570. PROCESS_VM_READ :: 0x0010
  571. PROCESS_VM_WRITE :: 0x0020
  572. THREAD_ALL_ACCESS :: \
  573. THREAD_DIRECT_IMPERSONATION |
  574. THREAD_GET_CONTEXT |
  575. THREAD_IMPERSONATE |
  576. THREAD_QUERY_INFORMATION |
  577. THREAD_QUERY_LIMITED_INFORMATION |
  578. THREAD_SET_CONTEXT |
  579. THREAD_SET_INFORMATION |
  580. THREAD_SET_LIMITED_INFORMATION |
  581. THREAD_SET_THREAD_TOKEN |
  582. THREAD_SUSPEND_RESUME |
  583. THREAD_TERMINATE |
  584. SYNCHRONIZE
  585. THREAD_DIRECT_IMPERSONATION :: 0x0200
  586. THREAD_GET_CONTEXT :: 0x0008
  587. THREAD_IMPERSONATE :: 0x0100
  588. THREAD_QUERY_INFORMATION :: 0x0040
  589. THREAD_QUERY_LIMITED_INFORMATION :: 0x0800
  590. THREAD_SET_CONTEXT :: 0x0010
  591. THREAD_SET_INFORMATION :: 0x0020
  592. THREAD_SET_LIMITED_INFORMATION :: 0x0400
  593. THREAD_SET_THREAD_TOKEN :: 0x0080
  594. THREAD_SUSPEND_RESUME :: 0x0002
  595. THREAD_TERMINATE :: 0x0001
  596. COPY_FILE_FAIL_IF_EXISTS :: 0x00000001
  597. COPY_FILE_RESTARTABLE :: 0x00000002
  598. COPY_FILE_OPEN_SOURCE_FOR_WRITE :: 0x00000004
  599. COPY_FILE_ALLOW_DECRYPTED_DESTINATION :: 0x00000008
  600. COPY_FILE_COPY_SYMLINK :: 0x00000800
  601. COPY_FILE_NO_BUFFERING :: 0x00001000
  602. COPY_FILE_REQUEST_SECURITY_PRIVILEGES :: 0x00002000
  603. COPY_FILE_RESUME_FROM_PAUSE :: 0x00004000
  604. COPY_FILE_NO_OFFLOAD :: 0x00040000
  605. COPY_FILE_IGNORE_EDP_BLOCK :: 0x00400000
  606. COPY_FILE_IGNORE_SOURCE_ENCRYPTION :: 0x00800000
  607. COPY_FILE_DONT_REQUEST_DEST_WRITE_DAC :: 0x02000000
  608. COPY_FILE_REQUEST_COMPRESSED_TRAFFIC :: 0x10000000
  609. COPY_FILE_OPEN_AND_COPY_REPARSE_POINT :: 0x00200000
  610. COPY_FILE_DIRECTORY :: 0x00000080
  611. COPY_FILE_SKIP_ALTERNATE_STREAMS :: 0x00008000
  612. COPY_FILE_DISABLE_PRE_ALLOCATION :: 0x04000000
  613. COPY_FILE_ENABLE_LOW_FREE_SPACE_MODE :: 0x08000000
  614. SECTION_QUERY :: DWORD(0x0001)
  615. SECTION_MAP_WRITE :: DWORD(0x0002)
  616. SECTION_MAP_READ :: DWORD(0x0004)
  617. SECTION_MAP_EXECUTE :: DWORD(0x0008)
  618. SECTION_EXTEND_SIZE :: DWORD(0x0010)
  619. SECTION_ALL_ACCESS :: STANDARD_RIGHTS_REQUIRED | SECTION_QUERY | SECTION_MAP_WRITE | SECTION_MAP_READ | SECTION_MAP_EXECUTE | SECTION_EXTEND_SIZE
  620. SECTION_MAP_EXECUTE_EXPLICIT :: DWORD(0x0020)
  621. FILE_MAP_WRITE :: SECTION_MAP_WRITE
  622. FILE_MAP_READ :: SECTION_MAP_READ
  623. FILE_MAP_ALL_ACCESS :: SECTION_ALL_ACCESS
  624. FILE_MAP_EXECUTE :: SECTION_MAP_EXECUTE_EXPLICIT
  625. FILE_MAP_COPY :: DWORD(0x00000001)
  626. FILE_MAP_RESERVE :: DWORD(0x80000000)
  627. FILE_MAP_TARGETS_INVALID :: DWORD(0x40000000)
  628. FILE_MAP_LARGE_PAGES :: DWORD(0x20000000)
  629. // Flags for `SetFileCompletionNotificationModes`.
  630. FILE_SKIP_COMPLETION_PORT_ON_SUCCESS :: 0x1
  631. FILE_SKIP_SET_EVENT_ON_HANDLE :: 0x2
  632. PAGE_NOACCESS :: 0x01
  633. PAGE_READONLY :: 0x02
  634. PAGE_READWRITE :: 0x04
  635. PAGE_WRITECOPY :: 0x08
  636. PAGE_EXECUTE :: 0x10
  637. PAGE_EXECUTE_READ :: 0x20
  638. PAGE_EXECUTE_READWRITE :: 0x40
  639. PAGE_EXECUTE_WRITECOPY :: 0x80
  640. PAGE_GUARD :: 0x100
  641. PAGE_NOCACHE :: 0x200
  642. PAGE_WRITECOMBINE :: 0x400
  643. MEMORY_BASIC_INFORMATION :: struct {
  644. BaseAddress: PVOID,
  645. AllocationBase: PVOID,
  646. AllocationProtect: DWORD,
  647. PartitionId: WORD,
  648. RegionSize: SIZE_T,
  649. State: DWORD,
  650. Protect: DWORD,
  651. Type: DWORD,
  652. }
  653. PMEMORY_BASIC_INFORMATION :: ^MEMORY_BASIC_INFORMATION
  654. LPMEMORY_BASIC_INFORMATION :: ^MEMORY_BASIC_INFORMATION
  655. MEM_COMMIT :: 0x1000
  656. MEM_RESERVE :: 0x2000
  657. MEM_DECOMMIT :: 0x4000
  658. MEM_RELEASE :: 0x8000
  659. MEM_FREE :: 0x10000
  660. MEM_PRIVATE :: 0x20000
  661. MEM_MAPPED :: 0x40000
  662. MEM_RESET :: 0x80000
  663. MEM_TOP_DOWN :: 0x100000
  664. MEM_LARGE_PAGES :: 0x20000000
  665. MEM_4MB_PAGES :: 0x80000000
  666. @(default_calling_convention="system")
  667. foreign kernel32 {
  668. VirtualAlloc :: proc(
  669. lpAddress: LPVOID,
  670. dwSize: SIZE_T,
  671. flAllocationType: DWORD,
  672. flProtect: DWORD,
  673. ) -> LPVOID ---
  674. VirtualProtect :: proc(
  675. lpAddress: LPVOID,
  676. dwSize: SIZE_T,
  677. flNewProtect: DWORD,
  678. lpflOldProtect: PDWORD,
  679. ) -> BOOL ---
  680. VirtualFree :: proc(
  681. lpAddress: LPVOID,
  682. dwSize: SIZE_T,
  683. dwFreeType: DWORD,
  684. ) -> BOOL ---
  685. VirtualQuery :: proc(
  686. lpAddress: LPCVOID,
  687. lpBuffer: PMEMORY_BASIC_INFORMATION,
  688. dwLength: SIZE_T,
  689. ) -> SIZE_T ---
  690. VirtualAllocEx :: proc(
  691. hProcess: HANDLE,
  692. lpAddress: LPVOID,
  693. dwSize: SIZE_T,
  694. flAllocationType: DWORD,
  695. flProtect: DWORD,
  696. ) -> LPVOID ---
  697. VirtualFreeEx :: proc(
  698. hProcess: HANDLE,
  699. lpAddress: LPVOID,
  700. dwSize: SIZE_T,
  701. dwFreeType: DWORD,
  702. ) -> BOOL ---
  703. VirtualProtectEx :: proc(
  704. hProcess: HANDLE,
  705. lpAddress: LPVOID,
  706. dwSize: SIZE_T,
  707. flNewProtect: DWORD,
  708. lpflOldProtect: PDWORD,
  709. ) -> BOOL ---
  710. VirtualQueryEx :: proc(
  711. hProcess: HANDLE,
  712. lpAddress: LPCVOID,
  713. lpBuffer: PMEMORY_BASIC_INFORMATION,
  714. dwLength: SIZE_T,
  715. ) -> SIZE_T ---
  716. ReadProcessMemory :: proc(
  717. hProcess: HANDLE,
  718. lpBaseAddress: LPCVOID,
  719. lpBuffer: LPVOID,
  720. nSize: SIZE_T,
  721. lpNumberOfBytesRead: ^SIZE_T,
  722. ) -> BOOL ---
  723. WriteProcessMemory :: proc(
  724. hProcess: HANDLE,
  725. lpBaseAddress: LPVOID,
  726. lpBuffer: LPCVOID,
  727. nSize: SIZE_T,
  728. lpNumberOfBytesWritten: ^SIZE_T,
  729. ) -> BOOL ---
  730. CreateFileMappingW :: proc(
  731. hFile: HANDLE,
  732. lpFileMappingAttributes: LPSECURITY_ATTRIBUTES,
  733. flProtect: DWORD,
  734. dwMaximumSizeHigh: DWORD,
  735. dwMaximumSizeLow: DWORD,
  736. lpName: LPCWSTR,
  737. ) -> HANDLE ---
  738. OpenFileMappingW :: proc(
  739. dwDesiredAccess: DWORD,
  740. bInheritHandle: BOOL,
  741. lpName: LPCWSTR,
  742. ) -> HANDLE ---
  743. MapViewOfFile :: proc(
  744. hFileMappingObject: HANDLE,
  745. dwDesiredAccess: DWORD,
  746. dwFileOffsetHigh: DWORD,
  747. dwFileOffsetLow: DWORD,
  748. dwNumberOfBytesToMap: SIZE_T,
  749. ) -> LPVOID ---
  750. MapViewOfFileEx :: proc(
  751. hFileMappingObject: HANDLE,
  752. dwDesiredAccess: DWORD,
  753. dwFileOffsetHigh: DWORD,
  754. dwFileOffsetLow: DWORD,
  755. dwNumberOfBytesToMap: SIZE_T,
  756. lpBaseAddress: LPVOID,
  757. ) -> LPVOID ---
  758. FlushViewOfFile :: proc(
  759. lpBaseAddress: LPCVOID,
  760. dwNumberOfBytesToFlush: SIZE_T,
  761. ) -> BOOL ---
  762. UnmapViewOfFile :: proc(
  763. lpBaseAddress: LPCVOID,
  764. ) -> BOOL ---
  765. GetLargePageMinimum :: proc() -> SIZE_T ---
  766. GetProcessWorkingSetSizeEx :: proc(
  767. hProcess: HANDLE,
  768. lpMinimumWorkingSetSize: PSIZE_T,
  769. lpMaximumWorkingSetSize: PSIZE_T,
  770. Flags: PDWORD,
  771. ) -> BOOL ---
  772. SetProcessWorkingSetSizeEx :: proc(
  773. hProcess: HANDLE,
  774. dwMinimumWorkingSetSize: SIZE_T,
  775. dwMaximumWorkingSetSize: SIZE_T,
  776. Flags: DWORD,
  777. ) -> BOOL ---
  778. VirtualLock :: proc(
  779. lpAddress: LPVOID,
  780. dwSize: SIZE_T,
  781. ) -> BOOL ---
  782. VirtualUnlock :: proc(
  783. lpAddress: LPVOID,
  784. dwSize: SIZE_T,
  785. ) -> BOOL ---
  786. GetWriteWatch :: proc(
  787. dwFlags: DWORD,
  788. lpBaseAddress: PVOID,
  789. dwRegionSize: SIZE_T,
  790. lpAddresses: ^PVOID,
  791. lpdwCount: ^ULONG_PTR,
  792. lpdwGranularity: LPDWORD,
  793. ) -> UINT ---
  794. ResetWriteWatch :: proc(
  795. lpBaseAddress: LPVOID,
  796. dwRegionSize: SIZE_T,
  797. ) -> UINT ---
  798. }
  799. MEMORY_RESOURCE_NOTIFICATION_TYPE :: enum c_int {
  800. LowMemoryResourceNotification,
  801. HighMemoryResourceNotification,
  802. }
  803. LowMemoryResourceNotification :: MEMORY_RESOURCE_NOTIFICATION_TYPE.LowMemoryResourceNotification
  804. HighMemoryResourceNotification :: MEMORY_RESOURCE_NOTIFICATION_TYPE.HighMemoryResourceNotification
  805. @(default_calling_convention="system")
  806. foreign kernel32 {
  807. CreateMemoryResourceNotification :: proc(
  808. NotificationType: MEMORY_RESOURCE_NOTIFICATION_TYPE,
  809. ) -> HANDLE ---
  810. QueryMemoryResourceNotification :: proc(
  811. ResourceNotificationHandle: HANDLE,
  812. ResourceState: PBOOL,
  813. ) -> BOOL ---
  814. }
  815. FILE_CACHE_MAX_HARD_ENABLE :: DWORD(0x00000001)
  816. FILE_CACHE_MAX_HARD_DISABLE :: DWORD(0x00000002)
  817. FILE_CACHE_MIN_HARD_ENABLE :: DWORD(0x00000004)
  818. FILE_CACHE_MIN_HARD_DISABLE :: DWORD(0x00000008)
  819. @(default_calling_convention="system")
  820. foreign kernel32 {
  821. GetSystemFileCacheSize :: proc(
  822. lpMinimumFileCacheSize: PSIZE_T,
  823. lpMaximumFileCacheSize: PSIZE_T,
  824. lpFlags: PDWORD,
  825. ) -> BOOL ---
  826. SetSystemFileCacheSize :: proc(
  827. MinimumFileCacheSize: SIZE_T,
  828. MaximumFileCacheSize: SIZE_T,
  829. Flags: DWORD,
  830. ) -> BOOL ---
  831. CreateFileMappingNumaW :: proc(
  832. hFile: HANDLE,
  833. lpFileMappingAttributes: LPSECURITY_ATTRIBUTES,
  834. flProtect: DWORD,
  835. dwMaximumSizeHigh: DWORD,
  836. dwMaximumSizeLow: DWORD,
  837. lpName: LPCWSTR,
  838. nndPreferred: DWORD,
  839. ) -> HANDLE ---
  840. }
  841. WIN32_MEMORY_RANGE_ENTRY :: struct {
  842. VirtualAddress: PVOID,
  843. NumberOfBytes: SIZE_T,
  844. }
  845. PWIN32_MEMORY_RANGE_ENTRY :: ^WIN32_MEMORY_RANGE_ENTRY
  846. @(default_calling_convention="system")
  847. foreign kernel32 {
  848. PrefetchVirtualMemory :: proc(
  849. hProcess: HANDLE,
  850. NumberOfEntries: ULONG_PTR,
  851. VirtualAddresses: PWIN32_MEMORY_RANGE_ENTRY,
  852. Flags: ULONG,
  853. ) -> BOOL ---
  854. CreateFileMappingFromApp :: proc(
  855. hFile: HANDLE,
  856. SecurityAttributes: PSECURITY_ATTRIBUTES,
  857. PageProtection: ULONG,
  858. MaximumSize: ULONG64,
  859. Name: PCWSTR,
  860. ) -> HANDLE ---
  861. MapViewOfFileFromApp :: proc(
  862. hFileMappingObject: HANDLE,
  863. DesiredAccess: ULONG,
  864. FileOffset: ULONG64,
  865. NumberOfBytesToMap: SIZE_T,
  866. ) -> PVOID ---
  867. UnmapViewOfFileEx :: proc(
  868. BaseAddress: PVOID,
  869. UnmapFlags: ULONG,
  870. ) -> BOOL ---
  871. AllocateUserPhysicalPages :: proc(
  872. hProcess: HANDLE,
  873. NumberOfPages: PULONG_PTR,
  874. PageArray: PULONG_PTR,
  875. ) -> BOOL ---
  876. FreeUserPhysicalPages :: proc(
  877. hProcess: HANDLE,
  878. NumberOfPages: PULONG_PTR,
  879. PageArray: PULONG_PTR,
  880. ) -> BOOL ---
  881. MapUserPhysicalPages :: proc(
  882. VirtualAddress: PVOID,
  883. NumberOfPages: ULONG_PTR,
  884. PageArray: PULONG_PTR,
  885. ) -> BOOL ---
  886. AllocateUserPhysicalPagesNuma :: proc(
  887. hProcess: HANDLE,
  888. NumberOfPages: PULONG_PTR,
  889. PageArray: PULONG_PTR,
  890. nndPreferred: DWORD,
  891. ) -> BOOL ---
  892. VirtualAllocExNuma :: proc(
  893. hProcess: HANDLE,
  894. lpAddress: LPVOID,
  895. dwSize: SIZE_T,
  896. flAllocationType: DWORD,
  897. flProtect: DWORD,
  898. nndPreferred: DWORD,
  899. ) -> LPVOID ---
  900. }
  901. MEHC_PATROL_SCRUBBER_PRESENT :: ULONG(0x1)
  902. @(default_calling_convention="system")
  903. foreign kernel32 {
  904. GetMemoryErrorHandlingCapabilities :: proc(
  905. Capabilities: PULONG,
  906. ) -> BOOL ---
  907. }
  908. @(default_calling_convention="system")
  909. foreign kernel32 {
  910. GlobalMemoryStatusEx :: proc(
  911. lpBuffer: ^MEMORYSTATUSEX,
  912. ) -> BOOL ---
  913. }
  914. PBAD_MEMORY_CALLBACK_ROUTINE :: #type proc "system" ()
  915. @(default_calling_convention="system")
  916. foreign kernel32 {
  917. RegisterBadMemoryNotification :: proc(
  918. Callback: PBAD_MEMORY_CALLBACK_ROUTINE,
  919. ) -> PVOID ---
  920. UnregisterBadMemoryNotification :: proc(
  921. RegistrationHandle: PVOID,
  922. ) -> BOOL ---
  923. }
  924. OFFER_PRIORITY :: enum c_int {
  925. VmOfferPriorityVeryLow = 1,
  926. VmOfferPriorityLow,
  927. VmOfferPriorityBelowNormal,
  928. VmOfferPriorityNormal,
  929. }
  930. VmOfferPriorityVeryLow :: OFFER_PRIORITY.VmOfferPriorityVeryLow
  931. VmOfferPriorityLow :: OFFER_PRIORITY.VmOfferPriorityLow
  932. VmOfferPriorityBelowNormal :: OFFER_PRIORITY.VmOfferPriorityBelowNormal
  933. VmOfferPriorityNormal :: OFFER_PRIORITY.VmOfferPriorityNormal
  934. @(default_calling_convention="system")
  935. foreign kernel32 {
  936. OfferVirtualMemory :: proc(
  937. VirtualAddress: PVOID,
  938. Size: SIZE_T,
  939. Priority: OFFER_PRIORITY,
  940. ) -> DWORD ---
  941. ReclaimVirtualMemory :: proc(
  942. VirtualAddress: PVOID,
  943. Size: SIZE_T,
  944. ) -> DWORD ---
  945. DiscardVirtualMemory :: proc(
  946. VirtualAddress: PVOID,
  947. Size: SIZE_T,
  948. ) -> DWORD ---
  949. VirtualAllocFromApp :: proc(
  950. BaseAddress: PVOID,
  951. Size: SIZE_T,
  952. AllocationType: ULONG,
  953. Protection: ULONG,
  954. ) -> PVOID ---
  955. VirtualProtectFromApp :: proc(
  956. Address: PVOID,
  957. Size: SIZE_T,
  958. NewProtection: ULONG,
  959. OldProtection: PULONG,
  960. ) -> BOOL ---
  961. OpenFileMappingFromApp :: proc(
  962. DesiredAccess: ULONG,
  963. InheritHandle: BOOL,
  964. Name: PCWSTR,
  965. ) -> HANDLE ---
  966. }
  967. WIN32_MEMORY_INFORMATION_CLASS :: enum c_int {
  968. MemoryRegionInfo,
  969. }
  970. MemoryRegionInfo :: WIN32_MEMORY_INFORMATION_CLASS.MemoryRegionInfo
  971. WIN32_MEMORY_REGION_INFORMATION :: struct {
  972. AllocationBase: PVOID,
  973. AllocationProtect: ULONG,
  974. u: WIN32_MEMORY_REGION_INFORMATION_u,
  975. RegionSize: SIZE_T,
  976. CommitSize: SIZE_T,
  977. }
  978. WIN32_MEMORY_REGION_INFORMATION_u :: struct #raw_union {
  979. u: [1]u32,
  980. Flags: ULONG,
  981. s: WIN32_MEMORY_REGION_INFORMATION_u_s,
  982. }
  983. WIN32_MEMORY_REGION_INFORMATION_u_s :: struct {
  984. Bitfield: ULONG,
  985. }
  986. WIN32_MEMORY_REGION_INFORMATION_u_s_Bitfield :: distinct ULONG
  987. /*bit_field #align(align_of(ULONG)) {
  988. Private : 1-0,
  989. MappedDataFile : 2-1,
  990. MappedImage : 3-2,
  991. MappedPageFile : 4-3,
  992. MappedPhysical : 5-4,
  993. DirectMapped : 6-5,
  994. Reserved : 32-6,
  995. }*/
  996. @(default_calling_convention="system")
  997. foreign one_core {
  998. QueryVirtualMemoryInformation :: proc(
  999. Process: HANDLE,
  1000. VirtualAddress: PVOID,
  1001. MemoryInformationClass: WIN32_MEMORY_INFORMATION_CLASS,
  1002. MemoryInformation: PVOID,
  1003. MemoryInformationSize: SIZE_T,
  1004. ReturnSize: PSIZE_T,
  1005. ) -> BOOL ---
  1006. MapViewOfFileNuma2 :: proc(
  1007. FileMappingHandle: HANDLE,
  1008. ProcessHandle: HANDLE,
  1009. Offset: ULONG64,
  1010. BaseAddress: PVOID,
  1011. ViewSize: SIZE_T,
  1012. AllocationType: ULONG,
  1013. PageProtection: ULONG,
  1014. PreferredNode: ULONG,
  1015. ) -> PVOID ---
  1016. GetCommPorts :: proc(
  1017. lpPortNumbers: PULONG,
  1018. uPortNumbersCount: ULONG,
  1019. puPortNumbersFound: PULONG,
  1020. ) -> ULONG ---
  1021. }
  1022. NUMA_NO_PREFERRED_NODE :: 0xffffffff
  1023. MapViewOfFile2 :: #force_inline proc "system" (
  1024. FileMappingHandle: HANDLE,
  1025. ProcessHandle: HANDLE,
  1026. Offset: ULONG64,
  1027. BaseAddress: PVOID,
  1028. ViewSize: SIZE_T,
  1029. AllocationType: ULONG,
  1030. PageProtection: ULONG,
  1031. ) -> PVOID {
  1032. return MapViewOfFileNuma2(
  1033. FileMappingHandle,
  1034. ProcessHandle,
  1035. Offset,
  1036. BaseAddress,
  1037. ViewSize,
  1038. AllocationType,
  1039. PageProtection,
  1040. NUMA_NO_PREFERRED_NODE,
  1041. )
  1042. }
  1043. @(default_calling_convention="system")
  1044. foreign kernel32 {
  1045. UnmapViewOfFile2 :: proc(
  1046. ProcessHandle: HANDLE,
  1047. BaseAddress: PVOID,
  1048. UnmapFlags: ULONG,
  1049. ) -> BOOL ---
  1050. }
  1051. @(default_calling_convention="system")
  1052. foreign kernel32 {
  1053. GetProductInfo :: proc(
  1054. OSMajorVersion: DWORD,
  1055. OSMinorVersion: DWORD,
  1056. SpMajorVersion: DWORD,
  1057. SpMinorVersion: DWORD,
  1058. product_type: ^Windows_Product_Type,
  1059. ) -> BOOL ---
  1060. }
  1061. HandlerRoutine :: proc "system" (dwCtrlType: DWORD) -> BOOL
  1062. PHANDLER_ROUTINE :: HandlerRoutine
  1063. // NOTE(Jeroen, 2024-06-13): As Odin now supports bit_fields, we no longer need
  1064. // a helper procedure. `init_dcb_with_config` and `get_dcb_config` have been removed.
  1065. LPFIBER_START_ROUTINE :: #type proc "system" (lpFiberParameter: LPVOID)
  1066. @(default_calling_convention = "system")
  1067. foreign kernel32 {
  1068. CreateFiber :: proc(dwStackSize: SIZE_T, lpStartAddress: LPFIBER_START_ROUTINE, lpParameter: LPVOID) -> LPVOID ---
  1069. DeleteFiber :: proc(lpFiber: LPVOID) ---
  1070. ConvertThreadToFiber :: proc(lpParameter: LPVOID) -> LPVOID ---
  1071. SwitchToFiber :: proc(lpFiber: LPVOID) ---
  1072. }
  1073. LOGICAL_PROCESSOR_RELATIONSHIP :: enum c_int {
  1074. RelationProcessorCore,
  1075. RelationNumaNode,
  1076. RelationCache,
  1077. RelationProcessorPackage,
  1078. RelationGroup,
  1079. RelationProcessorDie,
  1080. RelationNumaNodeEx,
  1081. RelationProcessorModule,
  1082. RelationAll = 0xffff,
  1083. }
  1084. PROCESSOR_CACHE_TYPE :: enum c_int {
  1085. CacheUnified,
  1086. CacheInstruction,
  1087. CacheData,
  1088. CacheTrace,
  1089. }
  1090. CACHE_DESCRIPTOR :: struct {
  1091. Level: BYTE,
  1092. Associativity: BYTE,
  1093. LineSize: WORD,
  1094. Size: DWORD,
  1095. Type: PROCESSOR_CACHE_TYPE,
  1096. }
  1097. ProcessorCore :: struct {
  1098. Flags: BYTE,
  1099. }
  1100. NumaNode :: struct {
  1101. NodeNumber: DWORD,
  1102. }
  1103. DUMMYUNIONNAME_u :: struct #raw_union {
  1104. Core: ProcessorCore,
  1105. Node: NumaNode,
  1106. Cache: CACHE_DESCRIPTOR,
  1107. Reserved: [2]ULONGLONG,
  1108. }
  1109. SYSTEM_LOGICAL_PROCESSOR_INFORMATION :: struct {
  1110. ProcessorMask: ULONG_PTR,
  1111. Relationship: LOGICAL_PROCESSOR_RELATIONSHIP,
  1112. using DummyUnion: DUMMYUNIONNAME_u,
  1113. }
  1114. SYSTEM_POWER_STATUS :: struct {
  1115. ACLineStatus: AC_Line_Status,
  1116. BatteryFlag: Battery_Flags,
  1117. BatteryLifePercent: BYTE,
  1118. SystemStatusFlag: BYTE,
  1119. BatteryLifeTime: DWORD,
  1120. BatteryFullLifeTime: DWORD,
  1121. }
  1122. AC_Line_Status :: enum BYTE {
  1123. Offline = 0,
  1124. Online = 1,
  1125. Unknown = 255,
  1126. }
  1127. Battery_Flag :: enum BYTE {
  1128. High = 0,
  1129. Low = 1,
  1130. Critical = 2,
  1131. Charging = 3,
  1132. No_Battery = 7,
  1133. }
  1134. Battery_Flags :: bit_set[Battery_Flag; BYTE]
  1135. /* Global Memory Flags */
  1136. GMEM_FIXED :: 0x0000
  1137. GMEM_MOVEABLE :: 0x0002
  1138. GMEM_NOCOMPACT :: 0x0010
  1139. GMEM_NODISCARD :: 0x0020
  1140. GMEM_ZEROINIT :: 0x0040
  1141. GMEM_MODIFY :: 0x0080
  1142. GMEM_DISCARDABLE :: 0x0100
  1143. GMEM_NOT_BANKED :: 0x1000
  1144. GMEM_SHARE :: 0x2000
  1145. GMEM_DDESHARE :: 0x2000
  1146. GMEM_NOTIFY :: 0x4000
  1147. GMEM_LOWER :: GMEM_NOT_BANKED
  1148. GMEM_VALID_FLAGS :: 0x7F72
  1149. GMEM_INVALID_HANDLE :: 0x8000
  1150. GHND :: (GMEM_MOVEABLE | GMEM_ZEROINIT)
  1151. GPTR :: (GMEM_FIXED | GMEM_ZEROINIT)
  1152. LPTOP_LEVEL_EXCEPTION_FILTER :: PVECTORED_EXCEPTION_HANDLER
  1153. ACTCTXW :: struct {
  1154. Size: ULONG,
  1155. Flags: DWORD,
  1156. Source: LPCWSTR,
  1157. ProcessorArchitecture: USHORT,
  1158. LangId: LANGID,
  1159. AssemblyDirectory: LPCWSTR,
  1160. ResourceName: LPCWSTR,
  1161. ApplicationName: LPCWSTR,
  1162. Module: HMODULE,
  1163. }
  1164. PACTCTXW :: ^ACTCTXW
  1165. PCACTCTXW :: ^ACTCTXW
  1166. ACTCTX_FLAG_PROCESSOR_ARCHITECTURE_VALID :: 0x001
  1167. ACTCTX_FLAG_LANGID_VALID :: 0x002
  1168. ACTCTX_FLAG_ASSEMBLY_DIRECTORY_VALID :: 0x004
  1169. ACTCTX_FLAG_RESOURCE_NAME_VALID :: 0x008
  1170. ACTCTX_FLAG_SET_PROCESS_DEFAULT :: 0x010
  1171. ACTCTX_FLAG_APPLICATION_NAME_VALID :: 0x020
  1172. ACTCTX_FLAG_HMODULE_VALID :: 0x080
  1173. @(default_calling_convention="system")
  1174. foreign kernel32 {
  1175. CreateActCtxW :: proc(pActCtx: ^ACTCTXW) -> HANDLE ---
  1176. ActivateActCtx :: proc(hActCtx: HANDLE, lpCookie: ^ULONG_PTR) -> BOOL ---
  1177. }