|
|
#pragma once
#define ever (;;)
void xGetOverlappedResult( HANDLE hFile, LPOVERLAPPED lpOverlapped, LPDWORD lpNumberOfBytesTransferred, BOOL bWait);
HANDLE xCreateFile( PCTSTR pcszFileName, // file name
DWORD dwDesiredAccess, // access mode
DWORD dwShareMode, // share mode
PSECURITY_ATTRIBUTES pSecurityAttributes, // SD
DWORD dwCreationDisposition, // how to create
DWORD dwFlagsAndAttributes, // file attributes
HANDLE hTemplateFile); // handle to template file
void xCloseHandle( HANDLE hObject); // handle to object
BOOL xReadFile( HANDLE hFile, // handle to file
PVOID pBuffer, // data buffer
DWORD dwNumberOfBytesToRead, // number of bytes to read
PDWORD pdwNumberOfBytesRead, // number of bytes read
LPOVERLAPPED pOverlapped); // overlapped buffer
void xReadFileWithAbort( HANDLE hFile, // handle to file
PVOID pBuffer, // data buffer
DWORD dwNumberOfBytesToRead, // number of bytes to read
PDWORD pdwNumberOfBytesRead, // number of bytes read
LPOVERLAPPED pOverlapped, // overlapped buffer
HANDLE hAbort); // Handle to manual reset abort event
BOOL xWriteFile( HANDLE hFile, // handle to file
LPCVOID pBuffer, // data buffer
DWORD dwNumberOfBytesToWrite, // number of bytes to write
PDWORD pdwNumberOfBytesWritten, // number of bytes written
LPOVERLAPPED pOverlapped); // overlapped buffer
void xWriteFileWithAbort( HANDLE hFile, // handle to file
LPCVOID pBuffer, // data buffer
DWORD dwNumberOfBytesToWrite, // number of bytes to write
PDWORD pdwNumberOfBytesWritten, // number of bytes written
LPOVERLAPPED pOverlapped, // overlapped buffer
HANDLE hAbort); // Handle to manual reset abort event
void xGetCommState( HANDLE hFile, // handle to communications device
LPDCB pDCB); // device-control block
void xSetCommState( HANDLE hFile, // handle to communications device
LPDCB pDCB); // device-control block
void xGetCommTimeouts( HANDLE hFile, // handle to comm device
LPCOMMTIMEOUTS pCommTimeouts); // time-out values
void xSetCommTimeouts( HANDLE hFile, // handle to comm device
LPCOMMTIMEOUTS pCommTimeouts); // time-out values
void xSetCommMask( HANDLE hFile, // handle to communications device
DWORD dwEvtMask); // mask that identifies enabled events
void xGetCommMask( HANDLE hFile, // handle to communications device
PDWORD pdwEvtMask); // mask that identifies enabled events
BOOL xWaitCommEvent( HANDLE hFile, // handle to comm device
PDWORD pdwEvtMask, // event type
LPOVERLAPPED pOverlapped); // overlapped structure
void xWaitCommEventWithAbort( HANDLE hFile, // handle to comm device
PDWORD pdwEvtMask, // event type
LPOVERLAPPED pOverlapped, // overlapped structure
HANDLE hAbort); // Manual reset abort event
void xEscapeCommFunction( HANDLE hFile, // handle to communications device
DWORD dwFunc); // extended function to perform
void xClearCommBreak( HANDLE hFile); // handle to communications device
void xClearCommError( HANDLE hFile, // handle to communications device
PDWORD pdwErrors, // error codes
LPCOMSTAT pStat); // communications status
void xBuildCommDCB( PCTSTR pcszDef, // device-control string
LPDCB lpDCB); // device-control block
void xTransmitCommChar( HANDLE hFile, char cChar);
HANDLE xCreateThread( LPSECURITY_ATTRIBUTES lpThreadAttributes, // SD
DWORD dwStackSize, // initial stack size
LPTHREAD_START_ROUTINE lpStartAddress, // thread function
LPVOID lpParameter, // thread argument
DWORD dwCreationFlags, // creation option
LPDWORD lpThreadId); // thread identifier
void xTerminateThread( HANDLE hThread, // handle to thread
DWORD dwExitCode); // exit code
UINT_PTR xSetTimer( HWND hWnd, // handle to window
UINT_PTR nIDEvent, // timer identifier
UINT uElapse, // time-out value
TIMERPROC lpTimerFunc); // timer procedure
void xKillTimer( HWND hWnd, // handle to window
UINT_PTR uIDEvent); // timer identifier
void xFillConsoleOutputAttribute( HANDLE hConsoleOutput, // handle to screen buffer
WORD wAttribute, // color attribute
DWORD nLength, // number of cells
COORD dwWriteCoord, // first coordinates
LPDWORD lpNumberOfAttrsWritten // number of cells written
);
void xFillConsoleOutputCharacter( HANDLE hConsoleOutput, // handle to screen buffer
TCHAR cCharacter, // character
DWORD nLength, // number of cells
COORD dwWriteCoord, // first coordinates
LPDWORD lpNumberOfCharsWritten // number of cells written
);
void xGetConsoleScreenBufferInfo( HANDLE hConsoleOutput, // handle to screen buffer
PCONSOLE_SCREEN_BUFFER_INFO lpConsoleScreenBufferInfo // screen buffer information
);
DWORD xGetConsoleTitle( LPTSTR lpConsoleTitle, // console title
DWORD nSize // size of title buffer
);
COORD xGetLargestConsoleWindowSize( HANDLE hConsoleOutput // handle to screen buffer
);
HANDLE xGetStdHandle( DWORD nStdHandle = STD_OUTPUT_HANDLE);// Input, output or error device
void xReadConsoleOutputAttribute( HANDLE hConsoleOutput, // handle to screen buffer
LPWORD lpAttribute, // attributes buffer
DWORD nLength, // number of cells to read
COORD dwReadCoord, // coordinates of first cell
LPDWORD lpNumberOfAttrsRead // number of cells read
);
void xReadConsoleOutputCharacter( HANDLE hConsoleOutput, // handle to screen buffer
LPTSTR lpCharacter, // character buffer
DWORD nLength, // number of cells to read
COORD dwReadCoord, // coordinates of first cell
LPDWORD lpNumberOfCharsRead // number of cells read
);
void xSetConsoleScreenBufferSize( HANDLE hConsoleOutput, // handle to screen buffer
COORD dwSize // new screen buffer size
);
void xSetConsoleTextAttribute( HANDLE hConsoleOutput, // handle to screen buffer
WORD wAttributes // text and background colors
);
void xSetConsoleTitle( LPCTSTR lpConsoleTitle // new console title
);
void xSetConsoleWindowInfo( HANDLE hConsoleOutput, // handle to screen buffer
BOOL bAbsolute, // coordinate type
CONST SMALL_RECT *lpConsoleWindow // window corners
);
void xWriteConsole( HANDLE hConsoleOutput, // handle to screen buffer
CONST VOID *lpBuffer, // write buffer
DWORD nNumberOfCharsToWrite, // number of characters to write
LPDWORD lpNumberOfCharsWritten, // number of characters written
LPVOID lpReserved // reserved
);
void xWriteConsoleOutputAttribute( HANDLE hConsoleOutput, // handle to screen buffer
CONST WORD *lpAttribute, // write attributes
DWORD nLength, // number of cells
COORD dwWriteCoord, // first cell coordinates
LPDWORD lpNumberOfAttrsWritten // number of cells written
);
void xWriteConsoleOutputCharacter( HANDLE hConsoleOutput, // handle to screen buffer
LPCTSTR lpCharacter, // characters
DWORD nLength, // number of characters to write
COORD dwWriteCoord, // first cell coordinates
LPDWORD lpNumberOfCharsWritten // number of cells written
);
HANDLE xCreateEvent( LPSECURITY_ATTRIBUTES lpEventAttributes, // SD
BOOL bManualReset, // reset type
BOOL bInitialState, // initial state
LPCTSTR lpName); // object name
void xSetEvent( HANDLE hEvent);
void xResetEvent( HANDLE hEvent);
DWORD xWaitForMultipleObjects( DWORD nCount, // number of handles in array
CONST HANDLE *lpHandles, // object-handle array
BOOL fWaitAll, // wait option
DWORD dwMilliseconds); // time-out interval
DWORD xWaitForSingleObject( HANDLE hHandle, // handle to object
DWORD dwMilliseconds); // time-out interval
PWSTR xMultiByteToWideChar( UINT CodePage, // code page
DWORD dwFlags, // performance and mapping flags
LPCSTR lpMultiByteStr); // wide-character string
PSTR xWideCharToMultiByte( UINT CodePage, // code page
DWORD dwFlags, // performance and mapping flags
LPCWSTR lpWideCharStr); // wide-character string
PWSTR xMakeWideChar( PTSTR pcszInput);
PSTR xMakeMultiByte( PTSTR pcszInput);
PTSTR xMakeDefaultChar( PWSTR pcszInput);
PTSTR xMakeDefaultChar( PSTR pcszInput);
DWORD xGetModuleFileName( HMODULE hModule, // handle to module
LPTSTR lpFilename, // file name of module
DWORD nSize // size of buffer
);
HANDLE xFindFirstFile( LPCTSTR lpFileName, // file name
LPWIN32_FIND_DATA lpFindFileData);// data buffer
BOOL xFindNextFile( HANDLE hFindFile, // search handle
LPWIN32_FIND_DATA lpFindFileData);// data buffer
HMODULE xLoadLibrary( LPCTSTR lpFileName); // file name of module
BOOL xFreeLibrary( HMODULE hModule); // handle to DLL module
FARPROC xGetProcAddress( HMODULE hModule, LPCSTR lpProcName);
HANDLE xCreateMutex( LPSECURITY_ATTRIBUTES lpMutexAttributes, // SD
BOOL bInitialOwner, // initial owner
LPCTSTR lpName); // object name
void xReleaseMutex( HANDLE hMutex);
PTSTR xFormatMessage( DWORD dwFlags, // source and processing options
LPCVOID lpSource, // message source
DWORD dwMessageId, // message identifier
DWORD dwLanguageId, // language identifier
LPTSTR lpBuffer, // message buffer
DWORD nSize, // maximum size of message buffer
va_list *Arguments); // array of message inserts
class CFindFile { public: CFindFile() : m_hFind(INVALID_HANDLE_VALUE) {} ~CFindFile();
public: BOOL First(PCTSTR pcszFileName); BOOL Next(); PWIN32_FIND_DATA Found();
protected: HANDLE m_hFind; WIN32_FIND_DATA m_FindData; };
template< class _Ty, void* _cf = CloseHandle, _Ty _inv = INVALID_HANDLE_VALUE> class auto_generic_handle { public: explicit auto_generic_handle(_Ty hValue = _inv) : _handle(hValue), _owner(hValue!=_inv) {} auto_generic_handle(const auto_generic_handle<_Ty,_cf,_inv>& _Y) : _owner(_Y._owner), _handle(_Y.release()) {}
~auto_generic_handle() { autoclose(); }
_Ty get() const { return _handle; }
_Ty release() const { _owner = FALSE; return get(); }
void close() { if (_handle!=_inv) { ((auto_handle_closeproc)_cf)(_handle); _handle = _inv; } _owner = FALSE; }
operator const _Ty () const { return _handle; }
protected: void autoclose() { if (_owner) { close(); } } auto_generic_handle<_Ty,_cf,_inv>& operator = (const auto_generic_handle<_Ty,_cf,_inv>& _Y) { if (this!=&_Y) // Ignore all self assignments
{ if (_handle!=_Y.get()) { if (_owner) { close(); } _owner = _Y._owner; } else if (_Y._owner) { _owner = TRUE; } _handle = _Y.release(); } return *this; }
private: //
// We can only specialize this template to operate on handles that have
// a close function taking one parameter (the handle) and returning BOOL.
//
typedef BOOL (WINAPI *auto_handle_closeproc)(_Ty); _Ty _handle; BOOL _owner; };
typedef auto_generic_handle<HMODULE,xFreeLibrary,NULL> auto_module_handle; typedef auto_generic_handle<HANDLE,xCloseHandle,INVALID_HANDLE_VALUE> auto_file_handle;
|