Permet de décorer les API Windows.
Site GitHub Archive du 09/12/2019 le 07/02/2020
Se compile avec nmake.exe
de Visual Studio.
J'ai dû ajouter au CFLAGS
du fichier src/Makefile
/I "C:\Program Files (x86)\Windows Kits\10\Include\10.0.17763.0\um" /I "C:\Program Files (x86)\Windows Kits\10\Include\10.0.17763.0\shared" /I "C:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\include" /I "C:\Program Files (x86)\Windows Kits\10\Include\10.0.17763.0\ucrt"
Exemple pris sur le Wiki du site GitHub.
#include <windows.h> #include <detours.h> // Target pointer for the uninstrumented Sleep API. // static VOID(WINAPI * TrueSleep)(DWORD dwMilliseconds) = Sleep; // Detour function that replaces the Sleep API. // VOID WINAPI TimedSleep(DWORD dwMilliseconds) { // Save the before and after times around calling the Sleep API. DWORD dwBeg = GetTickCount(); TrueSleep(dwMilliseconds); DWORD dwEnd = GetTickCount(); OutputDebugStringW(L"My output string.\n"); } int main() { if (DetourIsHelperProcess()) { return TRUE; } DetourRestoreAfterWith(); DetourTransactionBegin(); DetourUpdateThread(GetCurrentThread()); DetourAttach(&(PVOID&)TrueSleep, TimedSleep); DetourTransactionCommit(); Sleep(100); Sleep(100); Sleep(100); DetourTransactionBegin(); DetourUpdateThread(GetCurrentThread()); DetourDetach(&(PVOID&)TrueSleep, TimedSleep); DetourTransactionCommit(); return 0; }
Sortie dans la console :
My output string. My output string. My output string.