124 lines
3.8 KiB
C
124 lines
3.8 KiB
C
//TracePDB - Extracts trace information from the PDB
|
|
// This small tool is used to extract the same trace information that binplace does, but can be used 'after the fact'
|
|
// that is if you have the full symbols PDB but no trace information, TracePDB can generate the trace
|
|
// tmf and tmc files for you.
|
|
|
|
#ifdef __cplusplus
|
|
extern "C"{
|
|
#endif
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <nt.h>
|
|
#include <ntrtl.h>
|
|
#include <nturtl.h>
|
|
#include <windows.h>
|
|
#include <shellapi.h>
|
|
#include <tchar.h>
|
|
#include <dbghelp.h>
|
|
#include "wppfmt.h"
|
|
|
|
|
|
int _cdecl main(int argc, char** argv)
|
|
{
|
|
DWORD status;
|
|
TCHAR lppath[MAX_PATH] ;
|
|
TCHAR lppath_tmp[MAX_PATH];
|
|
TCHAR pdbname[MAX_PATH] ;
|
|
INT len, targv=0 ;
|
|
BOOL Verbose = FALSE ;
|
|
BOOL bPDBName = FALSE ;
|
|
LPSTR szRSDSDllToLoad = NULL;
|
|
|
|
|
|
TCHAR helptext[] = "Usage: TracePDB -f <pdbname> [-p <path>] [-v]\n"
|
|
" Options:\n"
|
|
// " -r recurse into subdirectories\n"
|
|
" -f specifies the PDBName from which to extract tmf's\n"
|
|
" -p specifies the path to create the tmf's,\n"
|
|
" by default the current directory.\n"
|
|
" -v verbose, displays actions taken \n" ;
|
|
|
|
|
|
|
|
if (GetCurrentDirectory(MAX_PATH,lppath) == 0 ) {
|
|
fputs("TracePDB: no current directory\n", stdout) ;
|
|
exit(-1);
|
|
}
|
|
|
|
|
|
while (--argc > 0) {
|
|
++targv;
|
|
if (argv[targv][0] == '-' || argv[targv][0] == '/') { // argument found
|
|
|
|
if (argv[targv][1] == 'h' || argv[targv][1] == 'H'
|
|
|| argv[targv][1] == '?')
|
|
{
|
|
fputs(helptext, stdout);
|
|
return 1;
|
|
} else if (argv[targv][1] == 'f') {
|
|
if (--argc >0 ) {
|
|
++targv ;
|
|
if ((strlen(argv[targv])+1) > MAX_PATH) {
|
|
fputs("TracePDB: PDBname toolarge\n", stdout);
|
|
exit(-1);
|
|
}
|
|
strncpy(pdbname,argv[targv],strlen(argv[targv])+1);
|
|
bPDBName = TRUE ;
|
|
}
|
|
} else if (argv[targv][1] == 'p') {
|
|
if (--argc >0 ) {
|
|
++ targv ;
|
|
if ((strlen(argv[targv])+1) > MAX_PATH) {
|
|
fputs("TracePDB: Path larger than MAX_PATH\n", stdout);
|
|
exit(-1);
|
|
}
|
|
strncpy(lppath,argv[targv],strlen(argv[targv])+1);
|
|
}
|
|
} else if (argv[targv][1] == 'v') {
|
|
Verbose = TRUE ;
|
|
} else {
|
|
fputs(helptext, stdout);
|
|
}
|
|
}
|
|
}
|
|
|
|
if (!bPDBName) {
|
|
printf("TracePDB: No PDB specified?\n\n%s",helptext);
|
|
return (1);
|
|
}
|
|
|
|
if ((szRSDSDllToLoad = (LPSTR) malloc(MAX_PATH+1)) == NULL) {
|
|
fputs("TracePDB: malloc failed\n", stdout);
|
|
return FALSE ;
|
|
}
|
|
strcpy( szRSDSDllToLoad, "mspdb70.dll");
|
|
|
|
//Append a '\' and check if the path name is a valid directory
|
|
_sntprintf(lppath_tmp,MAX_PATH,_T("%s\\"),lppath);
|
|
lppath_tmp[MAX_PATH-1] = _T('\0');
|
|
|
|
if (!MakeSureDirectoryPathExists(lppath_tmp))
|
|
{
|
|
_tprintf ("TracePDB: Invalid Path Name %s\n", lppath);
|
|
return 0;
|
|
}
|
|
|
|
status = BinplaceWppFmt(pdbname,
|
|
lppath,
|
|
szRSDSDllToLoad,
|
|
TRUE // always verbose
|
|
) ;
|
|
|
|
if (status != ERROR_SUCCESS) {
|
|
printf("TracePDB: failed with error %d\n", status);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|