亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? extendedtrace.cpp

?? dc++(一個曾經大量使用的p2p)的源代碼,dc++,開源的p2p源代碼
?? CPP
字號:
//////////////////////////////////////////////////////////////////////////////////////
//
// Written by Zoltan Csizmadia, zoltan_csizmadia@yahoo.com
// For companies(Austin,TX): If you would like to get my resume, send an email.
//
// The source is free, but if you want to use it, mention my name and e-mail address
//
// History:
//    1.0      Initial version                  Zoltan Csizmadia
//
//////////////////////////////////////////////////////////////////////////////////////
//
// ExtendedTrace.cpp
//

// Include StdAfx.h, if you're using precompiled 
// header through StdAfx.h
#include "stdafx.h"

#if defined(WIN32)

#include "../client/DCPlusPlus.h"
#include "../client/File.h"

#include <tchar.h>
#include <DbgHelp.h>
#include "ExtendedTrace.h"

#define BUFFERSIZE   0x200

// Unicode safe char* -> TCHAR* conversion
void PCSTR2LPTSTR( PCSTR lpszIn, LPTSTR lpszOut )
{
#if defined(UNICODE)||defined(_UNICODE)
   ULONG index = 0; 
   PCSTR lpAct = lpszIn;
   
	for( ; ; lpAct++ )
	{
		lpszOut[index++] = (TCHAR)(*lpAct);
		if ( *lpAct == 0 )
			break;
	} 
#else
   // This is trivial :)
	strcpy( lpszOut, lpszIn );
#endif
}

// Let's figure out the path for the symbol files
// Search path= ".;%_NT_SYMBOL_PATH%;%_NT_ALTERNATE_SYMBOL_PATH%;%SYSTEMROOT%;%SYSTEMROOT%\System32;" + lpszIniPath
// Note: There is no size check for lpszSymbolPath!
static void InitSymbolPath( PSTR lpszSymbolPath, PCSTR lpszIniPath )
{
	CHAR lpszPath[BUFFERSIZE];

   // Creating the default path
   // ".;%_NT_SYMBOL_PATH%;%_NT_ALTERNATE_SYMBOL_PATH%;%SYSTEMROOT%;%SYSTEMROOT%\System32;"
	strcpy( lpszSymbolPath, "." );

	// environment variable _NT_SYMBOL_PATH
	if ( GetEnvironmentVariableA( "_NT_SYMBOL_PATH", lpszPath, BUFFERSIZE ) )
	{
	   strcat( lpszSymbolPath, ";" );
		strcat( lpszSymbolPath, lpszPath );
	}

	// environment variable _NT_ALTERNATE_SYMBOL_PATH
	if ( GetEnvironmentVariableA( "_NT_ALTERNATE_SYMBOL_PATH", lpszPath, BUFFERSIZE ) )
	{
	   strcat( lpszSymbolPath, ";" );
		strcat( lpszSymbolPath, lpszPath );
	}

	// environment variable SYSTEMROOT
	if ( GetEnvironmentVariableA( "SYSTEMROOT", lpszPath, BUFFERSIZE ) )
	{
	   strcat( lpszSymbolPath, ";" );
		strcat( lpszSymbolPath, lpszPath );
		strcat( lpszSymbolPath, ";" );

		// SYSTEMROOT\System32
		strcat( lpszSymbolPath, lpszPath );
		strcat( lpszSymbolPath, "\\System32" );
	}

   // Add user defined path
	if ( lpszIniPath != NULL )
		if ( lpszIniPath[0] != '\0' )
		{
		   strcat( lpszSymbolPath, ";" );
			strcat( lpszSymbolPath, lpszIniPath );
		}
}

// Uninitialize the loaded symbol files
BOOL UninitSymInfo() {
	return SymCleanup( GetCurrentProcess() );
}

// Initializes the symbol files
BOOL InitSymInfo( PCSTR lpszInitialSymbolPath )
{

	SymSetOptions(SYMOPT_DEFERRED_LOADS | SYMOPT_FAIL_CRITICAL_ERRORS | SYMOPT_LOAD_LINES );
	CHAR     lpszSymbolPath[BUFFERSIZE];
	InitSymbolPath( lpszSymbolPath, lpszInitialSymbolPath );

	return SymInitialize( GetCurrentProcess(), lpszSymbolPath, TRUE);
}

