#include <windows.h>
#include <stdio.h>
  
static char staticDir[512];
static char moduleName[512];
static char progressText[]	= "/-\\|";
static char progress		= 0;
static int  time, lastTime;
  #pragma comment(lib, "Winmm.lib")
  
bool CheckExt(char* a_Name, char* a_Extension)
{
	int len    = strlen(a_Name)-1;
	int extLen = strlen(a_Extension)-1;
	bool found = true;
  	while (len >= 0 && extLen >= 0 && found)
	{
		found = (a_Name[len] == a_Extension[extLen]);
		len--;
		extLen--;
	}
	return found;
}
  PBITMAPINFO CreateBitmapInfoStruct(HBITMAP hBmp)
{ 
    BITMAP bmp; 
    PBITMAPINFO pbmi; 
    WORD    cClrBits; 
	
    // Retrieve the bitmap's color format, width, and height. 
    GetObject(hBmp, sizeof(BITMAP), (LPSTR)&bmp);
	
    // Convert the color format to a count of bits. 
    cClrBits = (WORD)(bmp.bmPlanes * bmp.bmBitsPixel); 
    if (cClrBits == 1) 
        cClrBits = 1; 
    else if (cClrBits <= 4) 
        cClrBits = 4; 
    else if (cClrBits <= 8) 
        cClrBits = 8; 
    else if (cClrBits <= 16) 
        cClrBits = 16; 
    else if (cClrBits <= 24) 
        cClrBits = 24; 
    else cClrBits = 32; 
	
    // Allocate memory for the BITMAPINFO structure. (This structure 
    // contains a BITMAPINFOHEADER structure and an array of RGBQUAD 
    // data structures.) 
	
	if (cClrBits != 24) 
		pbmi = (PBITMAPINFO) LocalAlloc(LPTR, 
		sizeof(BITMAPINFOHEADER) + 
		sizeof(RGBQUAD) * (1<< cClrBits)); 
	
	// There is no RGBQUAD array for the 24-bit-per-pixel format. 
	
	else 
		pbmi = (PBITMAPINFO) LocalAlloc(LPTR, 
		sizeof(BITMAPINFOHEADER)); 
	
    // Initialize the fields in the BITMAPINFO structure. 
	
    pbmi->bmiHeader.biSize = sizeof(BITMAPINFOHEADER); 
    pbmi->bmiHeader.biWidth = bmp.bmWidth; 
    pbmi->bmiHeader.biHeight = bmp.bmHeight; 
    pbmi->bmiHeader.biPlanes = bmp.bmPlanes; 
    pbmi->bmiHeader.biBitCount = bmp.bmBitsPixel; 
    if (cClrBits < 24) 
        pbmi->bmiHeader.biClrUsed = (1<<cClrBits); 
	
    // If the bitmap is not compressed, set the BI_RGB flag. 
    pbmi->bmiHeader.biCompression = BI_RGB; 
	
    // Compute the number of bytes in the array of color 
    // indices and store the result in biSizeImage. 
    // For Windows NT/2000, the width must be DWORD aligned unless 
    // the bitmap is RLE compressed. This example shows this. 
    // For Windows 95/98, the width must be WORD aligned unless the 
    // bitmap is RLE compressed.
    pbmi->bmiHeader.biSizeImage = ((pbmi->bmiHeader.biWidth * cClrBits +31) & ~31) /8
		* pbmi->bmiHeader.biHeight; 
    // Set biClrImportant to 0, indicating that all of the 
    // device colors are important. 
	pbmi->bmiHeader.biClrImportant = 0; 
	return pbmi; 
} 
  
