/*
????? Author: void#ph4nt0m.org
*/

// 編譯器 cl.exe(Visual C++ 6.0)
// 沒有做任何優化情況下,編譯大小為:16K
// 編譯優化后: 1K (用16進制編輯器把尾部的0x00去掉: 712bytes)

#include <windows.h>
#pragma comment(lib,"kernel32.lib")

// 作用: 指定節對齊為512字節
#pragma comment(linker, "/align:512")

// 作用: 合并節
// 將.data節和.rdata節合并到.text節(代碼節)

#pragma comment(linker, "/merge:.data=.text")
#pragma comment(linker, "/merge:.rdata=.text")

// 作用: 指定子系統為windows (和優化無關)
// vc編譯器默認是console,會有個黑糊糊的CMD窗口,不好看.用windows就好了

#pragma comment(linker, "/subsystem:windows")

// 作用: 指定入口函數
// 子系統為windows的默認入口點WinMain和console的默認入口點main,都會引入一段啟動stub代碼,指定入口函數可去掉之.
#pragma comment(linker, "/ENTRY:main")


//int WinMain(HINSTANCE current, HINSTANCE prev, LPSTR cmdline, int showcmd)

// 作用: 去掉函數的棧幀代碼,純屬吹毛求疵:-)
// 即函數開頭的push ebp / mov ebp, esp和結尾的pop ebp / retn
__declspec(naked)
void main()
{
????? // 調用wmp. 這是按套路出牌的方法.
????? //typedef VOID (__stdcall *fnRunDllW)(HWND, HINSTANCE, LPCWSTR, DWORD);
????? //((fnRunDllW)GetProcAddress(LoadLibrary("msdxm.ocx"), "RunDllW"))(0,0,0,0);

??? // 不按套路出牌,不壓入RunDllW的函數參數,直接調用.
????? GetProcAddress(LoadLibrary("msdxm.ocx"), "RunDllW")();
????? // 注意此時的堆棧是不平衡的.
????? // 但是通過ExitProcess()退出自身,就不用去考慮平衡了.
????? ExitProcess(0);
}