// Get the module name from a given address
static BOOL GetModuleNameFromAddress( UINT address, LPTSTR lpszModule )
{
	BOOL              ret = FALSE;
	IMAGEHLP_MODULE   moduleInfo;

	::ZeroMemory( &moduleInfo, sizeof(moduleInfo) );
	moduleInfo.SizeOfStruct = sizeof(moduleInfo);

	if ( SymGetModuleInfo( GetCurrentProcess(), (DWORD)address, &moduleInfo ) )
	{
	   // Got it!
		PCSTR2LPTSTR( moduleInfo.ModuleName, lpszModule );
		ret = TRUE;
	}
	else
	   // Not found :(
		_tcscpy( lpszModule, _T("?") );
	
	return ret;
}

// Get function prototype and parameter info from ip address and stack address
static BOOL GetFunctionInfoFromAddresses( ULONG fnAddress, ULONG stackAddress, LPTSTR lpszSymbol )
{
	BOOL              ret = FALSE;
	DWORD64             dwDisp = 0;
	DWORD             dwSymSize = 1024*16;
   TCHAR             lpszUnDSymbol[BUFFERSIZE]=_T("?");
	CHAR              lpszNonUnicodeUnDSymbol[BUFFERSIZE]="?";
	LPTSTR            lpszParamSep = NULL;
	LPCTSTR           lpszParsed = lpszUnDSymbol;
	PSYMBOL_INFO  pSym = (PSYMBOL_INFO)GlobalAlloc( GMEM_FIXED, dwSymSize );

	::ZeroMemory( pSym, dwSymSize );
	pSym->SizeOfStruct = dwSymSize;
	pSym->MaxNameLen = dwSymSize - sizeof(IMAGEHLP_SYMBOL);

   // Set the default to unknown
	_tcscpy( lpszSymbol, _T("?") );

	// Get symbol info for IP
	if ( SymFromAddr( GetCurrentProcess(), (ULONG)fnAddress, &dwDisp, pSym ) )
	{
	   // Make the symbol readable for humans
		UnDecorateSymbolName( pSym->Name, lpszNonUnicodeUnDSymbol, BUFFERSIZE, 
			UNDNAME_COMPLETE | 
			UNDNAME_NO_THISTYPE |
			UNDNAME_NO_SPECIAL_SYMS |
			UNDNAME_NO_MEMBER_TYPE |
			UNDNAME_NO_MS_KEYWORDS |
			UNDNAME_NO_ACCESS_SPECIFIERS );
		// Symbol information is ANSI string
		PCSTR2LPTSTR( lpszNonUnicodeUnDSymbol, lpszUnDSymbol );

      // I am just smarter than the symbol file :)
		if ( _tcscmp(lpszUnDSymbol, _T("_WinMain@16")) == 0 )
			_tcscpy(lpszUnDSymbol, _T("WinMain(HINSTANCE,HINSTANCE,LPCTSTR,int)"));
		else
		if ( _tcscmp(lpszUnDSymbol, _T("_main")) == 0 )
			_tcscpy(lpszUnDSymbol, _T("main(int,TCHAR * *)"));
		else
		if ( _tcscmp(lpszUnDSymbol, _T("_mainCRTStartup")) == 0 )
			_tcscpy(lpszUnDSymbol, _T("mainCRTStartup()"));
		else
		if ( _tcscmp(lpszUnDSymbol, _T("_wmain")) == 0 )
			_tcscpy(lpszUnDSymbol, _T("wmain(int,TCHAR * *,TCHAR * *)"));
		else
		if ( _tcscmp(lpszUnDSymbol, _T("_wmainCRTStartup")) == 0 )
			_tcscpy(lpszUnDSymbol, _T("wmainCRTStartup()"));

		lpszSymbol[0] = _T('\0');

      // Let's go through the stack, and modify the function prototype, and insert the actual
      // parameter values from the stack
		if ( _tcsstr( lpszUnDSymbol, _T("(void)") ) == NULL && _tcsstr( lpszUnDSymbol, _T("()") ) == NULL)
		{
			ULONG index = 0;
			for( ; ; index++ )
			{
				lpszParamSep = _tcschr( lpszParsed, _T(',') );
				if ( lpszParamSep == NULL )
					break;

				*lpszParamSep = _T('\0');

				_tcscat( lpszSymbol, lpszParsed );
				_stprintf( lpszSymbol + _tcslen(lpszSymbol), _T("=0x%08X,"), *((ULONG*)(stackAddress) + 2 + index) );

				lpszParsed = lpszParamSep + 1;
			}

			lpszParamSep = _tcschr( lpszParsed, _T(')') );
			if ( lpszParamSep != NULL )
			{
				*lpszParamSep = _T('\0');

				_tcscat( lpszSymbol, lpszParsed );
				_stprintf( lpszSymbol + _tcslen(lpszSymbol), _T("=0x%08X)"), *((ULONG*)(stackAddress) + 2 + index) );

				lpszParsed = lpszParamSep + 1;
			}
		}

		_tcscat( lpszSymbol, lpszParsed );
   
		ret = TRUE;
	} 
	GlobalFree( pSym );

	return ret;
}