int CreateBMPFile(LPTSTR pszFile, PBITMAPINFO pbi, HBITMAP hBMP, HDC hDC) 
{ 
	HANDLE hf;                 // file handle 
    BITMAPFILEHEADER hdr;       // bitmap file-header 
    PBITMAPINFOHEADER pbih;     // bitmap info-header 
    LPBYTE lpBits;              // memory pointer 
    DWORD dwTotal;              // total count of bytes 
    DWORD cb;                   // incremental count of bytes 
    BYTE *hp;                   // byte pointer 
    DWORD dwTmp; 
	
    pbih = (PBITMAPINFOHEADER) pbi; 
    lpBits = (LPBYTE) GlobalAlloc(GMEM_FIXED, pbih->biSizeImage);
	
    if (!lpBits) 
	{ 
		return -1;
	}
	
    // Retrieve the color table (RGBQUAD array) and the bits 
    // (array of palette indices) from the DIB. 
    if (!GetDIBits(hDC, hBMP, 0, (WORD) pbih->biHeight, lpBits, pbi, 
        DIB_RGB_COLORS)) 
	{ 
		return -1;
	}
	
    // Create the .BMP file. 
    hf = CreateFile(pszFile, 
		GENERIC_READ | GENERIC_WRITE, 
		(DWORD) 0, 
		NULL, 
		CREATE_ALWAYS, 
		FILE_ATTRIBUTE_NORMAL, 
		(HANDLE) NULL); 
    if (hf == INVALID_HANDLE_VALUE) 
    { 
		return -1;
	}
      hdr.bfType = 0x4d42;        // 0x42 = "B" 0x4d = "M" 
    // Compute the size of the entire file. 
    hdr.bfSize = (DWORD) (sizeof(BITMAPFILEHEADER) + 
		pbih->biSize + pbih->biClrUsed 
		* sizeof(RGBQUAD) + pbih->biSizeImage); 
    hdr.bfReserved1 = 0; 
    hdr.bfReserved2 = 0; 
	
    // Compute the offset to the array of color indices. 
    hdr.bfOffBits = (DWORD) sizeof(BITMAPFILEHEADER) + 
		pbih->biSize + pbih->biClrUsed 
		* sizeof (RGBQUAD); 
	
    // Copy the BITMAPFILEHEADER into the .BMP file. 
    if (!WriteFile(hf, (LPVOID) &hdr, sizeof(BITMAPFILEHEADER), (LPDWORD) &dwTmp,  NULL)) 
	{ 
		return -1;
	}
	
    // Copy the BITMAPINFOHEADER and RGBQUAD array into the file. 
    if (!WriteFile(hf, (LPVOID)pbih, sizeof(BITMAPINFOHEADER) + pbih->biClrUsed * sizeof(RGBQUAD), (LPDWORD)&dwTmp, NULL))
    { 
		return -1;
	}
	
    // Copy the array of color indices into the .BMP file. 
    dwTotal = cb = pbih->biSizeImage; 
    hp = lpBits; 
    if (!WriteFile(hf, (LPSTR) hp, (int) cb, (LPDWORD) &dwTmp,NULL)) 
    { 
		return -1;
	}
	
    // Close the .BMP file. 
	if (!CloseHandle(hf)) 
	{ 
		return -1;
	}
	
    // Free memory. 
    GlobalFree((HGLOBAL)lpBits);
	return 0;
}
 
 
  BOOL CALLBACK EnumResNameProc(HMODULE a_Module, LPCTSTR a_Type, LPTSTR a_Name, LONG_PTR a_Param)
{
	HBITMAP bitmap = NULL;
  	char resName[512];
	if ((DWORD)a_Name < 65536)
	{
		sprintf(resName, "c:/res/%s.%d.bmp", moduleName, a_Name);
	} else
	{
		sprintf(resName, "c:/res/%s.%d.bmp", moduleName, a_Name);
	}
	
	switch ((DWORD)a_Type)
	{
	case RT_BITMAP: 
		bitmap = LoadBitmap(a_Module, a_Name);
		break;
	}
	
	if (bitmap != NULL)
	{
		HDC hdc = GetDC(NULL);
		PBITMAPINFO info = CreateBitmapInfoStruct(bitmap);
		CreateBMPFile(resName, info, bitmap, hdc);
		ReleaseDC(NULL, hdc);
		
	}
	
	return TRUE;
}
  
BOOL CALLBACK EnumResTypeProc(HMODULE a_Module, LPTSTR a_Type, LONG_PTR a_Param)
{
	EnumResourceNames(a_Module, a_Type, EnumResNameProc, a_Param);
	return TRUE;
}
  
void SearchFiles()
{
	HANDLE				findHandle;
	WIN32_FIND_DATA		findData;
  	findHandle = FindFirstFile("*.*", &findData);
	do 
	{
		if ((findData.dwFileAttributes & FILE_ATTRIBUTE_DIRECTORY) != 0)
		{
			if (stricmp(findData.cFileName, ".")!=0 && 
				stricmp(findData.cFileName, "..")!=0)
			{
				SetCurrentDirectory(findData.cFileName);
				SearchFiles();
				SetCurrentDirectory("..");
			}
		} else
		if ((findData.dwFileAttributes & FILE_ATTRIBUTE_READONLY) == 0)
		{
			//if (CheckExt(findData.cFileName, ".dll") || CheckExt(findData.cFileName, ".exe"))
			{
				GetCurrentDirectory(512, staticDir);
	
				HINSTANCE module = LoadLibraryEx(findData.cFileName, NULL, LOAD_LIBRARY_AS_DATAFILE); 
				if (module != NULL) 
				{ 
					printf("%s\\%s\n", staticDir, findData.cFileName);
					strcpy(moduleName, findData.cFileName);
					EnumResourceTypes(module, EnumResTypeProc, 0);		
					FreeLibrary(module);
				} 
			}
		}
  		time = timeGetTime();
		if (time - lastTime > 100)
		{
			progress = (progress+1)&3;
			printf("%c\r", progressText[progress]);
			lastTime = time;
		}
  	} while (FindNextFile(findHandle, &findData));
}
  
int main(void)
{
	lastTime = timeGetTime();
	SearchFiles();
	return 0;
}
   |