2020-09-30 16:53:55 +02:00

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