// Get source file name and line number from IP address
// The output format is: "sourcefile(linenumber)" or
//                       "modulename!address" or
//                       "address"
static BOOL GetSourceInfoFromAddress( UINT address, LPTSTR lpszSourceInfo )
{
	BOOL           ret = FALSE;
	IMAGEHLP_LINE  lineInfo;
	DWORD          dwDisp;
	TCHAR          lpszFileName[BUFFERSIZE] = _T("");
	TCHAR          lpModuleInfo[BUFFERSIZE] = _T("");

	_tcscpy( lpszSourceInfo, _T("?(?)") );

	::ZeroMemory( &lineInfo, sizeof( lineInfo ) );
	lineInfo.SizeOfStruct = sizeof( lineInfo );

	if ( SymGetLineFromAddr( GetCurrentProcess(), address, &dwDisp, &lineInfo ) )
	{
	   // Got it. Let's use "sourcefile(linenumber)" format
		PCSTR2LPTSTR( lineInfo.FileName, lpszFileName );
		_stprintf( lpszSourceInfo, _T("%s(%d)"), lpszFileName, lineInfo.LineNumber );
		ret = TRUE;
	}
	else
	{
      // There is no source file information. :(
      // Let's use the "modulename!address" format
	  	GetModuleNameFromAddress( address, lpModuleInfo );

		if ( lpModuleInfo[0] == _T('?') || lpModuleInfo[0] == _T('\0'))
		   // There is no modulename information. :((
         // Let's use the "address" format
			_stprintf( lpszSourceInfo, _T("0x%08X"), lpModuleInfo, address );
		else
			_stprintf( lpszSourceInfo, _T("%s!0x%08X"), lpModuleInfo, address );

		ret = FALSE;
	}
	
	return ret;
}

void StackTrace( HANDLE hThread, LPCTSTR lpszMessage, File& f )
{
	STACKFRAME     callStack;
	BOOL           bResult;
	CONTEXT        context;
	TCHAR          symInfo[BUFFERSIZE] = _T("?");
	TCHAR          srcInfo[BUFFERSIZE] = _T("?");
	HANDLE         hProcess = GetCurrentProcess();

   // If it's not this thread, let's suspend it, and resume it at the end
	if ( hThread != GetCurrentThread() )
		if ( SuspendThread( hThread ) == -1 )
		{
		   // whaaat ?!
			f.write("Call stack info failed\r\n");
			return;
		}

	::ZeroMemory( &context, sizeof(context) );
	context.ContextFlags = CONTEXT_FULL;

	if ( !GetThreadContext( hThread, &context ) )
	{
		f.write("Call stack info failed\r\n");
		return;
	}
	
	::ZeroMemory( &callStack, sizeof(callStack) );
	callStack.AddrPC.Offset    = context.Eip;
	callStack.AddrStack.Offset = context.Esp;
	callStack.AddrFrame.Offset = context.Ebp;
	callStack.AddrPC.Mode      = AddrModeFlat;
	callStack.AddrStack.Mode   = AddrModeFlat;
	callStack.AddrFrame.Mode   = AddrModeFlat;

	f.write("Call stack info: \r\n");
	f.write(lpszMessage);

	GetFunctionInfoFromAddresses( callStack.AddrPC.Offset, callStack.AddrFrame.Offset, symInfo );
	GetSourceInfoFromAddress( callStack.AddrPC.Offset, srcInfo );
	f.write(string("     ") + srcInfo + string(" : ") + symInfo + string("\r\n"));
	
	for( ULONG index = 0; ; index++ ) 
	{
		bResult = StackWalk(
			IMAGE_FILE_MACHINE_I386,
			hProcess,
			hThread,
	      &callStack,
			NULL, 
			NULL,
			SymFunctionTableAccess,
			SymGetModuleBase,
			NULL);

		if ( index == 0 )
		   continue;

		if( !bResult || callStack.AddrFrame.Offset == 0 ) 
			break;
	
		GetFunctionInfoFromAddresses( callStack.AddrPC.Offset, callStack.AddrFrame.Offset, symInfo );
		GetSourceInfoFromAddress( callStack.AddrPC.Offset, srcInfo );
		f.write(string("     ") + srcInfo + string(" : ") + symInfo + string("\r\n"));

	}

	if ( hThread != GetCurrentThread() )
		ResumeThread( hThread );
}

void StackTrace( HANDLE hThread, LPCTSTR lpszMessage, File& f, DWORD eip, DWORD esp, DWORD ebp )
{
	STACKFRAME     callStack;
	BOOL           bResult;
	TCHAR          symInfo[BUFFERSIZE] = _T("?");
	TCHAR          srcInfo[BUFFERSIZE] = _T("?");
	HANDLE         hProcess = GetCurrentProcess();

	// If it's not this thread, let's suspend it, and resume it at the end
	if ( hThread != GetCurrentThread() )
		if ( SuspendThread( hThread ) == -1 )
		{
			// whaaat ?!
			f.write("Call stack info failed\r\n");
			return;
		}

		::ZeroMemory( &callStack, sizeof(callStack) );
		callStack.AddrPC.Offset    = eip;
		callStack.AddrStack.Offset = esp;
		callStack.AddrFrame.Offset = ebp;
		callStack.AddrPC.Mode      = AddrModeFlat;
		callStack.AddrStack.Mode   = AddrModeFlat;
		callStack.AddrFrame.Mode   = AddrModeFlat;

		f.write("Call stack info: \r\n");
		f.write(lpszMessage);

		GetFunctionInfoFromAddresses( callStack.AddrPC.Offset, callStack.AddrFrame.Offset, symInfo );
		GetSourceInfoFromAddress( callStack.AddrPC.Offset, srcInfo );
		f.write(string("     ") + srcInfo + string(" : ") + symInfo + string("\r\n"));

		for( ULONG index = 0; ; index++ ) 
		{
			bResult = StackWalk(
				IMAGE_FILE_MACHINE_I386,
				hProcess,
				hThread,
				&callStack,
				NULL, 
				NULL,
				SymFunctionTableAccess,
				SymGetModuleBase,
				NULL);

			if ( index == 0 )
				continue;

			if( !bResult || callStack.AddrFrame.Offset == 0 ) 
				break;

			GetFunctionInfoFromAddresses( callStack.AddrPC.Offset, callStack.AddrFrame.Offset, symInfo );
			GetSourceInfoFromAddress( callStack.AddrPC.Offset, srcInfo );
			f.write(string("     ") + srcInfo + string(" : ") + symInfo + string("\r\n"));

		}

		if ( hThread != GetCurrentThread() )
			ResumeThread( hThread );
}

#endif //_DEBUG && WIN32

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产综合在线| 一区二区三区不卡视频在线观看| 欧美日韩在线三区| 精品国产伦一区二区三区观看方式 | 国产精品天美传媒沈樵| 欧美tk丨vk视频| 日韩欧美国产电影| 日韩欧美成人激情| 精品免费一区二区三区| 欧美电影精品一区二区| 精品欧美久久久| 国产人成亚洲第一网站在线播放| 久久综合色8888| 国产人伦精品一区二区| 综合精品久久久| 亚洲综合一区二区| 日韩福利视频网| 韩国精品主播一区二区在线观看 | 色综合久久久网| 91久久精品一区二区三| 欧美色图片你懂的| 日韩精品一区二区三区四区 | 蜜臀av性久久久久蜜臀av麻豆| 奇米影视在线99精品| 国产一区二区网址| 99r精品视频| 欧美日韩不卡一区二区| 欧美xxx久久| 亚洲欧美综合网| 亚洲成av人影院在线观看网| 九九精品视频在线看| 成人黄色软件下载| 欧美日韩电影一区| 欧美国产精品专区| 天天色综合天天| 粉嫩久久99精品久久久久久夜| 色天天综合久久久久综合片| 日韩欧美一二三区| 亚洲美女视频在线| 精品午夜久久福利影院| 91免费看`日韩一区二区| 欧美一区二区三区免费| 亚洲视频综合在线| 美女久久久精品| 欧洲av在线精品| 国产亚洲综合在线| 日本不卡123| 91在线你懂得| 久久久精品天堂| 不卡视频在线看| 制服丝袜成人动漫| 亚洲欧美日韩在线不卡| 久久99精品久久久久久久久久久久| av中文字幕不卡| 精品99999| 日本sm残虐另类| 欧美日韩免费不卡视频一区二区三区| 中文欧美字幕免费| 国内精品国产三级国产a久久 | 精品99999| 日韩激情一区二区| 色美美综合视频| 国产精品免费视频一区| 久久精品二区亚洲w码| 欧美高清激情brazzers| 一区二区视频在线| 95精品视频在线| 国产精品久久久久久久久图文区 | 国产精品久久久久久久久免费丝袜| 日本在线观看不卡视频| 欧美日韩成人综合| 亚洲国产精品久久久男人的天堂 | 国产欧美精品一区二区三区四区 | 蜜臀国产一区二区三区在线播放| 在线观看国产91| 亚洲色图视频免费播放| 成人美女在线视频| 中国色在线观看另类| 成人免费视频一区| 国产精品免费观看视频| 大胆亚洲人体视频| 国产精品久久久久三级| 成人黄色一级视频| 亚洲精品免费一二三区| 欧美优质美女网站| 天天av天天翘天天综合网色鬼国产| 欧美无砖专区一中文字| 五月激情六月综合| 精品美女一区二区| 国产伦精品一区二区三区免费| 精品成人佐山爱一区二区| 国产精品一二三四五| 欧美国产精品一区二区三区| 成人91在线观看| 一区二区三区精品在线| 欧美日韩一区二区三区高清 | 亚洲一二三专区| 欧美一区二区视频观看视频| 精品一区二区免费在线观看| 国产亚洲一区字幕| 色吧成人激情小说| 三级一区在线视频先锋| 国产午夜亚洲精品理论片色戒| av成人老司机| 日韩和欧美的一区| 国产欧美精品在线观看| 欧美视频一区二区在线观看| 欧洲精品在线观看| 蜜桃视频免费观看一区| 国产精品毛片大码女人| 欧美日韩一区二区三区不卡| 国产一区欧美日韩| 一区二区三区波多野结衣在线观看 | 亚洲欧美日韩在线不卡| 日韩一区二区高清| www..com久久爱| 三级欧美在线一区| 国产精品久久毛片a| 欧美高清一级片在线| 丁香六月综合激情| 同产精品九九九| 亚洲视频每日更新| 久久婷婷国产综合国色天香| 在线免费观看成人短视频| 国产一区日韩二区欧美三区| 亚洲妇女屁股眼交7| 中文字幕欧美区| 精品国产免费一区二区三区四区| 色婷婷av久久久久久久| 国产乱色国产精品免费视频| 亚洲国产美国国产综合一区二区| 国产日韩精品一区二区三区| 91麻豆精品国产91久久久 | 欧美日韩一区中文字幕| 国产成人在线视频免费播放| 全部av―极品视觉盛宴亚洲| 亚洲欧美日韩一区| 中文字幕 久热精品 视频在线| 欧美成人综合网站| 欧美一区二区视频在线观看2020 | 亚洲欧美偷拍另类a∨色屁股| 久久亚洲影视婷婷| 日韩一区二区三区在线视频| 欧美无砖砖区免费| 欧洲精品中文字幕| 在线视频综合导航| 色女孩综合影院| 一本色道久久综合亚洲91| av午夜一区麻豆| 成人app软件下载大全免费| 粉嫩av一区二区三区粉嫩| 国产精品 欧美精品| 国产成人免费在线| 国产一区美女在线| 丰满岳乱妇一区二区三区| 国产高清在线观看免费不卡| 国产精品一区2区| 国产91丝袜在线播放九色| 国产成人综合在线观看| 成人动漫中文字幕| 91免费在线看| 欧美视频第二页| 欧美日本乱大交xxxxx| 日韩欧美在线网站| 日韩一级免费一区| 2020日本不卡一区二区视频| 久久久久成人黄色影片| 国产精品美女久久久久av爽李琼| 中文字幕亚洲成人| 亚洲成va人在线观看| 免费人成网站在线观看欧美高清| 久久电影网电视剧免费观看| 国产主播一区二区三区| 成人综合在线观看| 欧美日韩综合一区| 亚洲精品国产视频| 日韩福利视频导航| 国产精品77777竹菊影视小说| gogo大胆日本视频一区| 欧美亚日韩国产aⅴ精品中极品| 日韩午夜在线播放| 国产精品免费人成网站| 亚洲成人免费av| 国产99久久久国产精品潘金网站| 99久久精品99国产精品| 51午夜精品国产| 国产精品毛片大码女人| 天堂成人国产精品一区| 国产98色在线|日韩| 欧美日韩一区二区三区不卡| 国产午夜精品福利| 亚洲一区二区偷拍精品| 国产福利一区在线观看| 欧美在线免费观看亚洲| 久久精品欧美一区二区三区不卡 | 国产一区二区精品久久99| 91在线视频18| 久久久久久久av麻豆果冻| 五月综合激情婷婷六月色窝| www.性欧美|