; Listing generated by Microsoft (R) Optimizing Compiler Version 19.34.31933.0 TITLE D:\Works\Corpsms_2010\SmsCenter\Release_Unicode\KeyList.obj .686P .XMM include listing.inc .model flat INCLUDELIB LIBCMT INCLUDELIB OLDNAMES PUBLIC ?__empty_global_delete@@YAXPAX@Z ; __empty_global_delete PUBLIC ?__empty_global_delete@@YAXPAXI@Z ; __empty_global_delete PUBLIC ?__empty_global_delete@@YAXPAXW4align_val_t@std@@@Z ; __empty_global_delete PUBLIC ?__empty_global_delete@@YAXPAXIW4align_val_t@std@@@Z ; __empty_global_delete PUBLIC ___local_stdio_printf_options PUBLIC __vswprintf_c_l PUBLIC __vswprintf_l PUBLIC ___vswprintf_l PUBLIC __swprintf PUBLIC ?AfxCrtErrorCheck@@YAHH@Z ; AfxCrtErrorCheck PUBLIC ?AtlThrowImpl@ATL@@YGXJ@Z ; ATL::AtlThrowImpl PUBLIC ?wmemcpy_s@Checked@ATL@@YAXPA_WIPB_WI@Z ; ATL::Checked::wmemcpy_s PUBLIC ?AtlStrLen@ATL@@YAHPB_W@Z ; ATL::AtlStrLen PUBLIC ?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z ; ATL::_AtlGetStringResourceImage PUBLIC ?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z ; ATL::AtlGetStringResourceImage PUBLIC ?data@CStringData@ATL@@QAEPAXXZ ; ATL::CStringData::data PUBLIC ?IsLocked@CStringData@ATL@@QBE_NXZ ; ATL::CStringData::IsLocked PUBLIC ?IsShared@CStringData@ATL@@QBE_NXZ ; ATL::CStringData::IsShared PUBLIC ?Release@CStringData@ATL@@QAEXXZ ; ATL::CStringData::Release PUBLIC ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z ; ATL::ChTraitsCRT::GetBaseTypeLength PUBLIC ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_WH@Z ; ATL::ChTraitsCRT::GetBaseTypeLength PUBLIC ?ConvertToBaseType@?$ChTraitsCRT@_W@ATL@@SAXPA_WHPB_WH@Z ; ATL::ChTraitsCRT::ConvertToBaseType PUBLIC ??0?$CSimpleStringT@_W$0A@@ATL@@QAE@PAUIAtlStringMgr@1@@Z ; ATL::CSimpleStringT::CSimpleStringT PUBLIC ??1?$CSimpleStringT@_W$0A@@ATL@@QAE@XZ ; ATL::CSimpleStringT::~CSimpleStringT PUBLIC ??4?$CSimpleStringT@_W$0A@@ATL@@QAEAAV01@PB_W@Z ; ATL::CSimpleStringT::operator= PUBLIC ?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ ; ATL::CSimpleStringT::Empty PUBLIC ?GetAllocLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ ; ATL::CSimpleStringT::GetAllocLength PUBLIC ?GetBuffer@?$CSimpleStringT@_W$0A@@ATL@@QAEPA_WH@Z ; ATL::CSimpleStringT::GetBuffer PUBLIC ?GetLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ ; ATL::CSimpleStringT::GetLength PUBLIC ?GetString@?$CSimpleStringT@_W$0A@@ATL@@QBEPB_WXZ ; ATL::CSimpleStringT::GetString PUBLIC ?ReleaseBufferSetLength@?$CSimpleStringT@_W$0A@@ATL@@QAEXH@Z ; ATL::CSimpleStringT::ReleaseBufferSetLength PUBLIC ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_W@Z ; ATL::CSimpleStringT::SetString PUBLIC ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_WH@Z ; ATL::CSimpleStringT::SetString PUBLIC ?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z ; ATL::CSimpleStringT::CopyCharsOverlapped PUBLIC ?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z ; ATL::CSimpleStringT::StringLength PUBLIC ?ThrowMemoryException@?$CSimpleStringT@_W$0A@@ATL@@KAXXZ ; ATL::CSimpleStringT::ThrowMemoryException PUBLIC ?Attach@?$CSimpleStringT@_W$0A@@ATL@@AAEXPAUCStringData@2@@Z ; ATL::CSimpleStringT::Attach PUBLIC ?Fork@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::Fork PUBLIC ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData PUBLIC ?PrepareWrite@?$CSimpleStringT@_W$0A@@ATL@@AAEPA_WH@Z ; ATL::CSimpleStringT::PrepareWrite PUBLIC ?PrepareWrite2@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::PrepareWrite2 PUBLIC ?Reallocate@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::Reallocate PUBLIC ?SetLength@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::SetLength PUBLIC ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > PUBLIC ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > PUBLIC ??4?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEAAV01@PB_W@Z ; ATL::CStringT > >::operator= PUBLIC ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHI@Z ; ATL::CStringT > >::LoadStringW PUBLIC ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHPAUHINSTANCE__@@I@Z ; ATL::CStringT > >::LoadStringW PUBLIC ?CheckImplicitLoad@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@AAE_NPBX@Z ; ATL::CStringT > >::CheckImplicitLoad PUBLIC ?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z ; StrTraitMFC >::FindStringResourceInstance PUBLIC ?GetDefaultManager@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUIAtlStringMgr@ATL@@XZ ; StrTraitMFC >::GetDefaultManager PUBLIC ?SetID@CAdoConnection@@QAEXJ@Z ; CAdoConnection::SetID PUBLIC ??0IOCP_SQL@@QAE@XZ ; IOCP_SQL::IOCP_SQL PUBLIC ??1IOCP_SQL@@QAE@XZ ; IOCP_SQL::~IOCP_SQL PUBLIC ??_EIOCP_SQL@@QAEPAXI@Z ; IOCP_SQL::`vector deleting destructor' PUBLIC ?GetBlank_SQL@CKeyList@@QAEPAUIOCP_SQL@@XZ ; CKeyList::GetBlank_SQL PUBLIC ?Close@CKeyList@@QAEXXZ ; CKeyList::Close PUBLIC ?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ ; CKeyList::GetBlank_Process PUBLIC ?Init@CKeyList@@QAEXPAVCSmsCenterDlg@@@Z ; CKeyList::Init PUBLIC ?Close_IO@CKeyList@@QAEXXZ ; CKeyList::Close_IO PUBLIC ?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z ; CKeyList::RemoveAt_IO PUBLIC ?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z ; CKeyList::RemoveAt_Key PUBLIC ?GetBlank_IO@CKeyList@@QAEPAUIOCP_IO@@XZ ; CKeyList::GetBlank_IO PUBLIC ?GetBlank_Key@CKeyList@@QAEPAUIOCP_KEY@@XZ ; CKeyList::GetBlank_Key PUBLIC ??0CKeyList@@QAE@XZ ; CKeyList::CKeyList PUBLIC ??1CKeyList@@UAE@XZ ; CKeyList::~CKeyList PUBLIC ??_GCKeyList@@UAEPAXI@Z ; CKeyList::`scalar deleting destructor' PUBLIC ?_OptionsStorage@?1??__local_stdio_printf_options@@9@4_KA ; `__local_stdio_printf_options'::`2'::_OptionsStorage PUBLIC ??_C@_1BC@HEKPCAFP@?$AAA?$AAp?$AAp?$AAE?$AAr?$AAr?$AAo?$AAr@ ; `string' PUBLIC ??_C@_17LLLMIFAB@?$AAL?$AAo?$AAg@ ; `string' PUBLIC ??_C@_13JKNELIBG@?$AAT@ ; `string' PUBLIC ??_7CKeyList@@6B@ ; CKeyList::`vftable' PUBLIC ?__LINE__Var@?0??RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z@4JA ; `CKeyList::RemoveAt_Key'::`1'::__LINE__Var PUBLIC ??_C@_0N@LNMKMNFF@RemoveAt_Key@ ; `string' PUBLIC ??_C@_0DB@EILGGBMO@D?3?2Works?2Corpsms_2010?2SmsCenter@ ; `string' PUBLIC ?__LINE__Var@?0??RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z@4JA ; `CKeyList::RemoveAt_IO'::`1'::__LINE__Var PUBLIC ??_C@_1BO@OIFMIIBA@?$AA?$FL?$AA?$CF?$AAd?$AA?$FN?$AA?$CF?$AAs?$AA?9?$AA?$CF?$AAs?$PP?$KN?$PP?$LP?$AA?$AA?$PP?z?$AA?$CB@ ; `string' PUBLIC ??_C@_1BO@IFJHDIMD@?$AA?$FL?$AA?$CF?$AAd?$AA?$FN?$AA?$CF?$AAs?$AA?9?$AA?$CF?$AAs?$AAc?$AA8?$AA?$AA?$PP?z?$AA?$CB@ ; `string' PUBLIC ??_C@_0M@DCAJJICO@RemoveAt_IO@ ; `string' PUBLIC ?__LINE__Var@?0??Close_IO@CKeyList@@QAEXXZ@4JA ; `CKeyList::Close_IO'::`1'::__LINE__Var PUBLIC ??_C@_08EDPDCAEI@Close_IO@ ; `string' PUBLIC ?__LINE__Var@?0??GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ@4JA ; `CKeyList::GetBlank_Process'::`1'::__LINE__Var PUBLIC ??_C@_0BB@NCGHDNPI@GetBlank_Process@ ; `string' PUBLIC ?__LINE__Var@?0??Close@CKeyList@@QAEXXZ@4JA ; `CKeyList::Close'::`1'::__LINE__Var PUBLIC ??_C@_05LGELBCGM@Close@ ; `string' PUBLIC ??_R4CKeyList@@6B@ ; CKeyList::`RTTI Complete Object Locator' PUBLIC ??_R0?AVCKeyList@@@8 ; CKeyList `RTTI Type Descriptor' PUBLIC ??_R3CKeyList@@8 ; CKeyList::`RTTI Class Hierarchy Descriptor' PUBLIC ??_R2CKeyList@@8 ; CKeyList::`RTTI Base Class Array' PUBLIC ??_R1A@?0A@EA@CKeyList@@8 ; CKeyList::`RTTI Base Class Descriptor at (0,-1,0,64)' EXTRN ??_L@YGXPAXIIP6EX0@Z1@Z:PROC ; `eh vector constructor iterator' EXTRN ??_M@YGXPAXIIP6EX0@Z@Z:PROC ; `eh vector destructor iterator' EXTRN ??3@YAXPAXI@Z:PROC ; operator delete EXTRN ??_U@YAPAXI@Z:PROC ; operator new[] EXTRN ??_V@YAXPAX@Z:PROC ; operator delete[] EXTRN ??_V@YAXPAXI@Z:PROC ; operator delete[] EXTRN __invalid_parameter_noinfo:PROC EXTRN __errno:PROC EXTRN _rand:PROC EXTRN ___stdio_common_vswprintf:PROC EXTRN _memcpy:PROC EXTRN _memmove:PROC EXTRN _memset:PROC EXTRN _wcslen:PROC EXTRN _wmemcpy_s:PROC EXTRN __imp__Sleep@4:PROC EXTRN __imp__GetTickCount@0:PROC EXTRN __imp__LoadResource@8:PROC EXTRN __imp__LockResource@4:PROC EXTRN __imp__SizeofResource@8:PROC EXTRN __imp__FindResourceW@12:PROC EXTRN ?AfxThrowMemoryException@@YGXXZ:PROC ; AfxThrowMemoryException EXTRN ?AfxThrowInvalidArgException@@YGXXZ:PROC ; AfxThrowInvalidArgException EXTRN ?AfxThrowOleException@@YGXJ@Z:PROC ; AfxThrowOleException EXTRN ?AfxFindStringResourceHandle@@YGPAUHINSTANCE__@@I@Z:PROC ; AfxFindStringResourceHandle EXTRN __imp__closesocket@4:PROC EXTRN ?AfxGetStringManager@@YGPAUIAtlStringMgr@ATL@@XZ:PROC ; AfxGetStringManager EXTRN ?AfxIsValidAddress@@YGHPBXIH@Z:PROC ; AfxIsValidAddress EXTRN ??0CSAStatusLog@@QAE@XZ:PROC ; CSAStatusLog::CSAStatusLog EXTRN ??1CSAStatusLog@@QAE@XZ:PROC ; CSAStatusLog::~CSAStatusLog EXTRN ?Init@CSAStatusLog@@QAEXV?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@0@Z:PROC ; CSAStatusLog::Init EXTRN ?LogError@CSAStatusLog@@QAEHPB_WPBD1J@Z:PROC ; CSAStatusLog::LogError EXTRN ??0CAdoConnection@@QAE@XZ:PROC ; CAdoConnection::CAdoConnection EXTRN ??1CAdoConnection@@UAE@XZ:PROC ; CAdoConnection::~CAdoConnection EXTRN ?isOK@CAdoConnection@@QAEHXZ:PROC ; CAdoConnection::isOK EXTRN ??_ECKeyList@@UAEPAXI@Z:PROC ; CKeyList::`vector deleting destructor' EXTRN ?RefreshLogin@CSmsCenterDlg@@QAEXXZ:PROC ; CSmsCenterDlg::RefreshLogin EXTRN ?AddLog@CSmsCenterDlg@@QAEXPB_WJ@Z:PROC ; CSmsCenterDlg::AddLog EXTRN @__security_check_cookie@4:PROC EXTRN ___CxxFrameHandler3:PROC EXTRN __chkstk:PROC EXTRN _memset:PROC EXTRN ??_7type_info@@6B@:QWORD ; type_info::`vftable' EXTRN ___security_cookie:DWORD ; COMDAT ?_OptionsStorage@?1??__local_stdio_printf_options@@9@4_KA _BSS SEGMENT ?_OptionsStorage@?1??__local_stdio_printf_options@@9@4_KA DQ 01H DUP (?) ; `__local_stdio_printf_options'::`2'::_OptionsStorage _BSS ENDS ; COMDAT ??_R1A@?0A@EA@CKeyList@@8 rdata$r SEGMENT ??_R1A@?0A@EA@CKeyList@@8 DD FLAT:??_R0?AVCKeyList@@@8 ; CKeyList::`RTTI Base Class Descriptor at (0,-1,0,64)' DD 00H DD 00H DD 0ffffffffH DD 00H DD 040H DD FLAT:??_R3CKeyList@@8 rdata$r ENDS ; COMDAT ??_R2CKeyList@@8 rdata$r SEGMENT ??_R2CKeyList@@8 DD FLAT:??_R1A@?0A@EA@CKeyList@@8 ; CKeyList::`RTTI Base Class Array' rdata$r ENDS ; COMDAT ??_R3CKeyList@@8 rdata$r SEGMENT ??_R3CKeyList@@8 DD 00H ; CKeyList::`RTTI Class Hierarchy Descriptor' DD 00H DD 01H DD FLAT:??_R2CKeyList@@8 rdata$r ENDS ; COMDAT ??_R0?AVCKeyList@@@8 data$rs SEGMENT ??_R0?AVCKeyList@@@8 DD FLAT:??_7type_info@@6B@ ; CKeyList `RTTI Type Descriptor' DD 00H DB '.?AVCKeyList@@', 00H data$rs ENDS ; COMDAT ??_R4CKeyList@@6B@ rdata$r SEGMENT ??_R4CKeyList@@6B@ DD 00H ; CKeyList::`RTTI Complete Object Locator' DD 00H DD 00H DD FLAT:??_R0?AVCKeyList@@@8 DD FLAT:??_R3CKeyList@@8 rdata$r ENDS ; COMDAT ??_C@_05LGELBCGM@Close@ CONST SEGMENT ??_C@_05LGELBCGM@Close@ DB 'Close', 00H ; `string' CONST ENDS ; COMDAT ?__LINE__Var@?0??Close@CKeyList@@QAEXXZ@4JA _DATA SEGMENT ?__LINE__Var@?0??Close@CKeyList@@QAEXXZ@4JA DD 0133H ; `CKeyList::Close'::`1'::__LINE__Var _DATA ENDS ; COMDAT ??_C@_0BB@NCGHDNPI@GetBlank_Process@ CONST SEGMENT ??_C@_0BB@NCGHDNPI@GetBlank_Process@ DB 'GetBlank_Process', 00H ; `string' CONST ENDS ; COMDAT ?__LINE__Var@?0??GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ@4JA _DATA SEGMENT ?__LINE__Var@?0??GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ@4JA DD 0f4H ; `CKeyList::GetBlank_Process'::`1'::__LINE__Var _DATA ENDS ; COMDAT ??_C@_08EDPDCAEI@Close_IO@ CONST SEGMENT ??_C@_08EDPDCAEI@Close_IO@ DB 'Close_IO', 00H ; `string' CONST ENDS ; COMDAT ?__LINE__Var@?0??Close_IO@CKeyList@@QAEXXZ@4JA _DATA SEGMENT ?__LINE__Var@?0??Close_IO@CKeyList@@QAEXXZ@4JA DD 0a6H ; `CKeyList::Close_IO'::`1'::__LINE__Var _DATA ENDS ; COMDAT ??_C@_0M@DCAJJICO@RemoveAt_IO@ CONST SEGMENT ??_C@_0M@DCAJJICO@RemoveAt_IO@ DB 'RemoveAt_IO', 00H ; `string' CONST ENDS ; COMDAT ??_C@_1BO@IFJHDIMD@?$AA?$FL?$AA?$CF?$AAd?$AA?$FN?$AA?$CF?$AAs?$AA?9?$AA?$CF?$AAs?$AAc?$AA8?$AA?$AA?$PP?z?$AA?$CB@ CONST SEGMENT ??_C@_1BO@IFJHDIMD@?$AA?$FL?$AA?$CF?$AAd?$AA?$FN?$AA?$CF?$AAs?$AA?9?$AA?$CF?$AAs?$AAc?$AA8?$AA?$AA?$PP?z?$AA?$CB@ DB '[' DB 00H, '%', 00H, 'd', 00H, ']', 00H, '%', 00H, 's', 00H, '-', 00H DB '%', 00H, 's', 00H, 'ck8^', 00H, 090H, 0faH, 'Q!', 00H, 00H, 00H ; `string' CONST ENDS ; COMDAT ??_C@_1BO@OIFMIIBA@?$AA?$FL?$AA?$CF?$AAd?$AA?$FN?$AA?$CF?$AAs?$AA?9?$AA?$CF?$AAs?$PP?$KN?$PP?$LP?$AA?$AA?$PP?z?$AA?$CB@ CONST SEGMENT ??_C@_1BO@OIFMIIBA@?$AA?$FL?$AA?$CF?$AAd?$AA?$FN?$AA?$CF?$AAs?$AA?9?$AA?$CF?$AAs?$PP?$KN?$PP?$LP?$AA?$AA?$PP?z?$AA?$CB@ DB '[' DB 00H, '%', 00H, 'd', 00H, ']', 00H, '%', 00H, 's', 00H, '-', 00H DB '%', 00H, 's', 00H, 0adH, 'e', 0bfH, '~', 00H, 090H, 0faH, 'Q!' DB 00H, 00H, 00H ; `string' CONST ENDS ; COMDAT ?__LINE__Var@?0??RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z@4JA _DATA SEGMENT ?__LINE__Var@?0??RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z@4JA DD 081H ; `CKeyList::RemoveAt_IO'::`1'::__LINE__Var _DATA ENDS ; COMDAT ??_C@_0DB@EILGGBMO@D?3?2Works?2Corpsms_2010?2SmsCenter@ CONST SEGMENT ??_C@_0DB@EILGGBMO@D?3?2Works?2Corpsms_2010?2SmsCenter@ DB 'D:\Works\Corp' DB 'sms_2010\SmsCenter\IOCP\KeyList.cpp', 00H ; `string' CONST ENDS ; COMDAT ??_C@_0N@LNMKMNFF@RemoveAt_Key@ CONST SEGMENT ??_C@_0N@LNMKMNFF@RemoveAt_Key@ DB 'RemoveAt_Key', 00H ; `string' CONST ENDS ; COMDAT ?__LINE__Var@?0??RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z@4JA _DATA SEGMENT ?__LINE__Var@?0??RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z@4JA DD 06dH ; `CKeyList::RemoveAt_Key'::`1'::__LINE__Var _DATA ENDS ; COMDAT ??_7CKeyList@@6B@ CONST SEGMENT ??_7CKeyList@@6B@ DD FLAT:??_R4CKeyList@@6B@ ; CKeyList::`vftable' DD FLAT:??_ECKeyList@@UAEPAXI@Z CONST ENDS ; COMDAT ??_C@_13JKNELIBG@?$AAT@ CONST SEGMENT ??_C@_13JKNELIBG@?$AAT@ DB 'T', 00H, 00H, 00H ; `string' CONST ENDS ; COMDAT ??_C@_17LLLMIFAB@?$AAL?$AAo?$AAg@ CONST SEGMENT ??_C@_17LLLMIFAB@?$AAL?$AAo?$AAg@ DB 'L', 00H, 'o', 00H, 'g', 00H, 00H, 00H ; `string' CONST ENDS ; COMDAT ??_C@_1BC@HEKPCAFP@?$AAA?$AAp?$AAp?$AAE?$AAr?$AAr?$AAo?$AAr@ CONST SEGMENT ??_C@_1BC@HEKPCAFP@?$AAA?$AAp?$AAp?$AAE?$AAr?$AAr?$AAo?$AAr@ DB 'A', 00H, 'p' DB 00H, 'p', 00H, 'E', 00H, 'r', 00H, 'r', 00H, 'o', 00H, 'r', 00H DB 00H, 00H ; `string' CONST ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$??1CKeyList@@UAE@XZ DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 02fH DB 03cH voltbl ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DW 023H DW 0144H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __catchsym$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$5 DD 00H DD 00H DD 00H DD FLAT:__catch$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$0 __tryblocktable$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z DD 00H DD 00H DD 04H DD 01H DD FLAT:__catchsym$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$5 __ehfuncinfo$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z DD 019930522H DD 05H DD FLAT:__unwindtable$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z DD 01H DD FLAT:__tryblocktable$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z DD 2 DUP(00H) DD 00H DD 00H __unwindtable$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z DD 0ffffffffH DD 00H DD 0ffffffffH DD 00H DD 01H DD FLAT:__unwindfunclet$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$2 DD 02H DD FLAT:__unwindfunclet$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$3 DD 03H DD FLAT:__unwindfunclet$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$4 xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 02fH DB 03cH voltbl ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DW 023H DW 0237H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __catchsym$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$5 DD 00H DD 00H DD 00H DD FLAT:__catch$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$0 __tryblocktable$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z DD 00H DD 00H DD 04H DD 01H DD FLAT:__catchsym$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$5 __ehfuncinfo$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z DD 019930522H DD 05H DD FLAT:__unwindtable$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z DD 01H DD FLAT:__tryblocktable$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z DD 2 DUP(00H) DD 00H DD 00H __unwindtable$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z DD 0ffffffffH DD 00H DD 0ffffffffH DD 00H DD 01H DD FLAT:__unwindfunclet$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$2 DD 02H DD FLAT:__unwindfunclet$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$3 DD 03H DD FLAT:__unwindfunclet$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$4 xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 02fH DB 03cH voltbl ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DW 023H DW 0173H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __catchsym$?Close_IO@CKeyList@@QAEXXZ$5 DD 00H DD 00H DD 00H DD FLAT:__catch$?Close_IO@CKeyList@@QAEXXZ$0 __tryblocktable$?Close_IO@CKeyList@@QAEXXZ DD 00H DD 00H DD 04H DD 01H DD FLAT:__catchsym$?Close_IO@CKeyList@@QAEXXZ$5 __ehfuncinfo$?Close_IO@CKeyList@@QAEXXZ DD 019930522H DD 05H DD FLAT:__unwindtable$?Close_IO@CKeyList@@QAEXXZ DD 01H DD FLAT:__tryblocktable$?Close_IO@CKeyList@@QAEXXZ DD 2 DUP(00H) DD 00H DD 00H __unwindtable$?Close_IO@CKeyList@@QAEXXZ DD 0ffffffffH DD 00H DD 0ffffffffH DD 00H DD 01H DD FLAT:__unwindfunclet$?Close_IO@CKeyList@@QAEXXZ$2 DD 02H DD FLAT:__unwindfunclet$?Close_IO@CKeyList@@QAEXXZ$3 DD 03H DD FLAT:__unwindfunclet$?Close_IO@CKeyList@@QAEXXZ$4 xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 020H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __unwindtable$?Init@CKeyList@@QAEXPAVCSmsCenterDlg@@@Z DD 0ffffffffH DD FLAT:__unwindfunclet$?Init@CKeyList@@QAEXPAVCSmsCenterDlg@@@Z$0 __ehfuncinfo$?Init@CKeyList@@QAEXPAVCSmsCenterDlg@@@Z DD 019930522H DD 01H DD FLAT:__unwindtable$?Init@CKeyList@@QAEXPAVCSmsCenterDlg@@@Z DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 00H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 02fH DB 03cH voltbl ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 023H DB 0f5H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __catchsym$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$5 DD 00H DD 00H DD 00H DD FLAT:__catch$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$0 __tryblocktable$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ DD 00H DD 00H DD 04H DD 01H DD FLAT:__catchsym$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$5 __ehfuncinfo$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ DD 019930522H DD 05H DD FLAT:__unwindtable$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ DD 01H DD FLAT:__tryblocktable$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ DD 2 DUP(00H) DD 00H DD 00H __unwindtable$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ DD 0ffffffffH DD 00H DD 0ffffffffH DD 00H DD 01H DD FLAT:__unwindfunclet$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$2 DD 02H DD FLAT:__unwindfunclet$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$3 DD 03H DD FLAT:__unwindfunclet$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$4 xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 02fH DB 03cH voltbl ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DW 023H DW 0250H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __catchsym$?Close@CKeyList@@QAEXXZ$5 DD 00H DD 00H DD 00H DD FLAT:__catch$?Close@CKeyList@@QAEXXZ$0 __tryblocktable$?Close@CKeyList@@QAEXXZ DD 00H DD 00H DD 04H DD 01H DD FLAT:__catchsym$?Close@CKeyList@@QAEXXZ$5 __ehfuncinfo$?Close@CKeyList@@QAEXXZ DD 019930522H DD 05H DD FLAT:__unwindtable$?Close@CKeyList@@QAEXXZ DD 01H DD FLAT:__tryblocktable$?Close@CKeyList@@QAEXXZ DD 2 DUP(00H) DD 00H DD 00H __unwindtable$?Close@CKeyList@@QAEXXZ DD 0ffffffffH DD 00H DD 0ffffffffH DD 00H DD 01H DD FLAT:__unwindfunclet$?Close@CKeyList@@QAEXXZ$2 DD 02H DD FLAT:__unwindfunclet$?Close@CKeyList@@QAEXXZ$3 DD 03H DD FLAT:__unwindfunclet$?Close@CKeyList@@QAEXXZ$4 xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$??_EIOCP_SQL@@QAEPAXI@Z DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 019H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __unwindtable$??1IOCP_SQL@@QAE@XZ DD 0ffffffffH DD FLAT:__unwindfunclet$??1IOCP_SQL@@QAE@XZ$0 __ehfuncinfo$??1IOCP_SQL@@QAE@XZ DD 019930522H DD 01H DD FLAT:__unwindtable$??1IOCP_SQL@@QAE@XZ DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 019H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __unwindtable$??0IOCP_SQL@@QAE@XZ DD 0ffffffffH DD FLAT:__unwindfunclet$??0IOCP_SQL@@QAE@XZ$0 __ehfuncinfo$??0IOCP_SQL@@QAE@XZ DD 019930522H DD 01H DD FLAT:__unwindtable$??0IOCP_SQL@@QAE@XZ DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 00H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$?GetDefaultManager@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUIAtlStringMgr@ATL@@XZ DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 016H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __unwindtable$??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ DD 0ffffffffH DD FLAT:__unwindfunclet$??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ$0 __ehfuncinfo$??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ DD 019930522H DD 01H DD FLAT:__unwindtable$??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 016H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __unwindtable$??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z DD 0ffffffffH DD FLAT:__unwindfunclet$??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z$0 __ehfuncinfo$??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z DD 019930522H DD 01H DD FLAT:__unwindtable$??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 00H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; COMDAT voltbl voltbl SEGMENT _volmd DB 09H voltbl ENDS ; COMDAT xdata$x xdata$x SEGMENT __ehfuncinfo$?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z DD 019930522H DD 00H DD 00H DD 2 DUP(00H) DD 2 DUP(00H) DD 00H DD 04H xdata$x ENDS ; Function compile flags: /Odtp /ZI ; COMDAT ??_GCKeyList@@UAEPAXI@Z _TEXT SEGMENT _this$ = -4 ; size = 4 ___flags$ = 8 ; size = 4 ??_GCKeyList@@UAEPAXI@Z PROC ; CKeyList::`scalar deleting destructor', COMDAT ; _this$ = ecx 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx 0000c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0000f e8 00 00 00 00 call ??1CKeyList@@UAE@XZ ; CKeyList::~CKeyList 00014 8b 45 08 mov eax, DWORD PTR ___flags$[ebp] 00017 83 e0 01 and eax, 1 0001a 74 0e je SHORT $LN2@scalar 0001c 6a 20 push 32 ; 00000020H 0001e 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00021 50 push eax 00022 e8 00 00 00 00 call ??3@YAXPAXI@Z ; operator delete 00027 83 c4 08 add esp, 8 $LN2@scalar: 0002a 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0002d 5f pop edi 0002e 5e pop esi 0002f 5b pop ebx 00030 8b e5 mov esp, ebp 00032 5d pop ebp 00033 c2 04 00 ret 4 ??_GCKeyList@@UAEPAXI@Z ENDP ; CKeyList::`scalar deleting destructor' _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ??1CKeyList@@UAE@XZ _TEXT SEGMENT _this$ = -16 ; size = 4 __$EHRec$ = -12 ; size = 12 ??1CKeyList@@UAE@XZ PROC ; CKeyList::~CKeyList, COMDAT ; _this$ = ecx ; 32 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$??1CKeyList@@UAE@XZ 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 44 sub esp, 68 ; 00000044H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00028 89 4d f0 mov DWORD PTR _this$[ebp], ecx 0002b 8b 45 f0 mov eax, DWORD PTR _this$[ebp] 0002e c7 00 00 00 00 00 mov DWORD PTR [eax], OFFSET ??_7CKeyList@@6B@ ; 33 : Close(); 00034 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 00037 e8 00 00 00 00 call ?Close@CKeyList@@QAEXXZ ; CKeyList::Close ; 34 : } 0003c 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 0003f 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 00046 59 pop ecx 00047 5f pop edi 00048 5e pop esi 00049 5b pop ebx 0004a 8b e5 mov esp, ebp 0004c 5d pop ebp 0004d c3 ret 0 0004e cc int 3 0004f cc int 3 00050 cc int 3 00051 cc int 3 00052 cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$??1CKeyList@@UAE@XZ: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a ac mov ecx, DWORD PTR [edx-84] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$??1CKeyList@@UAE@XZ 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ??1CKeyList@@UAE@XZ ENDP ; CKeyList::~CKeyList ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ??0CKeyList@@QAE@XZ _TEXT SEGMENT _this$ = -4 ; size = 4 ??0CKeyList@@QAE@XZ PROC ; CKeyList::CKeyList, COMDAT ; _this$ = ecx ; 21 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx 0000c 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0000f c7 00 00 00 00 00 mov DWORD PTR [eax], OFFSET ??_7CKeyList@@6B@ ; 22 : m_IO = NULL; 00015 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00018 c7 40 0c 00 00 00 00 mov DWORD PTR [eax+12], 0 ; 23 : m_Key = NULL; 0001f 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00022 c7 40 04 00 00 00 00 mov DWORD PTR [eax+4], 0 ; 24 : m_Process = NULL; 00029 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0002c c7 40 18 00 00 00 00 mov DWORD PTR [eax+24], 0 ; 25 : m_SQL = NULL; 00033 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00036 c7 40 14 00 00 00 00 mov DWORD PTR [eax+20], 0 ; 26 : m_IOIndex = 0; 0003d 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00040 c7 40 10 00 00 00 00 mov DWORD PTR [eax+16], 0 ; 27 : m_KeyIndex = 0; 00047 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0004a c7 40 08 00 00 00 00 mov DWORD PTR [eax+8], 0 ; 28 : m_Process = 0; 00051 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00054 c7 40 18 00 00 00 00 mov DWORD PTR [eax+24], 0 ; 29 : } 0005b 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0005e 5f pop edi 0005f 5e pop esi 00060 5b pop ebx 00061 8b e5 mov esp, ebp 00063 5d pop ebp 00064 c3 ret 0 ??0CKeyList@@QAE@XZ ENDP ; CKeyList::CKeyList _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?GetBlank_Key@CKeyList@@QAEPAUIOCP_KEY@@XZ _TEXT SEGMENT tv159 = -76 ; size = 4 tv93 = -76 ; size = 4 _i$1 = -8 ; size = 4 _this$ = -4 ; size = 4 ?GetBlank_Key@CKeyList@@QAEPAUIOCP_KEY@@XZ PROC ; CKeyList::GetBlank_Key, COMDAT ; _this$ = ecx ; 37 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 4c sub esp, 76 ; 0000004cH 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 38 : //从尾部找空闲的Key ; 39 : for ( int i=m_KeyIndex ; i=MAX_LOGINUSER ) 00063 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00066 81 78 08 c8 00 00 00 cmp DWORD PTR [eax+8], 200 ; 000000c8H 0006d 7c 0a jl SHORT $LN10@GetBlank_K ; 46 : m_KeyIndex = 0; 0006f 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00072 c7 40 08 00 00 00 00 mov DWORD PTR [eax+8], 0 $LN10@GetBlank_K: ; 47 : m_Key[i].lRandID = rand(); 00079 e8 00 00 00 00 call _rand 0007e 89 45 b4 mov DWORD PTR tv93[ebp], eax 00081 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00084 8b 48 04 mov ecx, DWORD PTR [eax+4] 00087 8b 55 f8 mov edx, DWORD PTR _i$1[ebp] 0008a 8b 45 b4 mov eax, DWORD PTR tv93[ebp] 0008d 89 44 d1 04 mov DWORD PTR [ecx+edx*8+4], eax ; 48 : return &m_Key[i]; 00091 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00094 8b 48 04 mov ecx, DWORD PTR [eax+4] 00097 8b 55 f8 mov edx, DWORD PTR _i$1[ebp] 0009a 8d 04 d1 lea eax, DWORD PTR [ecx+edx*8] 0009d e9 ac 00 00 00 jmp $LN1@GetBlank_K $LN8@GetBlank_K: ; 49 : } ; 50 : } 000a2 e9 70 ff ff ff jmp $LN2@GetBlank_K $LN3@GetBlank_K: ; 51 : ; 52 : //从头部找空闲的Key ; 53 : for ( i=0 ; i=MAX_LOGINUSER ) 0010b 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0010e 81 78 08 c8 00 00 00 cmp DWORD PTR [eax+8], 200 ; 000000c8H 00115 7c 0a jl SHORT $LN13@GetBlank_K ; 60 : m_KeyIndex = 0; 00117 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0011a c7 40 08 00 00 00 00 mov DWORD PTR [eax+8], 0 $LN13@GetBlank_K: ; 61 : m_Key[i].lRandID = rand(); 00121 e8 00 00 00 00 call _rand 00126 89 45 b4 mov DWORD PTR tv159[ebp], eax 00129 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0012c 8b 48 04 mov ecx, DWORD PTR [eax+4] 0012f 8b 55 f8 mov edx, DWORD PTR _i$1[ebp] 00132 8b 45 b4 mov eax, DWORD PTR tv159[ebp] 00135 89 44 d1 04 mov DWORD PTR [ecx+edx*8+4], eax ; 62 : return &m_Key[i]; 00139 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0013c 8b 48 04 mov ecx, DWORD PTR [eax+4] 0013f 8b 55 f8 mov edx, DWORD PTR _i$1[ebp] 00142 8d 04 d1 lea eax, DWORD PTR [ecx+edx*8] 00145 eb 07 jmp SHORT $LN1@GetBlank_K $LN11@GetBlank_K: ; 63 : } ; 64 : } 00147 e9 64 ff ff ff jmp $LN5@GetBlank_K $LN6@GetBlank_K: ; 65 : return NULL; 0014c 33 c0 xor eax, eax $LN1@GetBlank_K: ; 66 : } 0014e 5f pop edi 0014f 5e pop esi 00150 5b pop ebx 00151 8b e5 mov esp, ebp 00153 5d pop ebp 00154 c3 ret 0 ?GetBlank_Key@CKeyList@@QAEPAUIOCP_KEY@@XZ ENDP ; CKeyList::GetBlank_Key _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?GetBlank_IO@CKeyList@@QAEPAUIOCP_IO@@XZ _TEXT SEGMENT tv175 = -76 ; size = 4 tv93 = -76 ; size = 4 _i$1 = -8 ; size = 4 _this$ = -4 ; size = 4 ?GetBlank_IO@CKeyList@@QAEPAUIOCP_IO@@XZ PROC ; CKeyList::GetBlank_IO, COMDAT ; _this$ = ecx ; 69 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 4c sub esp, 76 ; 0000004cH 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 70 : //从尾部找空闲的IO ; 71 : for ( int i=m_IOIndex ; i=MAX_LOGINUSER ) 0007d 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00080 81 78 10 c8 00 00 00 cmp DWORD PTR [eax+16], 200 ; 000000c8H 00087 7c 0a jl SHORT $LN10@GetBlank_I ; 78 : m_IOIndex = 0; 00089 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0008c c7 40 10 00 00 00 00 mov DWORD PTR [eax+16], 0 $LN10@GetBlank_I: ; 79 : m_IO[i].lRandID = rand(); 00093 e8 00 00 00 00 call _rand 00098 89 45 b4 mov DWORD PTR tv93[ebp], eax 0009b 69 45 f8 b0 df 06 00 imul eax, DWORD PTR _i$1[ebp], 450480 000a2 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 000a5 8b 51 0c mov edx, DWORD PTR [ecx+12] 000a8 8b 4d b4 mov ecx, DWORD PTR tv93[ebp] 000ab 89 4c 02 20 mov DWORD PTR [edx+eax+32], ecx ; 80 : // m_IO[i].IOS.lRandID=m_IO[i].lRandID; ; 81 : ; 82 : m_IO[i].m_bCheckup = true; 000af 69 45 f8 b0 df 06 00 imul eax, DWORD PTR _i$1[ebp], 450480 000b6 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 000b9 8b 51 0c mov edx, DWORD PTR [ecx+12] 000bc c7 84 02 b4 01 00 00 01 00 00 00 mov DWORD PTR [edx+eax+436], 1 ; 83 : m_IO[i].m_bCompress = SENDDATA_COMPRESS; //发送数据时是否压缩 000c7 69 45 f8 b0 df 06 00 imul eax, DWORD PTR _i$1[ebp], 450480 000ce 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 000d1 8b 51 0c mov edx, DWORD PTR [ecx+12] 000d4 c7 84 02 b8 01 00 00 00 00 00 00 mov DWORD PTR [edx+eax+440], 0 ; 84 : m_IO[i].m_lAgentID =-100; //代理商ID (默认为-100,未知代理商) 000df 69 45 f8 b0 df 06 00 imul eax, DWORD PTR _i$1[ebp], 450480 000e6 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 000e9 8b 51 0c mov edx, DWORD PTR [ecx+12] 000ec c7 84 02 98 01 00 00 9c ff ff ff mov DWORD PTR [edx+eax+408], -100 ; ffffff9cH ; 85 : m_IO[i].m_lAgentType=-100; //代理商类型(默认为-100,未知代理商类型) 000f7 69 45 f8 b0 df 06 00 imul eax, DWORD PTR _i$1[ebp], 450480 000fe 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00101 8b 51 0c mov edx, DWORD PTR [ecx+12] 00104 c7 84 02 a0 01 00 00 9c ff ff ff mov DWORD PTR [edx+eax+416], -100 ; ffffff9cH ; 86 : ; 87 : return &m_IO[i]; 0010f 69 45 f8 b0 df 06 00 imul eax, DWORD PTR _i$1[ebp], 450480 00116 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00119 03 41 0c add eax, DWORD PTR [ecx+12] 0011c e9 c3 00 00 00 jmp $LN1@GetBlank_I $LN8@GetBlank_I: ; 88 : } ; 89 : } 00121 e9 f1 fe ff ff jmp $LN2@GetBlank_I $LN3@GetBlank_I: ; 90 : ; 91 : //从头部找空闲的IO ; 92 : for ( i=0 ; i=MAX_LOGINUSER ) 0019c 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0019f 81 78 10 c8 00 00 00 cmp DWORD PTR [eax+16], 200 ; 000000c8H 001a6 7c 0a jl SHORT $LN13@GetBlank_I ; 99 : m_IOIndex = 0; 001a8 8b 45 fc mov eax, DWORD PTR _this$[ebp] 001ab c7 40 10 00 00 00 00 mov DWORD PTR [eax+16], 0 $LN13@GetBlank_I: ; 100 : m_IO[i].lRandID = rand(); 001b2 e8 00 00 00 00 call _rand 001b7 89 45 b4 mov DWORD PTR tv175[ebp], eax 001ba 69 45 f8 b0 df 06 00 imul eax, DWORD PTR _i$1[ebp], 450480 001c1 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 001c4 8b 51 0c mov edx, DWORD PTR [ecx+12] 001c7 8b 4d b4 mov ecx, DWORD PTR tv175[ebp] 001ca 89 4c 02 20 mov DWORD PTR [edx+eax+32], ecx ; 101 : // m_IO[i].IOS.lRandID=m_IO[i].lRandID; ; 102 : return &m_IO[i]; 001ce 69 45 f8 b0 df 06 00 imul eax, DWORD PTR _i$1[ebp], 450480 001d5 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 001d8 03 41 0c add eax, DWORD PTR [ecx+12] 001db eb 07 jmp SHORT $LN1@GetBlank_I $LN11@GetBlank_I: ; 103 : } ; 104 : } 001dd e9 4d ff ff ff jmp $LN5@GetBlank_I $LN6@GetBlank_I: ; 105 : return NULL; 001e2 33 c0 xor eax, eax $LN1@GetBlank_I: ; 106 : } 001e4 5f pop edi 001e5 5e pop esi 001e6 5b pop ebx 001e7 8b e5 mov esp, ebp 001e9 5d pop ebp 001ea c3 ret 0 ?GetBlank_IO@CKeyList@@QAEPAUIOCP_IO@@XZ ENDP ; CKeyList::GetBlank_IO _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z _TEXT SEGMENT tv151 = -6612 ; size = 4 tv76 = -6608 ; size = 4 $T2 = -6604 ; size = 4 $T3 = -6600 ; size = 4 _i$4 = -6084 ; size = 4 _NXlog$5 = -6080 ; size = 6056 _this$ = -24 ; size = 4 __$ArrayPad$ = -20 ; size = 4 __$EHRec$ = -16 ; size = 16 _pKey$ = 8 ; size = 4 ?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z PROC ; CKeyList::RemoveAt_Key, COMDAT ; _this$ = ecx ; 109 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 51 push ecx 00012 b8 c4 19 00 00 mov eax, 6596 ; 000019c4H 00017 e8 00 00 00 00 call __chkstk 0001c a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 00021 33 c5 xor eax, ebp 00023 89 45 ec mov DWORD PTR __$ArrayPad$[ebp], eax 00026 53 push ebx 00027 56 push esi 00028 57 push edi 00029 50 push eax 0002a 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp+4] 0002d 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00033 89 65 f0 mov DWORD PTR __$EHRec$[ebp], esp 00036 89 4d e8 mov DWORD PTR _this$[ebp], ecx ; 110 : try 00039 c7 45 fc 00 00 00 00 mov DWORD PTR __$EHRec$[ebp+12], 0 ; 111 : { ; 112 : if ( pKey ) 00040 83 7d 08 00 cmp DWORD PTR _pKey$[ebp], 0 00044 74 41 je SHORT $LN3@RemoveAt_K ; 113 : { ; 114 : if ( pKey< &m_Key[0] || pKey>&m_Key[MAX_LOGINUSER] ) 00046 b8 08 00 00 00 mov eax, 8 0004b 6b c8 00 imul ecx, eax, 0 0004e 8b 55 e8 mov edx, DWORD PTR _this$[ebp] 00051 03 4a 04 add ecx, DWORD PTR [edx+4] 00054 39 4d 08 cmp DWORD PTR _pKey$[ebp], ecx 00057 72 16 jb SHORT $LN5@RemoveAt_K 00059 b8 08 00 00 00 mov eax, 8 0005e 69 c8 c8 00 00 00 imul ecx, eax, 200 00064 8b 55 e8 mov edx, DWORD PTR _this$[ebp] 00067 03 4a 04 add ecx, DWORD PTR [edx+4] 0006a 39 4d 08 cmp DWORD PTR _pKey$[ebp], ecx 0006d 76 05 jbe SHORT $LN4@RemoveAt_K $LN5@RemoveAt_K: ; 115 : return ; 0006f e9 c2 00 00 00 jmp $LN1@RemoveAt_K $LN4@RemoveAt_K: ; 116 : ; 117 : //closesocket(pKey->socket); ; 118 : pKey->socket = 0; 00074 8b 45 08 mov eax, DWORD PTR _pKey$[ebp] 00077 c7 00 00 00 00 00 mov DWORD PTR [eax], 0 ; 119 : pKey->lRandID = 0; 0007d 8b 45 08 mov eax, DWORD PTR _pKey$[ebp] 00080 c7 40 04 00 00 00 00 mov DWORD PTR [eax+4], 0 $LN3@RemoveAt_K: ; 120 : } ; 121 : }catch(...) 00087 e9 9a 00 00 00 jmp $LN7@RemoveAt_K __catch$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$0: ; 122 : { ; 123 : LOG_APPERROR(_T("T")); 0008c 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 00092 e8 00 00 00 00 call ??0CSAStatusLog@@QAE@XZ ; CSAStatusLog::CSAStatusLog 00097 c6 45 fc 02 mov BYTE PTR __$EHRec$[ebp+12], 2 0009b 51 push ecx 0009c 8b cc mov ecx, esp 0009e 89 a5 38 e6 ff ff mov DWORD PTR $T3[ebp], esp 000a4 68 00 00 00 00 push OFFSET ??_C@_1BC@HEKPCAFP@?$AAA?$AAp?$AAp?$AAE?$AAr?$AAr?$AAo?$AAr@ 000a9 e8 00 00 00 00 call ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > 000ae 89 85 30 e6 ff ff mov DWORD PTR tv76[ebp], eax 000b4 c6 45 fc 03 mov BYTE PTR __$EHRec$[ebp+12], 3 000b8 51 push ecx 000b9 8b cc mov ecx, esp 000bb 89 a5 34 e6 ff ff mov DWORD PTR $T2[ebp], esp 000c1 68 00 00 00 00 push OFFSET ??_C@_17LLLMIFAB@?$AAL?$AAo?$AAg@ 000c6 e8 00 00 00 00 call ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > 000cb 89 85 2c e6 ff ff mov DWORD PTR tv151[ebp], eax 000d1 c6 45 fc 04 mov BYTE PTR __$EHRec$[ebp+12], 4 000d5 c6 45 fc 02 mov BYTE PTR __$EHRec$[ebp+12], 2 000d9 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 000df e8 00 00 00 00 call ?Init@CSAStatusLog@@QAEXV?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@0@Z ; CSAStatusLog::Init 000e4 a1 00 00 00 00 mov eax, DWORD PTR ?__LINE__Var@?0??RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z@4JA 000e9 83 c0 0e add eax, 14 ; 0000000eH 000ec 50 push eax 000ed 68 00 00 00 00 push OFFSET ??_C@_0N@LNMKMNFF@RemoveAt_Key@ 000f2 68 00 00 00 00 push OFFSET ??_C@_0DB@EILGGBMO@D?3?2Works?2Corpsms_2010?2SmsCenter@ 000f7 68 00 00 00 00 push OFFSET ??_C@_13JKNELIBG@?$AAT@ 000fc 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 00102 e8 00 00 00 00 call ?LogError@CSAStatusLog@@QAEHPB_WPBD1J@Z ; CSAStatusLog::LogError 00107 c6 45 fc 01 mov BYTE PTR __$EHRec$[ebp+12], 1 0010b 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 00111 e8 00 00 00 00 call ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog ; 124 : int i=0; 00116 c7 85 3c e8 ff ff 00 00 00 00 mov DWORD PTR _i$4[ebp], 0 ; 125 : } 00120 b8 00 00 00 00 mov eax, $LN13@RemoveAt_K 00125 c3 ret 0 $LN7@RemoveAt_K: 00126 c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 0012d eb 07 jmp SHORT $LN1@RemoveAt_K $LN13@RemoveAt_K: 0012f c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 $LN1@RemoveAt_K: ; 126 : } 00136 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp+4] 00139 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 00140 59 pop ecx 00141 5f pop edi 00142 5e pop esi 00143 5b pop ebx 00144 8b 4d ec mov ecx, DWORD PTR __$ArrayPad$[ebp] 00147 33 cd xor ecx, ebp 00149 e8 00 00 00 00 call @__security_check_cookie@4 0014e 8b e5 mov esp, ebp 00150 5d pop ebp 00151 c2 04 00 ret 4 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __unwindfunclet$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$2: 00000 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 00006 e9 00 00 00 00 jmp ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog __unwindfunclet$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$3: 0000b 8b 8d 38 e6 ff ff mov ecx, DWORD PTR $T3[ebp] 00011 e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > __unwindfunclet$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z$4: 00016 8b 8d 34 e6 ff ff mov ecx, DWORD PTR $T2[ebp] 0001c e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > 00021 cc int 3 00022 cc int 3 00023 cc int 3 00024 cc int 3 00025 cc int 3 __ehhandler$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z: 00026 90 npad 1 00027 90 npad 1 00028 8b 54 24 08 mov edx, DWORD PTR [esp+8] 0002c 8d 42 0c lea eax, DWORD PTR [edx+12] 0002f 8b 8a 28 e6 ff ff mov ecx, DWORD PTR [edx-6616] 00035 33 c8 xor ecx, eax 00037 e8 00 00 00 00 call @__security_check_cookie@4 0003c 8b 4a f8 mov ecx, DWORD PTR [edx-8] 0003f 33 c8 xor ecx, eax 00041 e8 00 00 00 00 call @__security_check_cookie@4 00046 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z 0004b e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?RemoveAt_Key@CKeyList@@QAEXPAUIOCP_KEY@@@Z ENDP ; CKeyList::RemoveAt_Key ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z _TEXT SEGMENT tv192 = -7124 ; size = 4 tv149 = -7120 ; size = 4 tv142 = -7120 ; size = 4 $T2 = -7116 ; size = 4 $T3 = -7112 ; size = 4 _i$4 = -6596 ; size = 4 _NXlog$5 = -6592 ; size = 6056 _szMsg$6 = -536 ; size = 512 _this$ = -24 ; size = 4 __$ArrayPad$ = -20 ; size = 4 __$EHRec$ = -16 ; size = 16 _pIO$ = 8 ; size = 4 ?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z PROC ; CKeyList::RemoveAt_IO, COMDAT ; _this$ = ecx ; 129 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 51 push ecx 00012 b8 c4 1b 00 00 mov eax, 7108 ; 00001bc4H 00017 e8 00 00 00 00 call __chkstk 0001c a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 00021 33 c5 xor eax, ebp 00023 89 45 ec mov DWORD PTR __$ArrayPad$[ebp], eax 00026 53 push ebx 00027 56 push esi 00028 57 push edi 00029 50 push eax 0002a 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp+4] 0002d 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00033 89 65 f0 mov DWORD PTR __$EHRec$[ebp], esp 00036 89 4d e8 mov DWORD PTR _this$[ebp], ecx ; 130 : try 00039 c7 45 fc 00 00 00 00 mov DWORD PTR __$EHRec$[ebp+12], 0 ; 131 : { ; 132 : if ( pIO ) 00040 83 7d 08 00 cmp DWORD PTR _pIO$[ebp], 0 00044 0f 84 30 01 00 00 je $LN3@RemoveAt_I ; 133 : { ; 134 : if ( pIO< &m_IO[0] || pIO>&m_IO[MAX_LOGINUSER] ) 0004a b8 b0 df 06 00 mov eax, 450480 ; 0006dfb0H 0004f 6b c8 00 imul ecx, eax, 0 00052 8b 55 e8 mov edx, DWORD PTR _this$[ebp] 00055 03 4a 0c add ecx, DWORD PTR [edx+12] 00058 39 4d 08 cmp DWORD PTR _pIO$[ebp], ecx 0005b 72 16 jb SHORT $LN5@RemoveAt_I 0005d b8 b0 df 06 00 mov eax, 450480 ; 0006dfb0H 00062 69 c8 c8 00 00 00 imul ecx, eax, 200 00068 8b 55 e8 mov edx, DWORD PTR _this$[ebp] 0006b 03 4a 0c add ecx, DWORD PTR [edx+12] 0006e 39 4d 08 cmp DWORD PTR _pIO$[ebp], ecx 00071 76 05 jbe SHORT $LN4@RemoveAt_I $LN5@RemoveAt_I: ; 135 : return ; 00073 e9 b1 01 00 00 jmp $LN1@RemoveAt_I $LN4@RemoveAt_I: ; 136 : ; 137 : pIO->socket = 0; 00078 8b 45 08 mov eax, DWORD PTR _pIO$[ebp] 0007b c7 40 14 00 00 00 00 mov DWORD PTR [eax+20], 0 ; 138 : pIO->lRandID= 0; 00082 8b 45 08 mov eax, DWORD PTR _pIO$[ebp] 00085 c7 40 20 00 00 00 00 mov DWORD PTR [eax+32], 0 ; 139 : // pIO->IOS.lRandID = 0; ; 140 : ; 141 : if ( pIO->m_lUserID>0 ) 0008c 8b 45 08 mov eax, DWORD PTR _pIO$[ebp] 0008f 83 b8 94 01 00 00 00 cmp DWORD PTR [eax+404], 0 00096 0f 8e cb 00 00 00 jle $LN6@RemoveAt_I ; 142 : { ; 143 : TCHAR szMsg[256]={0}; 0009c 68 00 02 00 00 push 512 ; 00000200H 000a1 6a 00 push 0 000a3 8d 85 e8 fd ff ff lea eax, DWORD PTR _szMsg$6[ebp] 000a9 50 push eax 000aa e8 00 00 00 00 call _memset 000af 83 c4 0c add esp, 12 ; 0000000cH ; 144 : //退出 ; 145 : if ( pIO->m_lID==199992 ) //正常退出 000b2 8b 45 08 mov eax, DWORD PTR _pIO$[ebp] 000b5 81 b8 c8 01 00 00 38 0d 03 00 cmp DWORD PTR [eax+456], 199992 ; 00030d38H 000bf 75 30 jne SHORT $LN7@RemoveAt_I ; 146 : _stprintf( szMsg , _T("[%d]%s-%s断线退出!") , pIO->m_lLocalPort,pIO->m_szCorpName,pIO->m_szLoginName); 000c1 8b 45 08 mov eax, DWORD PTR _pIO$[ebp] 000c4 05 48 01 00 00 add eax, 328 ; 00000148H 000c9 50 push eax 000ca 8b 4d 08 mov ecx, DWORD PTR _pIO$[ebp] 000cd 81 c1 88 00 00 00 add ecx, 136 ; 00000088H 000d3 51 push ecx 000d4 8b 55 08 mov edx, DWORD PTR _pIO$[ebp] 000d7 8b 42 74 mov eax, DWORD PTR [edx+116] 000da 50 push eax 000db 68 00 00 00 00 push OFFSET ??_C@_1BO@OIFMIIBA@?$AA?$FL?$AA?$CF?$AAd?$AA?$FN?$AA?$CF?$AAs?$AA?9?$AA?$CF?$AAs?$PP?$KN?$PP?$LP?$AA?$AA?$PP?z?$AA?$CB@ 000e0 8d 8d e8 fd ff ff lea ecx, DWORD PTR _szMsg$6[ebp] 000e6 51 push ecx 000e7 e8 00 00 00 00 call __swprintf 000ec 83 c4 14 add esp, 20 ; 00000014H 000ef eb 2e jmp SHORT $LN8@RemoveAt_I $LN7@RemoveAt_I: ; 147 : else ; 148 : _stprintf( szMsg , _T("[%d]%s-%s正常退出!") , pIO->m_lLocalPort,pIO->m_szCorpName,pIO->m_szLoginName); 000f1 8b 45 08 mov eax, DWORD PTR _pIO$[ebp] 000f4 05 48 01 00 00 add eax, 328 ; 00000148H 000f9 50 push eax 000fa 8b 4d 08 mov ecx, DWORD PTR _pIO$[ebp] 000fd 81 c1 88 00 00 00 add ecx, 136 ; 00000088H 00103 51 push ecx 00104 8b 55 08 mov edx, DWORD PTR _pIO$[ebp] 00107 8b 42 74 mov eax, DWORD PTR [edx+116] 0010a 50 push eax 0010b 68 00 00 00 00 push OFFSET ??_C@_1BO@IFJHDIMD@?$AA?$FL?$AA?$CF?$AAd?$AA?$FN?$AA?$CF?$AAs?$AA?9?$AA?$CF?$AAs?$AAc?$AA8?$AA?$AA?$PP?z?$AA?$CB@ 00110 8d 8d e8 fd ff ff lea ecx, DWORD PTR _szMsg$6[ebp] 00116 51 push ecx 00117 e8 00 00 00 00 call __swprintf 0011c 83 c4 14 add esp, 20 ; 00000014H $LN8@RemoveAt_I: ; 149 : if ( AfxIsValidAddress(&m_pDlg->m_Setup,sizeof(m_pDlg->m_Setup),true) ) 0011f 6a 01 push 1 00121 68 c0 0e 00 00 push 3776 ; 00000ec0H 00126 8b 45 e8 mov eax, DWORD PTR _this$[ebp] 00129 8b 48 1c mov ecx, DWORD PTR [eax+28] 0012c 81 c1 50 03 00 00 add ecx, 848 ; 00000350H 00132 51 push ecx 00133 e8 00 00 00 00 call ?AfxIsValidAddress@@YGHPBXIH@Z ; AfxIsValidAddress 00138 85 c0 test eax, eax 0013a 74 2b je SHORT $LN6@RemoveAt_I ; 150 : { ; 151 : m_pDlg->AddLog( szMsg ); 0013c 8b 45 e8 mov eax, DWORD PTR _this$[ebp] 0013f 8b 48 1c mov ecx, DWORD PTR [eax+28] 00142 89 8d 30 e4 ff ff mov DWORD PTR tv142[ebp], ecx 00148 6a 00 push 0 0014a 8d 95 e8 fd ff ff lea edx, DWORD PTR _szMsg$6[ebp] 00150 52 push edx 00151 8b 8d 30 e4 ff ff mov ecx, DWORD PTR tv142[ebp] 00157 e8 00 00 00 00 call ?AddLog@CSmsCenterDlg@@QAEXPB_WJ@Z ; CSmsCenterDlg::AddLog ; 152 : m_pDlg->RefreshLogin(); 0015c 8b 45 e8 mov eax, DWORD PTR _this$[ebp] 0015f 8b 48 1c mov ecx, DWORD PTR [eax+28] 00162 e8 00 00 00 00 call ?RefreshLogin@CSmsCenterDlg@@QAEXXZ ; CSmsCenterDlg::RefreshLogin $LN6@RemoveAt_I: ; 153 : } ; 154 : } ; 155 : memset(pIO,0,sizeof(IOCP_IO)); 00167 68 b0 df 06 00 push 450480 ; 0006dfb0H 0016c 6a 00 push 0 0016e 8b 45 08 mov eax, DWORD PTR _pIO$[ebp] 00171 50 push eax 00172 e8 00 00 00 00 call _memset 00177 83 c4 0c add esp, 12 ; 0000000cH $LN3@RemoveAt_I: ; 156 : ; 157 : } ; 158 : }catch(...) 0017a e9 9a 00 00 00 jmp $LN11@RemoveAt_I __catch$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$0: ; 159 : { ; 160 : LOG_APPERROR(_T("T")); 0017f 8d 8d 40 e6 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 00185 e8 00 00 00 00 call ??0CSAStatusLog@@QAE@XZ ; CSAStatusLog::CSAStatusLog 0018a c6 45 fc 02 mov BYTE PTR __$EHRec$[ebp+12], 2 0018e 51 push ecx 0018f 8b cc mov ecx, esp 00191 89 a5 38 e4 ff ff mov DWORD PTR $T3[ebp], esp 00197 68 00 00 00 00 push OFFSET ??_C@_1BC@HEKPCAFP@?$AAA?$AAp?$AAp?$AAE?$AAr?$AAr?$AAo?$AAr@ 0019c e8 00 00 00 00 call ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > 001a1 89 85 30 e4 ff ff mov DWORD PTR tv149[ebp], eax 001a7 c6 45 fc 03 mov BYTE PTR __$EHRec$[ebp+12], 3 001ab 51 push ecx 001ac 8b cc mov ecx, esp 001ae 89 a5 34 e4 ff ff mov DWORD PTR $T2[ebp], esp 001b4 68 00 00 00 00 push OFFSET ??_C@_17LLLMIFAB@?$AAL?$AAo?$AAg@ 001b9 e8 00 00 00 00 call ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > 001be 89 85 2c e4 ff ff mov DWORD PTR tv192[ebp], eax 001c4 c6 45 fc 04 mov BYTE PTR __$EHRec$[ebp+12], 4 001c8 c6 45 fc 02 mov BYTE PTR __$EHRec$[ebp+12], 2 001cc 8d 8d 40 e6 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 001d2 e8 00 00 00 00 call ?Init@CSAStatusLog@@QAEXV?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@0@Z ; CSAStatusLog::Init 001d7 a1 00 00 00 00 mov eax, DWORD PTR ?__LINE__Var@?0??RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z@4JA 001dc 83 c0 1f add eax, 31 ; 0000001fH 001df 50 push eax 001e0 68 00 00 00 00 push OFFSET ??_C@_0M@DCAJJICO@RemoveAt_IO@ 001e5 68 00 00 00 00 push OFFSET ??_C@_0DB@EILGGBMO@D?3?2Works?2Corpsms_2010?2SmsCenter@ 001ea 68 00 00 00 00 push OFFSET ??_C@_13JKNELIBG@?$AAT@ 001ef 8d 8d 40 e6 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 001f5 e8 00 00 00 00 call ?LogError@CSAStatusLog@@QAEHPB_WPBD1J@Z ; CSAStatusLog::LogError 001fa c6 45 fc 01 mov BYTE PTR __$EHRec$[ebp+12], 1 001fe 8d 8d 40 e6 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 00204 e8 00 00 00 00 call ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog ; 161 : int i=0; 00209 c7 85 3c e6 ff ff 00 00 00 00 mov DWORD PTR _i$4[ebp], 0 ; 162 : } 00213 b8 00 00 00 00 mov eax, $LN17@RemoveAt_I 00218 c3 ret 0 $LN11@RemoveAt_I: 00219 c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 00220 eb 07 jmp SHORT $LN1@RemoveAt_I $LN17@RemoveAt_I: 00222 c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 $LN1@RemoveAt_I: ; 163 : } 00229 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp+4] 0022c 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 00233 59 pop ecx 00234 5f pop edi 00235 5e pop esi 00236 5b pop ebx 00237 8b 4d ec mov ecx, DWORD PTR __$ArrayPad$[ebp] 0023a 33 cd xor ecx, ebp 0023c e8 00 00 00 00 call @__security_check_cookie@4 00241 8b e5 mov esp, ebp 00243 5d pop ebp 00244 c2 04 00 ret 4 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __unwindfunclet$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$2: 00000 8d 8d 40 e6 ff ff lea ecx, DWORD PTR _NXlog$5[ebp] 00006 e9 00 00 00 00 jmp ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog __unwindfunclet$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$3: 0000b 8b 8d 38 e4 ff ff mov ecx, DWORD PTR $T3[ebp] 00011 e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > __unwindfunclet$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z$4: 00016 8b 8d 34 e4 ff ff mov ecx, DWORD PTR $T2[ebp] 0001c e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > 00021 cc int 3 00022 cc int 3 00023 cc int 3 00024 cc int 3 00025 cc int 3 __ehhandler$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z: 00026 90 npad 1 00027 90 npad 1 00028 8b 54 24 08 mov edx, DWORD PTR [esp+8] 0002c 8d 42 0c lea eax, DWORD PTR [edx+12] 0002f 8b 8a 28 e4 ff ff mov ecx, DWORD PTR [edx-7128] 00035 33 c8 xor ecx, eax 00037 e8 00 00 00 00 call @__security_check_cookie@4 0003c 8b 4a f8 mov ecx, DWORD PTR [edx-8] 0003f 33 c8 xor ecx, eax 00041 e8 00 00 00 00 call @__security_check_cookie@4 00046 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z 0004b e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?RemoveAt_IO@CKeyList@@QAEXPAUIOCP_IO@@@Z ENDP ; CKeyList::RemoveAt_IO ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?Close_IO@CKeyList@@QAEXXZ _TEXT SEGMENT tv164 = -6612 ; size = 4 tv89 = -6608 ; size = 4 $T2 = -6604 ; size = 4 $T3 = -6600 ; size = 4 _NXlog$4 = -6084 ; size = 6056 _i$5 = -28 ; size = 4 _this$ = -24 ; size = 4 __$ArrayPad$ = -20 ; size = 4 __$EHRec$ = -16 ; size = 16 ?Close_IO@CKeyList@@QAEXXZ PROC ; CKeyList::Close_IO, COMDAT ; _this$ = ecx ; 166 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?Close_IO@CKeyList@@QAEXXZ 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 51 push ecx 00012 b8 c4 19 00 00 mov eax, 6596 ; 000019c4H 00017 e8 00 00 00 00 call __chkstk 0001c a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 00021 33 c5 xor eax, ebp 00023 89 45 ec mov DWORD PTR __$ArrayPad$[ebp], eax 00026 53 push ebx 00027 56 push esi 00028 57 push edi 00029 50 push eax 0002a 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp+4] 0002d 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00033 89 65 f0 mov DWORD PTR __$EHRec$[ebp], esp 00036 89 4d e8 mov DWORD PTR _this$[ebp], ecx ; 167 : try 00039 c7 45 fc 00 00 00 00 mov DWORD PTR __$EHRec$[ebp+12], 0 ; 168 : { ; 169 : if ( !m_IO ) 00040 8b 45 e8 mov eax, DWORD PTR _this$[ebp] 00043 83 78 0c 00 cmp DWORD PTR [eax+12], 0 00047 0f 84 18 01 00 00 je $LN1@Close_IO ; 170 : return ; ; 171 : //从尾部找空闲的IO ; 172 : for ( int i=0 ; i > >::CStringT > > 000e7 89 85 30 e6 ff ff mov DWORD PTR tv89[ebp], eax 000ed c6 45 fc 03 mov BYTE PTR __$EHRec$[ebp+12], 3 000f1 51 push ecx 000f2 8b cc mov ecx, esp 000f4 89 a5 34 e6 ff ff mov DWORD PTR $T2[ebp], esp 000fa 68 00 00 00 00 push OFFSET ??_C@_17LLLMIFAB@?$AAL?$AAo?$AAg@ 000ff e8 00 00 00 00 call ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > 00104 89 85 2c e6 ff ff mov DWORD PTR tv164[ebp], eax 0010a c6 45 fc 04 mov BYTE PTR __$EHRec$[ebp+12], 4 0010e c6 45 fc 02 mov BYTE PTR __$EHRec$[ebp+12], 2 00112 8d 8d 3c e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 00118 e8 00 00 00 00 call ?Init@CSAStatusLog@@QAEXV?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@0@Z ; CSAStatusLog::Init 0011d a1 00 00 00 00 mov eax, DWORD PTR ?__LINE__Var@?0??Close_IO@CKeyList@@QAEXXZ@4JA 00122 83 c0 11 add eax, 17 ; 00000011H 00125 50 push eax 00126 68 00 00 00 00 push OFFSET ??_C@_08EDPDCAEI@Close_IO@ 0012b 68 00 00 00 00 push OFFSET ??_C@_0DB@EILGGBMO@D?3?2Works?2Corpsms_2010?2SmsCenter@ 00130 68 00 00 00 00 push OFFSET ??_C@_13JKNELIBG@?$AAT@ 00135 8d 8d 3c e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 0013b e8 00 00 00 00 call ?LogError@CSAStatusLog@@QAEHPB_WPBD1J@Z ; CSAStatusLog::LogError 00140 c6 45 fc 01 mov BYTE PTR __$EHRec$[ebp+12], 1 00144 8d 8d 3c e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 0014a e8 00 00 00 00 call ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog ; 184 : } 0014f b8 00 00 00 00 mov eax, $LN15@Close_IO 00154 c3 ret 0 $LN9@Close_IO: 00155 c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 0015c eb 07 jmp SHORT $LN1@Close_IO $LN15@Close_IO: 0015e c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 $LN1@Close_IO: ; 185 : } 00165 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp+4] 00168 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 0016f 59 pop ecx 00170 5f pop edi 00171 5e pop esi 00172 5b pop ebx 00173 8b 4d ec mov ecx, DWORD PTR __$ArrayPad$[ebp] 00176 33 cd xor ecx, ebp 00178 e8 00 00 00 00 call @__security_check_cookie@4 0017d 8b e5 mov esp, ebp 0017f 5d pop ebp 00180 c3 ret 0 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __unwindfunclet$?Close_IO@CKeyList@@QAEXXZ$2: 00000 8d 8d 3c e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 00006 e9 00 00 00 00 jmp ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog __unwindfunclet$?Close_IO@CKeyList@@QAEXXZ$3: 0000b 8b 8d 38 e6 ff ff mov ecx, DWORD PTR $T3[ebp] 00011 e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > __unwindfunclet$?Close_IO@CKeyList@@QAEXXZ$4: 00016 8b 8d 34 e6 ff ff mov ecx, DWORD PTR $T2[ebp] 0001c e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > 00021 cc int 3 00022 cc int 3 00023 cc int 3 00024 cc int 3 00025 cc int 3 __ehhandler$?Close_IO@CKeyList@@QAEXXZ: 00026 90 npad 1 00027 90 npad 1 00028 8b 54 24 08 mov edx, DWORD PTR [esp+8] 0002c 8d 42 0c lea eax, DWORD PTR [edx+12] 0002f 8b 8a 28 e6 ff ff mov ecx, DWORD PTR [edx-6616] 00035 33 c8 xor ecx, eax 00037 e8 00 00 00 00 call @__security_check_cookie@4 0003c 8b 4a f8 mov ecx, DWORD PTR [edx-8] 0003f 33 c8 xor ecx, eax 00041 e8 00 00 00 00 call @__security_check_cookie@4 00046 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?Close_IO@CKeyList@@QAEXXZ 0004b e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?Close_IO@CKeyList@@QAEXXZ ENDP ; CKeyList::Close_IO ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?Init@CKeyList@@QAEXPAVCSmsCenterDlg@@@Z _TEXT SEGMENT tv174 = -108 ; size = 4 tv141 = -108 ; size = 4 $T2 = -104 ; size = 4 $T3 = -100 ; size = 4 $T4 = -96 ; size = 4 $T5 = -92 ; size = 4 _i$6 = -24 ; size = 4 _lSize$7 = -20 ; size = 4 _this$ = -16 ; size = 4 __$EHRec$ = -12 ; size = 12 _pDlg$ = 8 ; size = 4 ?Init@CKeyList@@QAEXPAVCSmsCenterDlg@@@Z PROC ; CKeyList::Init, COMDAT ; _this$ = ecx ; 188 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?Init@CKeyList@@QAEXPAVCSmsCenterDlg@@@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 60 sub esp, 96 ; 00000060H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00028 89 4d f0 mov DWORD PTR _this$[ebp], ecx ; 189 : m_pDlg = pDlg; 0002b 8b 45 f0 mov eax, DWORD PTR _this$[ebp] 0002e 8b 4d 08 mov ecx, DWORD PTR _pDlg$[ebp] 00031 89 48 1c mov DWORD PTR [eax+28], ecx ; 190 : ; 191 : Close(); //先关闭再初始化 00034 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 00037 e8 00 00 00 00 call ?Close@CKeyList@@QAEXXZ ; CKeyList::Close ; 192 : ; 193 : if ( !m_IO ) 0003c 8b 45 f0 mov eax, DWORD PTR _this$[ebp] 0003f 83 78 0c 00 cmp DWORD PTR [eax+12], 0 00043 75 36 jne SHORT $LN5@Init ; 194 : { ; 195 : long lSize = sizeof(IOCP_IO)*MAX_LOGINUSER; 00045 c7 45 ec 80 c1 5e 05 mov DWORD PTR _lSize$7[ebp], 90096000 ; 055ec180H ; 196 : m_IO = new IOCP_IO[MAX_LOGINUSER]; 0004c 68 80 c1 5e 05 push 90096000 ; 055ec180H 00051 e8 00 00 00 00 call ??_U@YAPAXI@Z ; operator new[] 00056 83 c4 04 add esp, 4 00059 89 45 a4 mov DWORD PTR $T5[ebp], eax 0005c 8b 45 f0 mov eax, DWORD PTR _this$[ebp] 0005f 8b 4d a4 mov ecx, DWORD PTR $T5[ebp] 00062 89 48 0c mov DWORD PTR [eax+12], ecx ; 197 : memset(m_IO,0,sizeof(IOCP_IO)*MAX_LOGINUSER); 00065 68 80 c1 5e 05 push 90096000 ; 055ec180H 0006a 6a 00 push 0 0006c 8b 45 f0 mov eax, DWORD PTR _this$[ebp] 0006f 8b 48 0c mov ecx, DWORD PTR [eax+12] 00072 51 push ecx 00073 e8 00 00 00 00 call _memset 00078 83 c4 0c add esp, 12 ; 0000000cH $LN5@Init: ; 198 : } ; 199 : /* ; 200 : //初始化接收缓冲区 ; 201 : for ( int i=0 ; iSetDlg(m_pDlg); ; 221 : pSocket->SetIndex(i); ; 222 : } ; 223 : */ ; 224 : if ( !m_SQL ) 000b3 8b 45 f0 mov eax, DWORD PTR _this$[ebp] 000b6 83 78 14 00 cmp DWORD PTR [eax+20], 0 000ba 0f 85 17 01 00 00 jne $LN1@Init ; 225 : { ; 226 : m_SQL = new IOCP_SQL[MAX_SQLCONNECT]; 000c0 68 7c 1e 00 00 push 7804 ; 00001e7cH 000c5 e8 00 00 00 00 call ??_U@YAPAXI@Z ; operator new[] 000ca 83 c4 04 add esp, 4 000cd 89 45 98 mov DWORD PTR $T2[ebp], eax 000d0 c7 45 fc 00 00 00 00 mov DWORD PTR __$EHRec$[ebp+8], 0 000d7 83 7d 98 00 cmp DWORD PTR $T2[ebp], 0 000db 74 31 je SHORT $LN9@Init 000dd 8b 45 98 mov eax, DWORD PTR $T2[ebp] 000e0 c7 00 96 00 00 00 mov DWORD PTR [eax], 150 ; 00000096H 000e6 68 00 00 00 00 push OFFSET ??1IOCP_SQL@@QAE@XZ 000eb 68 00 00 00 00 push OFFSET ??0IOCP_SQL@@QAE@XZ 000f0 68 96 00 00 00 push 150 ; 00000096H 000f5 6a 34 push 52 ; 00000034H 000f7 8b 4d 98 mov ecx, DWORD PTR $T2[ebp] 000fa 83 c1 04 add ecx, 4 000fd 51 push ecx 000fe e8 00 00 00 00 call ??_L@YGXPAXIIP6EX0@Z1@Z 00103 8b 55 98 mov edx, DWORD PTR $T2[ebp] 00106 83 c2 04 add edx, 4 00109 89 55 94 mov DWORD PTR tv141[ebp], edx 0010c eb 07 jmp SHORT $LN10@Init $LN9@Init: 0010e c7 45 94 00 00 00 00 mov DWORD PTR tv141[ebp], 0 $LN10@Init: 00115 8b 45 94 mov eax, DWORD PTR tv141[ebp] 00118 89 45 9c mov DWORD PTR $T3[ebp], eax 0011b c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+8], -1 00122 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 00125 8b 55 9c mov edx, DWORD PTR $T3[ebp] 00128 89 51 14 mov DWORD PTR [ecx+20], edx ; 227 : for ( int i=0 ; im_bUse && pProcess->m_lRandID==0 ) ; 254 : { ; 255 : if ( pProcess->m_adoConnection.isOK() && pProcess->m_AdoRS.isOK() && pProcess->m_AdoRS2.isOK() ) ; 256 : { ; 257 : pProcess->m_bUse = true; ; 258 : pProcess->m_lRandID = rand(); ; 259 : pProcess->m_dwBeginUse = ::GetTickCount(); ; 260 : return pProcess; ; 261 : } ; 262 : } ; 263 : } ; 264 : */ ; 265 : /* ; 266 : //先查找前面10个,看能否找到空闲的 ; 267 : for ( int j=0 ; j<3 ; j++ ) ; 268 : { ; 269 : for ( int i=0 ; im_bUse && pProcess->m_lRandID==0 ) ; 273 : { ; 274 : pProcess->m_bUse = true; ; 275 : pProcess->m_lRandID = rand(); ; 276 : pProcess->m_dwBeginUse = ::GetTickCount(); ; 277 : return pProcess; ; 278 : } ; 279 : } ; 280 : Sleep(100); ; 281 : } ; 282 : for ( int i=MIN_SQLCONNECT ; im_bUse && pProcess->m_lRandID==0 ) ; 286 : { ; 287 : pProcess->m_bUse = true; ; 288 : pProcess->m_lRandID = rand(); ; 289 : pProcess->m_dwBeginUse = ::GetTickCount(); ; 290 : return pProcess; ; 291 : } ; 292 : } ; 293 : */ ; 294 : /* ; 295 : Sleep(500); ; 296 : } ; 297 : */ ; 298 : } 00040 e9 90 00 00 00 jmp $LN4@GetBlank_P __catch$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$0: ; 299 : catch(...) ; 300 : { ; 301 : LOG_APPERROR(_T("T")); 00045 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 0004b e8 00 00 00 00 call ??0CSAStatusLog@@QAE@XZ ; CSAStatusLog::CSAStatusLog 00050 c6 45 fc 02 mov BYTE PTR __$EHRec$[ebp+12], 2 00054 51 push ecx 00055 8b cc mov ecx, esp 00057 89 a5 3c e6 ff ff mov DWORD PTR $T3[ebp], esp 0005d 68 00 00 00 00 push OFFSET ??_C@_1BC@HEKPCAFP@?$AAA?$AAp?$AAp?$AAE?$AAr?$AAr?$AAo?$AAr@ 00062 e8 00 00 00 00 call ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > 00067 89 85 34 e6 ff ff mov DWORD PTR tv65[ebp], eax 0006d c6 45 fc 03 mov BYTE PTR __$EHRec$[ebp+12], 3 00071 51 push ecx 00072 8b cc mov ecx, esp 00074 89 a5 38 e6 ff ff mov DWORD PTR $T2[ebp], esp 0007a 68 00 00 00 00 push OFFSET ??_C@_17LLLMIFAB@?$AAL?$AAo?$AAg@ 0007f e8 00 00 00 00 call ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > 00084 89 85 30 e6 ff ff mov DWORD PTR tv140[ebp], eax 0008a c6 45 fc 04 mov BYTE PTR __$EHRec$[ebp+12], 4 0008e c6 45 fc 02 mov BYTE PTR __$EHRec$[ebp+12], 2 00092 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 00098 e8 00 00 00 00 call ?Init@CSAStatusLog@@QAEXV?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@0@Z ; CSAStatusLog::Init 0009d a1 00 00 00 00 mov eax, DWORD PTR ?__LINE__Var@?0??GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ@4JA 000a2 83 c0 39 add eax, 57 ; 00000039H 000a5 50 push eax 000a6 68 00 00 00 00 push OFFSET ??_C@_0BB@NCGHDNPI@GetBlank_Process@ 000ab 68 00 00 00 00 push OFFSET ??_C@_0DB@EILGGBMO@D?3?2Works?2Corpsms_2010?2SmsCenter@ 000b0 68 00 00 00 00 push OFFSET ??_C@_13JKNELIBG@?$AAT@ 000b5 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 000bb e8 00 00 00 00 call ?LogError@CSAStatusLog@@QAEHPB_WPBD1J@Z ; CSAStatusLog::LogError 000c0 c6 45 fc 01 mov BYTE PTR __$EHRec$[ebp+12], 1 000c4 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 000ca e8 00 00 00 00 call ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog ; 302 : } 000cf b8 00 00 00 00 mov eax, $LN10@GetBlank_P 000d4 c3 ret 0 $LN4@GetBlank_P: 000d5 c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 000dc eb 07 jmp SHORT __tryend$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$1 $LN10@GetBlank_P: 000de c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 __tryend$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$1: ; 303 : return NULL; 000e5 33 c0 xor eax, eax ; 304 : } 000e7 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp+4] 000ea 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 000f1 59 pop ecx 000f2 5f pop edi 000f3 5e pop esi 000f4 5b pop ebx 000f5 8b 4d ec mov ecx, DWORD PTR __$ArrayPad$[ebp] 000f8 33 cd xor ecx, ebp 000fa e8 00 00 00 00 call @__security_check_cookie@4 000ff 8b e5 mov esp, ebp 00101 5d pop ebp 00102 c3 ret 0 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __unwindfunclet$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$2: 00000 8d 8d 40 e8 ff ff lea ecx, DWORD PTR _NXlog$4[ebp] 00006 e9 00 00 00 00 jmp ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog __unwindfunclet$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$3: 0000b 8b 8d 3c e6 ff ff mov ecx, DWORD PTR $T3[ebp] 00011 e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > __unwindfunclet$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ$4: 00016 8b 8d 38 e6 ff ff mov ecx, DWORD PTR $T2[ebp] 0001c e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > 00021 cc int 3 00022 cc int 3 00023 cc int 3 00024 cc int 3 00025 cc int 3 __ehhandler$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ: 00026 90 npad 1 00027 90 npad 1 00028 8b 54 24 08 mov edx, DWORD PTR [esp+8] 0002c 8d 42 0c lea eax, DWORD PTR [edx+12] 0002f 8b 8a 2c e6 ff ff mov ecx, DWORD PTR [edx-6612] 00035 33 c8 xor ecx, eax 00037 e8 00 00 00 00 call @__security_check_cookie@4 0003c 8b 4a f8 mov ecx, DWORD PTR [edx-8] 0003f 33 c8 xor ecx, eax 00041 e8 00 00 00 00 call @__security_check_cookie@4 00046 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ 0004b e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?GetBlank_Process@CKeyList@@QAEPAVCProcessSocket@@XZ ENDP ; CKeyList::GetBlank_Process ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?Close@CKeyList@@QAEXXZ _TEXT SEGMENT tv183 = -6636 ; size = 4 tv90 = -6636 ; size = 4 tv140 = -6632 ; size = 4 tv137 = -6632 ; size = 4 tv89 = -6632 ; size = 4 $T2 = -6628 ; size = 4 $T3 = -6624 ; size = 4 $T4 = -6620 ; size = 4 $T5 = -6616 ; size = 4 $T6 = -6612 ; size = 4 $T7 = -6608 ; size = 4 $T8 = -6604 ; size = 4 _NXlog$9 = -6088 ; size = 6056 _pSocket$10 = -32 ; size = 4 _i$11 = -28 ; size = 4 _this$ = -24 ; size = 4 __$ArrayPad$ = -20 ; size = 4 __$EHRec$ = -16 ; size = 16 ?Close@CKeyList@@QAEXXZ PROC ; CKeyList::Close, COMDAT ; _this$ = ecx ; 307 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?Close@CKeyList@@QAEXXZ 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 51 push ecx 00012 b8 dc 19 00 00 mov eax, 6620 ; 000019dcH 00017 e8 00 00 00 00 call __chkstk 0001c a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 00021 33 c5 xor eax, ebp 00023 89 45 ec mov DWORD PTR __$ArrayPad$[ebp], eax 00026 53 push ebx 00027 56 push esi 00028 57 push edi 00029 50 push eax 0002a 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp+4] 0002d 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00033 89 65 f0 mov DWORD PTR __$EHRec$[ebp], esp 00036 89 4d e8 mov DWORD PTR _this$[ebp], ecx ; 308 : try 00039 c7 45 fc 00 00 00 00 mov DWORD PTR __$EHRec$[ebp+12], 0 ; 309 : { ; 310 : Close_IO(); 00040 8b 4d e8 mov ecx, DWORD PTR _this$[ebp] 00043 e8 00 00 00 00 call ?Close_IO@CKeyList@@QAEXXZ ; CKeyList::Close_IO ; 311 : ; 312 : if ( m_Key ) 00048 8b 45 e8 mov eax, DWORD PTR _this$[ebp] 0004b 83 78 04 00 cmp DWORD PTR [eax+4], 0 0004f 74 25 je SHORT $LN6@Close ; 313 : {delete []m_Key;m_Key=NULL;} 00051 8b 45 e8 mov eax, DWORD PTR _this$[ebp] 00054 8b 48 04 mov ecx, DWORD PTR [eax+4] 00057 89 8d 34 e6 ff ff mov DWORD PTR $T8[ebp], ecx 0005d 8b 95 34 e6 ff ff mov edx, DWORD PTR $T8[ebp] 00063 52 push edx 00064 e8 00 00 00 00 call ??_V@YAXPAX@Z ; operator delete[] 00069 83 c4 04 add esp, 4 0006c 8b 45 e8 mov eax, DWORD PTR _this$[ebp] 0006f c7 40 04 00 00 00 00 mov DWORD PTR [eax+4], 0 $LN6@Close: ; 314 : /* ; 315 : //删除接收缓冲区 ; 316 : for ( int i=0 ; i > >::CStringT > > 001c4 89 85 18 e6 ff ff mov DWORD PTR tv140[ebp], eax 001ca c6 45 fc 03 mov BYTE PTR __$EHRec$[ebp+12], 3 001ce 51 push ecx 001cf 8b cc mov ecx, esp 001d1 89 a5 1c e6 ff ff mov DWORD PTR $T2[ebp], esp 001d7 68 00 00 00 00 push OFFSET ??_C@_17LLLMIFAB@?$AAL?$AAo?$AAg@ 001dc e8 00 00 00 00 call ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ; ATL::CStringT > >::CStringT > > 001e1 89 85 14 e6 ff ff mov DWORD PTR tv183[ebp], eax 001e7 c6 45 fc 04 mov BYTE PTR __$EHRec$[ebp+12], 4 001eb c6 45 fc 02 mov BYTE PTR __$EHRec$[ebp+12], 2 001ef 8d 8d 38 e8 ff ff lea ecx, DWORD PTR _NXlog$9[ebp] 001f5 e8 00 00 00 00 call ?Init@CSAStatusLog@@QAEXV?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@0@Z ; CSAStatusLog::Init 001fa a1 00 00 00 00 mov eax, DWORD PTR ?__LINE__Var@?0??Close@CKeyList@@QAEXXZ@4JA 001ff 83 c0 22 add eax, 34 ; 00000022H 00202 50 push eax 00203 68 00 00 00 00 push OFFSET ??_C@_05LGELBCGM@Close@ 00208 68 00 00 00 00 push OFFSET ??_C@_0DB@EILGGBMO@D?3?2Works?2Corpsms_2010?2SmsCenter@ 0020d 68 00 00 00 00 push OFFSET ??_C@_13JKNELIBG@?$AAT@ 00212 8d 8d 38 e8 ff ff lea ecx, DWORD PTR _NXlog$9[ebp] 00218 e8 00 00 00 00 call ?LogError@CSAStatusLog@@QAEHPB_WPBD1J@Z ; CSAStatusLog::LogError 0021d c6 45 fc 01 mov BYTE PTR __$EHRec$[ebp+12], 1 00221 8d 8d 38 e8 ff ff lea ecx, DWORD PTR _NXlog$9[ebp] 00227 e8 00 00 00 00 call ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog ; 342 : } 0022c b8 00 00 00 00 mov eax, $LN21@Close 00231 c3 ret 0 $LN15@Close: 00232 c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 00239 eb 07 jmp SHORT $LN1@Close $LN21@Close: 0023b c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+12], -1 $LN1@Close: ; 343 : } 00242 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp+4] 00245 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 0024c 59 pop ecx 0024d 5f pop edi 0024e 5e pop esi 0024f 5b pop ebx 00250 8b 4d ec mov ecx, DWORD PTR __$ArrayPad$[ebp] 00253 33 cd xor ecx, ebp 00255 e8 00 00 00 00 call @__security_check_cookie@4 0025a 8b e5 mov esp, ebp 0025c 5d pop ebp 0025d c3 ret 0 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __unwindfunclet$?Close@CKeyList@@QAEXXZ$2: 00000 8d 8d 38 e8 ff ff lea ecx, DWORD PTR _NXlog$9[ebp] 00006 e9 00 00 00 00 jmp ??1CSAStatusLog@@QAE@XZ ; CSAStatusLog::~CSAStatusLog __unwindfunclet$?Close@CKeyList@@QAEXXZ$3: 0000b 8b 8d 20 e6 ff ff mov ecx, DWORD PTR $T3[ebp] 00011 e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > __unwindfunclet$?Close@CKeyList@@QAEXXZ$4: 00016 8b 8d 1c e6 ff ff mov ecx, DWORD PTR $T2[ebp] 0001c e9 00 00 00 00 jmp ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ; ATL::CStringT > >::~CStringT > > 00021 cc int 3 00022 cc int 3 00023 cc int 3 00024 cc int 3 00025 cc int 3 __ehhandler$?Close@CKeyList@@QAEXXZ: 00026 90 npad 1 00027 90 npad 1 00028 8b 54 24 08 mov edx, DWORD PTR [esp+8] 0002c 8d 42 0c lea eax, DWORD PTR [edx+12] 0002f 8b 8a 10 e6 ff ff mov ecx, DWORD PTR [edx-6640] 00035 33 c8 xor ecx, eax 00037 e8 00 00 00 00 call @__security_check_cookie@4 0003c 8b 4a f8 mov ecx, DWORD PTR [edx-8] 0003f 33 c8 xor ecx, eax 00041 e8 00 00 00 00 call @__security_check_cookie@4 00046 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?Close@CKeyList@@QAEXXZ 0004b e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?Close@CKeyList@@QAEXXZ ENDP ; CKeyList::Close ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?GetBlank_SQL@CKeyList@@QAEPAUIOCP_SQL@@XZ _TEXT SEGMENT tv134 = -80 ; size = 4 tv95 = -80 ; size = 4 _i$1 = -12 ; size = 4 _j$2 = -8 ; size = 4 _this$ = -4 ; size = 4 ?GetBlank_SQL@CKeyList@@QAEPAUIOCP_SQL@@XZ PROC ; CKeyList::GetBlank_SQL, COMDAT ; _this$ = ecx ; 346 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 50 sub esp, 80 ; 00000050H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 347 : for ( int j=0 ; j<3 ; j++ ) 0000c c7 45 f8 00 00 00 00 mov DWORD PTR _j$2[ebp], 0 00013 eb 09 jmp SHORT $LN4@GetBlank_S $LN2@GetBlank_S: 00015 8b 45 f8 mov eax, DWORD PTR _j$2[ebp] 00018 83 c0 01 add eax, 1 0001b 89 45 f8 mov DWORD PTR _j$2[ebp], eax $LN4@GetBlank_S: 0001e 83 7d f8 03 cmp DWORD PTR _j$2[ebp], 3 00022 0f 8d e8 00 00 00 jge $LN3@GetBlank_S ; 348 : { ; 349 : for ( int i=0 ; i >::GetDefaultManager, COMDAT ; 51 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?GetDefaultManager@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUIAtlStringMgr@ATL@@XZ 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 40 sub esp, 64 ; 00000040H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax ; 52 : return( AfxGetStringManager() ); 00028 e8 00 00 00 00 call ?AfxGetStringManager@@YGPAUIAtlStringMgr@ATL@@XZ ; AfxGetStringManager ; 53 : } 0002d 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 00030 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 00037 59 pop ecx 00038 5f pop edi 00039 5e pop esi 0003a 5b pop ebx 0003b 8b e5 mov esp, ebp 0003d 5d pop ebp 0003e c3 ret 0 0003f cc int 3 00040 cc int 3 00041 cc int 3 00042 cc int 3 00043 cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$?GetDefaultManager@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUIAtlStringMgr@ATL@@XZ: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a b0 mov ecx, DWORD PTR [edx-80] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?GetDefaultManager@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUIAtlStringMgr@ATL@@XZ 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?GetDefaultManager@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUIAtlStringMgr@ATL@@XZ ENDP ; StrTraitMFC >::GetDefaultManager ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\afxstr.h ; COMDAT ?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z _TEXT SEGMENT __$EHRec$ = -12 ; size = 12 _nID$ = 8 ; size = 4 ?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z PROC ; StrTraitMFC >::FindStringResourceInstance, COMDAT ; 46 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 40 sub esp, 64 ; 00000040H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax ; 47 : return( AfxFindStringResourceHandle( nID ) ); 00028 8b 45 08 mov eax, DWORD PTR _nID$[ebp] 0002b 50 push eax 0002c e8 00 00 00 00 call ?AfxFindStringResourceHandle@@YGPAUHINSTANCE__@@I@Z ; AfxFindStringResourceHandle ; 48 : } 00031 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 00034 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 0003b 59 pop ecx 0003c 5f pop edi 0003d 5e pop esi 0003e 5b pop ebx 0003f 8b e5 mov esp, ebp 00041 5d pop ebp 00042 c3 ret 0 00043 cc int 3 00044 cc int 3 00045 cc int 3 00046 cc int 3 00047 cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a b0 mov ecx, DWORD PTR [edx-80] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z ENDP ; StrTraitMFC >::FindStringResourceInstance ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ?CheckImplicitLoad@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@AAE_NPBX@Z _TEXT SEGMENT _nID$1 = -12 ; size = 4 _bRet$ = -5 ; size = 1 _this$ = -4 ; size = 4 _pv$ = 8 ; size = 4 ?CheckImplicitLoad@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@AAE_NPBX@Z PROC ; ATL::CStringT > >::CheckImplicitLoad, COMDAT ; _this$ = ecx ; 2705 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 4c sub esp, 76 ; 0000004cH 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 2706 : bool bRet = false; 0000c c6 45 fb 00 mov BYTE PTR _bRet$[ebp], 0 ; 2707 : ; 2708 : if( (pv != NULL) && IS_INTRESOURCE( pv ) ) 00010 83 7d 08 00 cmp DWORD PTR _pv$[ebp], 0 00014 74 28 je SHORT $LN2@CheckImpli 00016 8b 45 08 mov eax, DWORD PTR _pv$[ebp] 00019 c1 e8 10 shr eax, 16 ; 00000010H 0001c 85 c0 test eax, eax 0001e 75 1e jne SHORT $LN2@CheckImpli ; 2709 : { ; 2710 : UINT nID = LOWORD( reinterpret_cast< DWORD_PTR >( pv ) ); 00020 8b 45 08 mov eax, DWORD PTR _pv$[ebp] 00023 25 ff ff 00 00 and eax, 65535 ; 0000ffffH 00028 0f b7 c8 movzx ecx, ax 0002b 89 4d f4 mov DWORD PTR _nID$1[ebp], ecx ; 2711 : (nID); ; 2712 : #ifdef _ATL_USE_WINAPI_FAMILY_DESKTOP_APP ; 2713 : if( !LoadString( nID ) ) 0002e 8b 45 f4 mov eax, DWORD PTR _nID$1[ebp] 00031 50 push eax 00032 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00035 e8 00 00 00 00 call ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHI@Z ; ATL::CStringT > >::LoadStringW ; 2714 : { ; 2715 : ATLTRACE( atlTraceString, 2, _T( "Warning: implicit LoadString(%u) failed\n" ), nID ); ; 2716 : } ; 2717 : bRet = true; 0003a c6 45 fb 01 mov BYTE PTR _bRet$[ebp], 1 $LN2@CheckImpli: ; 2718 : #else ; 2719 : ATLTRACE( atlTraceString, 2, _T( "Warning: LoadString(%u) not supported under the current WINAPI_FAMILY.\n" ), nID ); ; 2720 : #endif ; 2721 : } ; 2722 : ; 2723 : return( bRet ); 0003e 8a 45 fb mov al, BYTE PTR _bRet$[ebp] ; 2724 : } 00041 5f pop edi 00042 5e pop esi 00043 5b pop ebx 00044 8b e5 mov esp, ebp 00046 5d pop ebp 00047 c2 04 00 ret 4 ?CheckImplicitLoad@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@AAE_NPBX@Z ENDP ; ATL::CStringT > >::CheckImplicitLoad _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHPAUHINSTANCE__@@I@Z _TEXT SEGMENT _pszBuffer$ = -16 ; size = 4 _nLength$ = -12 ; size = 4 _pImage$ = -8 ; size = 4 _this$ = -4 ; size = 4 _hInstance$ = 8 ; size = 4 _nID$ = 12 ; size = 4 ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHPAUHINSTANCE__@@I@Z PROC ; ATL::CStringT > >::LoadStringW, COMDAT ; _this$ = ecx ; 2350 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 50 sub esp, 80 ; 00000050H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 2351 : const ATLSTRINGRESOURCEIMAGE* pImage = AtlGetStringResourceImage( hInstance, nID ); 0000c 8b 45 0c mov eax, DWORD PTR _nID$[ebp] 0000f 50 push eax 00010 8b 4d 08 mov ecx, DWORD PTR _hInstance$[ebp] 00013 51 push ecx 00014 e8 00 00 00 00 call ?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z ; ATL::AtlGetStringResourceImage 00019 83 c4 08 add esp, 8 0001c 89 45 f8 mov DWORD PTR _pImage$[ebp], eax ; 2352 : if( pImage == NULL ) 0001f 83 7d f8 00 cmp DWORD PTR _pImage$[ebp], 0 00023 75 04 jne SHORT $LN2@LoadString ; 2353 : { ; 2354 : return( FALSE ); 00025 33 c0 xor eax, eax 00027 eb 57 jmp SHORT $LN1@LoadString $LN2@LoadString: ; 2355 : } ; 2356 : ; 2357 : int nLength = StringTraits::GetBaseTypeLength( pImage->achString, pImage->nLength ); 00029 8b 45 f8 mov eax, DWORD PTR _pImage$[ebp] 0002c 0f b7 08 movzx ecx, WORD PTR [eax] 0002f 51 push ecx 00030 8b 55 f8 mov edx, DWORD PTR _pImage$[ebp] 00033 83 c2 02 add edx, 2 00036 52 push edx 00037 e8 00 00 00 00 call ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_WH@Z ; ATL::ChTraitsCRT::GetBaseTypeLength 0003c 83 c4 08 add esp, 8 0003f 89 45 f4 mov DWORD PTR _nLength$[ebp], eax ; 2358 : PXSTR pszBuffer = this->GetBuffer( nLength ); 00042 8b 45 f4 mov eax, DWORD PTR _nLength$[ebp] 00045 50 push eax 00046 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00049 e8 00 00 00 00 call ?GetBuffer@?$CSimpleStringT@_W$0A@@ATL@@QAEPA_WH@Z ; ATL::CSimpleStringT::GetBuffer 0004e 89 45 f0 mov DWORD PTR _pszBuffer$[ebp], eax ; 2359 : StringTraits::ConvertToBaseType( pszBuffer, nLength, pImage->achString, pImage->nLength ); 00051 8b 45 f8 mov eax, DWORD PTR _pImage$[ebp] 00054 0f b7 08 movzx ecx, WORD PTR [eax] 00057 51 push ecx 00058 8b 55 f8 mov edx, DWORD PTR _pImage$[ebp] 0005b 83 c2 02 add edx, 2 0005e 52 push edx 0005f 8b 45 f4 mov eax, DWORD PTR _nLength$[ebp] 00062 50 push eax 00063 8b 4d f0 mov ecx, DWORD PTR _pszBuffer$[ebp] 00066 51 push ecx 00067 e8 00 00 00 00 call ?ConvertToBaseType@?$ChTraitsCRT@_W@ATL@@SAXPA_WHPB_WH@Z ; ATL::ChTraitsCRT::ConvertToBaseType 0006c 83 c4 10 add esp, 16 ; 00000010H ; 2360 : this->ReleaseBufferSetLength( nLength ); 0006f 8b 45 f4 mov eax, DWORD PTR _nLength$[ebp] 00072 50 push eax 00073 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00076 e8 00 00 00 00 call ?ReleaseBufferSetLength@?$CSimpleStringT@_W$0A@@ATL@@QAEXH@Z ; ATL::CSimpleStringT::ReleaseBufferSetLength ; 2361 : ; 2362 : return( TRUE ); 0007b b8 01 00 00 00 mov eax, 1 $LN1@LoadString: ; 2363 : } 00080 5f pop edi 00081 5e pop esi 00082 5b pop ebx 00083 8b e5 mov esp, ebp 00085 5d pop ebp 00086 c2 08 00 ret 8 ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHPAUHINSTANCE__@@I@Z ENDP ; ATL::CStringT > >::LoadStringW _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHI@Z _TEXT SEGMENT _hInstance$ = -8 ; size = 4 _this$ = -4 ; size = 4 _nID$ = 8 ; size = 4 ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHI@Z PROC ; ATL::CStringT > >::LoadStringW, COMDAT ; _this$ = ecx ; 2336 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 48 sub esp, 72 ; 00000048H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 2337 : HINSTANCE hInstance = StringTraits::FindStringResourceInstance( nID ); 0000c 8b 45 08 mov eax, DWORD PTR _nID$[ebp] 0000f 50 push eax 00010 e8 00 00 00 00 call ?FindStringResourceInstance@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUHINSTANCE__@@I@Z ; StrTraitMFC >::FindStringResourceInstance 00015 83 c4 04 add esp, 4 00018 89 45 f8 mov DWORD PTR _hInstance$[ebp], eax ; 2338 : if( hInstance == NULL ) 0001b 83 7d f8 00 cmp DWORD PTR _hInstance$[ebp], 0 0001f 75 04 jne SHORT $LN2@LoadString ; 2339 : { ; 2340 : return( FALSE ); 00021 33 c0 xor eax, eax 00023 eb 10 jmp SHORT $LN1@LoadString $LN2@LoadString: ; 2341 : } ; 2342 : ; 2343 : return( LoadString( hInstance, nID ) ); 00025 8b 45 08 mov eax, DWORD PTR _nID$[ebp] 00028 50 push eax 00029 8b 4d f8 mov ecx, DWORD PTR _hInstance$[ebp] 0002c 51 push ecx 0002d 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00030 e8 00 00 00 00 call ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHPAUHINSTANCE__@@I@Z ; ATL::CStringT > >::LoadStringW $LN1@LoadString: ; 2344 : } 00035 5f pop edi 00036 5e pop esi 00037 5b pop ebx 00038 8b e5 mov esp, ebp 0003a 5d pop ebp 0003b c2 04 00 ret 4 ?LoadStringW@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEHI@Z ENDP ; ATL::CStringT > >::LoadStringW _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ??4?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEAAV01@PB_W@Z _TEXT SEGMENT _this$ = -4 ; size = 4 _pszSrc$ = 8 ; size = 4 ??4?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEAAV01@PB_W@Z PROC ; ATL::CStringT > >::operator=, COMDAT ; _this$ = ecx ; 1318 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 1319 : CThisSimpleString::operator=( pszSrc ); 0000c 8b 45 08 mov eax, DWORD PTR _pszSrc$[ebp] 0000f 50 push eax 00010 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00013 e8 00 00 00 00 call ??4?$CSimpleStringT@_W$0A@@ATL@@QAEAAV01@PB_W@Z ; ATL::CSimpleStringT::operator= ; 1320 : ; 1321 : return( *this ); 00018 8b 45 fc mov eax, DWORD PTR _this$[ebp] ; 1322 : } 0001b 5f pop edi 0001c 5e pop esi 0001d 5b pop ebx 0001e 8b e5 mov esp, ebp 00020 5d pop ebp 00021 c2 04 00 ret 4 ??4?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEAAV01@PB_W@Z ENDP ; ATL::CStringT > >::operator= _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ _TEXT SEGMENT _this$ = -16 ; size = 4 __$EHRec$ = -12 ; size = 12 ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ PROC ; ATL::CStringT > >::~CStringT > >, COMDAT ; _this$ = ecx ; 1298 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 44 sub esp, 68 ; 00000044H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00028 89 4d f0 mov DWORD PTR _this$[ebp], ecx 0002b c7 45 fc 00 00 00 00 mov DWORD PTR __$EHRec$[ebp+8], 0 ; 1299 : } 00032 c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+8], -1 00039 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 0003c e8 00 00 00 00 call ??1?$CSimpleStringT@_W$0A@@ATL@@QAE@XZ ; ATL::CSimpleStringT::~CSimpleStringT 00041 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 00044 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 0004b 59 pop ecx 0004c 5f pop edi 0004d 5e pop esi 0004e 5b pop ebx 0004f 8b e5 mov esp, ebp 00051 5d pop ebp 00052 c3 ret 0 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __unwindfunclet$??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ$0: 00000 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 00003 e9 00 00 00 00 jmp ??1?$CSimpleStringT@_W$0A@@ATL@@QAE@XZ ; ATL::CSimpleStringT::~CSimpleStringT 00008 cc int 3 00009 cc int 3 0000a cc int 3 0000b cc int 3 0000c cc int 3 __ehhandler$??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ: 0000d 90 npad 1 0000e 90 npad 1 0000f 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00013 8d 42 0c lea eax, DWORD PTR [edx+12] 00016 8b 4a ac mov ecx, DWORD PTR [edx-84] 00019 33 c8 xor ecx, eax 0001b e8 00 00 00 00 call @__security_check_cookie@4 00020 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ 00025 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ??1?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@XZ ENDP ; ATL::CStringT > >::~CStringT > > ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z _TEXT SEGMENT _this$ = -16 ; size = 4 __$EHRec$ = -12 ; size = 12 _pszSrc$ = 8 ; size = 4 ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z PROC ; ATL::CStringT > >::CStringT > >, COMDAT ; _this$ = ecx ; 1049 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 44 sub esp, 68 ; 00000044H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00028 89 4d f0 mov DWORD PTR _this$[ebp], ecx ; 1048 : CThisSimpleString( StringTraits::GetDefaultManager() ) 0002b e8 00 00 00 00 call ?GetDefaultManager@?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@SAPAUIAtlStringMgr@ATL@@XZ ; StrTraitMFC >::GetDefaultManager 00030 50 push eax 00031 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 00034 e8 00 00 00 00 call ??0?$CSimpleStringT@_W$0A@@ATL@@QAE@PAUIAtlStringMgr@1@@Z ; ATL::CSimpleStringT::CSimpleStringT 00039 c7 45 fc 00 00 00 00 mov DWORD PTR __$EHRec$[ebp+8], 0 ; 1050 : if( !CheckImplicitLoad( pszSrc ) ) 00040 8b 45 08 mov eax, DWORD PTR _pszSrc$[ebp] 00043 50 push eax 00044 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 00047 e8 00 00 00 00 call ?CheckImplicitLoad@?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@AAE_NPBX@Z ; ATL::CStringT > >::CheckImplicitLoad 0004c 0f b6 c8 movzx ecx, al 0004f 85 c9 test ecx, ecx 00051 75 0c jne SHORT $LN1@CStringT ; 1051 : { ; 1052 : *this = pszSrc; 00053 8b 45 08 mov eax, DWORD PTR _pszSrc$[ebp] 00056 50 push eax 00057 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 0005a e8 00 00 00 00 call ??4?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAEAAV01@PB_W@Z ; ATL::CStringT > >::operator= $LN1@CStringT: ; 1053 : } ; 1054 : } 0005f c7 45 fc ff ff ff ff mov DWORD PTR __$EHRec$[ebp+8], -1 00066 8b 45 f0 mov eax, DWORD PTR _this$[ebp] 00069 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 0006c 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 00073 59 pop ecx 00074 5f pop edi 00075 5e pop esi 00076 5b pop ebx 00077 8b e5 mov esp, ebp 00079 5d pop ebp 0007a c2 04 00 ret 4 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __unwindfunclet$??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z$0: 00000 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 00003 e9 00 00 00 00 jmp ??1?$CSimpleStringT@_W$0A@@ATL@@QAE@XZ ; ATL::CSimpleStringT::~CSimpleStringT 00008 cc int 3 00009 cc int 3 0000a cc int 3 0000b cc int 3 0000c cc int 3 __ehhandler$??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z: 0000d 90 npad 1 0000e 90 npad 1 0000f 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00013 8d 42 0c lea eax, DWORD PTR [edx+12] 00016 8b 4a ac mov ecx, DWORD PTR [edx-84] 00019 33 c8 xor ecx, eax 0001b e8 00 00 00 00 call @__security_check_cookie@4 00020 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z 00025 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ??0?$CStringT@_WV?$StrTraitMFC@_WV?$ChTraitsCRT@_W@ATL@@@@@ATL@@QAE@PB_W@Z ENDP ; ATL::CStringT > >::CStringT > > ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?SetLength@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z _TEXT SEGMENT _this$ = -4 ; size = 4 _nLength$ = 8 ; size = 4 ?SetLength@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z PROC ; ATL::CSimpleStringT::SetLength, COMDAT ; _this$ = ecx ; 867 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 868 : ATLASSERT( nLength >= 0 ); ; 869 : ATLASSERT( nLength <= GetData()->nAllocLength ); ; 870 : ; 871 : if( nLength < 0 || nLength > GetData()->nAllocLength) 0000c 83 7d 08 00 cmp DWORD PTR _nLength$[ebp], 0 00010 7c 10 jl SHORT $LN3@SetLength 00012 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00015 e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 0001a 8b 4d 08 mov ecx, DWORD PTR _nLength$[ebp] 0001d 3b 48 08 cmp ecx, DWORD PTR [eax+8] 00020 7e 0a jle SHORT $LN2@SetLength $LN3@SetLength: ; 872 : AtlThrow(E_INVALIDARG); 00022 68 57 00 07 80 push -2147024809 ; 80070057H 00027 e8 00 00 00 00 call ?AtlThrowImpl@ATL@@YGXJ@Z ; ATL::AtlThrowImpl $LN2@SetLength: ; 873 : ; 874 : GetData()->nDataLength = nLength; 0002c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0002f e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00034 8b 4d 08 mov ecx, DWORD PTR _nLength$[ebp] 00037 89 48 04 mov DWORD PTR [eax+4], ecx ; 875 : m_pszData[nLength] = 0; 0003a 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0003d 8b 08 mov ecx, DWORD PTR [eax] 0003f 33 d2 xor edx, edx 00041 8b 45 08 mov eax, DWORD PTR _nLength$[ebp] 00044 66 89 14 41 mov WORD PTR [ecx+eax*2], dx $LN4@SetLength: ; 876 : } 00048 5f pop edi 00049 5e pop esi 0004a 5b pop ebx 0004b 8b e5 mov esp, ebp 0004d 5d pop ebp 0004e c2 04 00 ret 4 ?SetLength@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ENDP ; ATL::CSimpleStringT::SetLength _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?Reallocate@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z _TEXT SEGMENT tv78 = -84 ; size = 4 _pNewData$ = -16 ; size = 4 _pStringMgr$ = -12 ; size = 4 _pOldData$ = -8 ; size = 4 _this$ = -4 ; size = 4 _nLength$ = 8 ; size = 4 ?Reallocate@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z PROC ; ATL::CSimpleStringT::Reallocate, COMDAT ; _this$ = ecx ; 849 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 54 sub esp, 84 ; 00000054H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 850 : CStringData* pOldData = GetData(); 0000c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0000f e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00014 89 45 f8 mov DWORD PTR _pOldData$[ebp], eax ; 851 : ATLASSERT( pOldData->nAllocLength < nLength ); ; 852 : IAtlStringMgr* pStringMgr = pOldData->pStringMgr; 00017 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 0001a 8b 08 mov ecx, DWORD PTR [eax] 0001c 89 4d f4 mov DWORD PTR _pStringMgr$[ebp], ecx ; 853 : if ( pOldData->nAllocLength >= nLength || nLength <= 0) 0001f 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 00022 8b 48 08 mov ecx, DWORD PTR [eax+8] 00025 3b 4d 08 cmp ecx, DWORD PTR _nLength$[ebp] 00028 7d 06 jge SHORT $LN3@Reallocate 0002a 83 7d 08 00 cmp DWORD PTR _nLength$[ebp], 0 0002e 7f 07 jg SHORT $LN2@Reallocate $LN3@Reallocate: ; 854 : { ; 855 : ThrowMemoryException(); 00030 e8 00 00 00 00 call ?ThrowMemoryException@?$CSimpleStringT@_W$0A@@ATL@@KAXXZ ; ATL::CSimpleStringT::ThrowMemoryException ; 856 : return; 00035 eb 35 jmp SHORT $LN5@Reallocate $LN2@Reallocate: ; 857 : } ; 858 : CStringData* pNewData = pStringMgr->Reallocate( pOldData, nLength, sizeof( XCHAR ) ); 00037 8b 45 f4 mov eax, DWORD PTR _pStringMgr$[ebp] 0003a 8b 08 mov ecx, DWORD PTR [eax] 0003c 8b 51 08 mov edx, DWORD PTR [ecx+8] 0003f 89 55 ac mov DWORD PTR tv78[ebp], edx 00042 6a 02 push 2 00044 8b 45 08 mov eax, DWORD PTR _nLength$[ebp] 00047 50 push eax 00048 8b 4d f8 mov ecx, DWORD PTR _pOldData$[ebp] 0004b 51 push ecx 0004c 8b 4d f4 mov ecx, DWORD PTR _pStringMgr$[ebp] 0004f ff 55 ac call DWORD PTR tv78[ebp] 00052 89 45 f0 mov DWORD PTR _pNewData$[ebp], eax ; 859 : if( pNewData == NULL ) 00055 83 7d f0 00 cmp DWORD PTR _pNewData$[ebp], 0 00059 75 05 jne SHORT $LN4@Reallocate ; 860 : { ; 861 : ThrowMemoryException(); 0005b e8 00 00 00 00 call ?ThrowMemoryException@?$CSimpleStringT@_W$0A@@ATL@@KAXXZ ; ATL::CSimpleStringT::ThrowMemoryException $LN4@Reallocate: ; 862 : } ; 863 : Attach( pNewData ); 00060 8b 45 f0 mov eax, DWORD PTR _pNewData$[ebp] 00063 50 push eax 00064 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00067 e8 00 00 00 00 call ?Attach@?$CSimpleStringT@_W$0A@@ATL@@AAEXPAUCStringData@2@@Z ; ATL::CSimpleStringT::Attach $LN5@Reallocate: ; 864 : } 0006c 5f pop edi 0006d 5e pop esi 0006e 5b pop ebx 0006f 8b e5 mov esp, ebp 00071 5d pop ebp 00072 c2 04 00 ret 4 ?Reallocate@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ENDP ; ATL::CSimpleStringT::Reallocate _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?PrepareWrite2@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z _TEXT SEGMENT _nNewLength$1 = -12 ; size = 4 _pOldData$ = -8 ; size = 4 _this$ = -4 ; size = 4 _nLength$ = 8 ; size = 4 ?PrepareWrite2@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z PROC ; ATL::CSimpleStringT::PrepareWrite2, COMDAT ; _this$ = ecx ; 818 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 4c sub esp, 76 ; 0000004cH 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 819 : CStringData* pOldData = GetData(); 0000c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0000f e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00014 89 45 f8 mov DWORD PTR _pOldData$[ebp], eax ; 820 : if( pOldData->nDataLength > nLength ) 00017 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 0001a 8b 48 04 mov ecx, DWORD PTR [eax+4] 0001d 3b 4d 08 cmp ecx, DWORD PTR _nLength$[ebp] 00020 7e 09 jle SHORT $LN2@PrepareWri ; 821 : { ; 822 : nLength = pOldData->nDataLength; 00022 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 00025 8b 48 04 mov ecx, DWORD PTR [eax+4] 00028 89 4d 08 mov DWORD PTR _nLength$[ebp], ecx $LN2@PrepareWri: ; 823 : } ; 824 : if( pOldData->IsShared() ) 0002b 8b 4d f8 mov ecx, DWORD PTR _pOldData$[ebp] 0002e e8 00 00 00 00 call ?IsShared@CStringData@ATL@@QBE_NXZ ; ATL::CStringData::IsShared 00033 0f b6 c0 movzx eax, al 00036 85 c0 test eax, eax 00038 74 0e je SHORT $LN3@PrepareWri ; 825 : { ; 826 : Fork( nLength ); 0003a 8b 45 08 mov eax, DWORD PTR _nLength$[ebp] 0003d 50 push eax 0003e 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00041 e8 00 00 00 00 call ?Fork@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::Fork ; 827 : } 00046 eb 52 jmp SHORT $LN1@PrepareWri $LN3@PrepareWri: ; 828 : else if( pOldData->nAllocLength < nLength ) 00048 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 0004b 8b 48 08 mov ecx, DWORD PTR [eax+8] 0004e 3b 4d 08 cmp ecx, DWORD PTR _nLength$[ebp] 00051 7d 47 jge SHORT $LN1@PrepareWri ; 829 : { ; 830 : // Grow exponentially, until we hit 1G, then by 1M thereafter. ; 831 : int nNewLength = pOldData->nAllocLength; 00053 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 00056 8b 48 08 mov ecx, DWORD PTR [eax+8] 00059 89 4d f4 mov DWORD PTR _nNewLength$1[ebp], ecx ; 832 : if( nNewLength > 1024 * 1024 * 1024 ) 0005c 81 7d f4 00 00 00 40 cmp DWORD PTR _nNewLength$1[ebp], 1073741824 ; 40000000H 00063 7e 0d jle SHORT $LN6@PrepareWri ; 833 : { ; 834 : nNewLength += 1024 * 1024; 00065 8b 45 f4 mov eax, DWORD PTR _nNewLength$1[ebp] 00068 05 00 00 10 00 add eax, 1048576 ; 00100000H 0006d 89 45 f4 mov DWORD PTR _nNewLength$1[ebp], eax ; 835 : } 00070 eb 0e jmp SHORT $LN7@PrepareWri $LN6@PrepareWri: ; 836 : else ; 837 : { ; 838 : // Exponential growth factor is 1.5. ; 839 : nNewLength = nNewLength + nNewLength / 2; 00072 8b 45 f4 mov eax, DWORD PTR _nNewLength$1[ebp] 00075 99 cdq 00076 2b c2 sub eax, edx 00078 d1 f8 sar eax, 1 0007a 03 45 f4 add eax, DWORD PTR _nNewLength$1[ebp] 0007d 89 45 f4 mov DWORD PTR _nNewLength$1[ebp], eax $LN7@PrepareWri: ; 840 : } ; 841 : if( nNewLength < nLength ) 00080 8b 45 f4 mov eax, DWORD PTR _nNewLength$1[ebp] 00083 3b 45 08 cmp eax, DWORD PTR _nLength$[ebp] 00086 7d 06 jge SHORT $LN8@PrepareWri ; 842 : { ; 843 : nNewLength = nLength; 00088 8b 45 08 mov eax, DWORD PTR _nLength$[ebp] 0008b 89 45 f4 mov DWORD PTR _nNewLength$1[ebp], eax $LN8@PrepareWri: ; 844 : } ; 845 : Reallocate( nNewLength ); 0008e 8b 45 f4 mov eax, DWORD PTR _nNewLength$1[ebp] 00091 50 push eax 00092 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00095 e8 00 00 00 00 call ?Reallocate@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::Reallocate $LN1@PrepareWri: ; 846 : } ; 847 : } 0009a 5f pop edi 0009b 5e pop esi 0009c 5b pop ebx 0009d 8b e5 mov esp, ebp 0009f 5d pop ebp 000a0 c2 04 00 ret 4 ?PrepareWrite2@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ENDP ; ATL::CSimpleStringT::PrepareWrite2 _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?PrepareWrite@?$CSimpleStringT@_W$0A@@ATL@@AAEPA_WH@Z _TEXT SEGMENT _nTooShort$ = -16 ; size = 4 _nShared$ = -12 ; size = 4 _pOldData$ = -8 ; size = 4 _this$ = -4 ; size = 4 _nLength$ = 8 ; size = 4 ?PrepareWrite@?$CSimpleStringT@_W$0A@@ATL@@AAEPA_WH@Z PROC ; ATL::CSimpleStringT::PrepareWrite, COMDAT ; _this$ = ecx ; 803 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 50 sub esp, 80 ; 00000050H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 804 : if (nLength < 0) 0000c 83 7d 08 00 cmp DWORD PTR _nLength$[ebp], 0 00010 7d 0a jge SHORT $LN2@PrepareWri ; 805 : AtlThrow(E_INVALIDARG); 00012 68 57 00 07 80 push -2147024809 ; 80070057H 00017 e8 00 00 00 00 call ?AtlThrowImpl@ATL@@YGXJ@Z ; ATL::AtlThrowImpl $LN2@PrepareWri: ; 806 : ; 807 : CStringData* pOldData = GetData(); 0001c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0001f e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00024 89 45 f8 mov DWORD PTR _pOldData$[ebp], eax ; 808 : int nShared = 1-pOldData->nRefs; // nShared < 0 means true, >= 0 means false 00027 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 0002a b9 01 00 00 00 mov ecx, 1 0002f 2b 48 0c sub ecx, DWORD PTR [eax+12] 00032 89 4d f4 mov DWORD PTR _nShared$[ebp], ecx ; 809 : int nTooShort = pOldData->nAllocLength-nLength; // nTooShort < 0 means true, >= 0 means false 00035 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 00038 8b 48 08 mov ecx, DWORD PTR [eax+8] 0003b 2b 4d 08 sub ecx, DWORD PTR _nLength$[ebp] 0003e 89 4d f0 mov DWORD PTR _nTooShort$[ebp], ecx ; 810 : if( (nShared|nTooShort) < 0 ) // If either sign bit is set (i.e. either is less than zero), we need to copy data 00041 8b 45 f4 mov eax, DWORD PTR _nShared$[ebp] 00044 0b 45 f0 or eax, DWORD PTR _nTooShort$[ebp] 00047 7d 0c jge SHORT $LN3@PrepareWri ; 811 : { ; 812 : PrepareWrite2( nLength ); 00049 8b 45 08 mov eax, DWORD PTR _nLength$[ebp] 0004c 50 push eax 0004d 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00050 e8 00 00 00 00 call ?PrepareWrite2@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::PrepareWrite2 $LN3@PrepareWri: ; 813 : } ; 814 : ; 815 : return( m_pszData ); 00055 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00058 8b 00 mov eax, DWORD PTR [eax] $LN4@PrepareWri: ; 816 : } 0005a 5f pop edi 0005b 5e pop esi 0005c 5b pop ebx 0005d 8b e5 mov esp, ebp 0005f 5d pop ebp 00060 c2 04 00 ret 4 ?PrepareWrite@?$CSimpleStringT@_W$0A@@ATL@@AAEPA_WH@Z ENDP ; ATL::CSimpleStringT::PrepareWrite _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ _TEXT SEGMENT _this$ = -4 ; size = 4 ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ PROC ; ATL::CSimpleStringT::GetData, COMDAT ; _this$ = ecx ; 799 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 800 : return( reinterpret_cast< CStringData* >( m_pszData )-1 ); 0000c 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0000f 8b 00 mov eax, DWORD PTR [eax] 00011 83 e8 10 sub eax, 16 ; 00000010H ; 801 : } 00014 5f pop edi 00015 5e pop esi 00016 5b pop ebx 00017 8b e5 mov esp, ebp 00019 5d pop ebp 0001a c3 ret 0 ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ENDP ; ATL::CSimpleStringT::GetData _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?Fork@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z _TEXT SEGMENT tv132 = -92 ; size = 4 tv83 = -92 ; size = 4 tv134 = -88 ; size = 4 tv86 = -88 ; size = 4 tv76 = -88 ; size = 4 _nCharsToCopy$ = -20 ; size = 4 _pNewData$ = -16 ; size = 4 _nOldLength$ = -12 ; size = 4 _pOldData$ = -8 ; size = 4 _this$ = -4 ; size = 4 _nLength$ = 8 ; size = 4 ?Fork@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z PROC ; ATL::CSimpleStringT::Fork, COMDAT ; _this$ = ecx ; 783 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 5c sub esp, 92 ; 0000005cH 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 784 : CStringData* pOldData = GetData(); 0000c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0000f e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00014 89 45 f8 mov DWORD PTR _pOldData$[ebp], eax ; 785 : int nOldLength = pOldData->nDataLength; 00017 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 0001a 8b 48 04 mov ecx, DWORD PTR [eax+4] 0001d 89 4d f4 mov DWORD PTR _nOldLength$[ebp], ecx ; 786 : CStringData* pNewData = pOldData->pStringMgr->Clone()->Allocate( nLength, sizeof( XCHAR ) ); 00020 8b 45 f8 mov eax, DWORD PTR _pOldData$[ebp] 00023 8b 08 mov ecx, DWORD PTR [eax] 00025 8b 55 f8 mov edx, DWORD PTR _pOldData$[ebp] 00028 8b 01 mov eax, DWORD PTR [ecx] 0002a 8b 0a mov ecx, DWORD PTR [edx] 0002c 8b 50 10 mov edx, DWORD PTR [eax+16] 0002f ff d2 call edx 00031 89 45 a8 mov DWORD PTR tv76[ebp], eax 00034 8b 45 a8 mov eax, DWORD PTR tv76[ebp] 00037 8b 08 mov ecx, DWORD PTR [eax] 00039 8b 11 mov edx, DWORD PTR [ecx] 0003b 89 55 a4 mov DWORD PTR tv83[ebp], edx 0003e 6a 02 push 2 00040 8b 45 08 mov eax, DWORD PTR _nLength$[ebp] 00043 50 push eax 00044 8b 4d a8 mov ecx, DWORD PTR tv76[ebp] 00047 ff 55 a4 call DWORD PTR tv83[ebp] 0004a 89 45 f0 mov DWORD PTR _pNewData$[ebp], eax ; 787 : if( pNewData == NULL ) 0004d 83 7d f0 00 cmp DWORD PTR _pNewData$[ebp], 0 00051 75 05 jne SHORT $LN2@Fork ; 788 : { ; 789 : ThrowMemoryException(); 00053 e8 00 00 00 00 call ?ThrowMemoryException@?$CSimpleStringT@_W$0A@@ATL@@KAXXZ ; ATL::CSimpleStringT::ThrowMemoryException $LN2@Fork: ; 790 : } ; 791 : int nCharsToCopy = ((nOldLength < nLength) ? nOldLength : nLength)+1; // Copy '\0' 00058 8b 45 f4 mov eax, DWORD PTR _nOldLength$[ebp] 0005b 3b 45 08 cmp eax, DWORD PTR _nLength$[ebp] 0005e 7d 08 jge SHORT $LN4@Fork 00060 8b 4d f4 mov ecx, DWORD PTR _nOldLength$[ebp] 00063 89 4d a8 mov DWORD PTR tv86[ebp], ecx 00066 eb 06 jmp SHORT $LN5@Fork $LN4@Fork: 00068 8b 55 08 mov edx, DWORD PTR _nLength$[ebp] 0006b 89 55 a8 mov DWORD PTR tv86[ebp], edx $LN5@Fork: 0006e 8b 45 a8 mov eax, DWORD PTR tv86[ebp] 00071 83 c0 01 add eax, 1 00074 89 45 ec mov DWORD PTR _nCharsToCopy$[ebp], eax ; 792 : memcpy_s( PXSTR( pNewData->data() ), nCharsToCopy * sizeof( XCHAR ), 00077 8b 4d f8 mov ecx, DWORD PTR _pOldData$[ebp] 0007a e8 00 00 00 00 call ?data@CStringData@ATL@@QAEPAXXZ ; ATL::CStringData::data 0007f 89 45 a8 mov DWORD PTR tv134[ebp], eax 00082 8b 4d f0 mov ecx, DWORD PTR _pNewData$[ebp] 00085 e8 00 00 00 00 call ?data@CStringData@ATL@@QAEPAXXZ ; ATL::CStringData::data 0008a 89 45 a4 mov DWORD PTR tv132[ebp], eax 0008d 8b 45 ec mov eax, DWORD PTR _nCharsToCopy$[ebp] 00090 d1 e0 shl eax, 1 00092 50 push eax 00093 8b 4d a8 mov ecx, DWORD PTR tv134[ebp] 00096 51 push ecx 00097 8b 55 ec mov edx, DWORD PTR _nCharsToCopy$[ebp] 0009a d1 e2 shl edx, 1 0009c 52 push edx 0009d 8b 45 a4 mov eax, DWORD PTR tv132[ebp] 000a0 50 push eax 000a1 e8 00 00 00 00 call _memcpy_s 000a6 83 c4 10 add esp, 16 ; 00000010H ; 793 : PCXSTR( pOldData->data() ), nCharsToCopy * sizeof( XCHAR )); ; 794 : pNewData->nDataLength = nOldLength; 000a9 8b 45 f0 mov eax, DWORD PTR _pNewData$[ebp] 000ac 8b 4d f4 mov ecx, DWORD PTR _nOldLength$[ebp] 000af 89 48 04 mov DWORD PTR [eax+4], ecx ; 795 : pOldData->Release(); 000b2 8b 4d f8 mov ecx, DWORD PTR _pOldData$[ebp] 000b5 e8 00 00 00 00 call ?Release@CStringData@ATL@@QAEXXZ ; ATL::CStringData::Release ; 796 : Attach( pNewData ); 000ba 8b 45 f0 mov eax, DWORD PTR _pNewData$[ebp] 000bd 50 push eax 000be 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 000c1 e8 00 00 00 00 call ?Attach@?$CSimpleStringT@_W$0A@@ATL@@AAEXPAUCStringData@2@@Z ; ATL::CSimpleStringT::Attach $LN3@Fork: ; 797 : } 000c6 5f pop edi 000c7 5e pop esi 000c8 5b pop ebx 000c9 8b e5 mov esp, ebp 000cb 5d pop ebp 000cc c2 04 00 ret 4 ?Fork@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ENDP ; ATL::CSimpleStringT::Fork _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?Attach@?$CSimpleStringT@_W$0A@@ATL@@AAEXPAUCStringData@2@@Z _TEXT SEGMENT _this$ = -4 ; size = 4 _pData$ = 8 ; size = 4 ?Attach@?$CSimpleStringT@_W$0A@@ATL@@AAEXPAUCStringData@2@@Z PROC ; ATL::CSimpleStringT::Attach, COMDAT ; _this$ = ecx ; 779 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 780 : m_pszData = static_cast< PXSTR >( pData->data() ); 0000c 8b 4d 08 mov ecx, DWORD PTR _pData$[ebp] 0000f e8 00 00 00 00 call ?data@CStringData@ATL@@QAEPAXXZ ; ATL::CStringData::data 00014 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00017 89 01 mov DWORD PTR [ecx], eax ; 781 : } 00019 5f pop edi 0001a 5e pop esi 0001b 5b pop ebx 0001c 8b e5 mov esp, ebp 0001e 5d pop ebp 0001f c2 04 00 ret 4 ?Attach@?$CSimpleStringT@_W$0A@@ATL@@AAEXPAUCStringData@2@@Z ENDP ; ATL::CSimpleStringT::Attach _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?ThrowMemoryException@?$CSimpleStringT@_W$0A@@ATL@@KAXXZ _TEXT SEGMENT ?ThrowMemoryException@?$CSimpleStringT@_W$0A@@ATL@@KAXXZ PROC ; ATL::CSimpleStringT::ThrowMemoryException, COMDAT ; 772 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 773 : AtlThrow( E_OUTOFMEMORY ); 00009 68 0e 00 07 80 push -2147024882 ; 8007000eH 0000e e8 00 00 00 00 call ?AtlThrowImpl@ATL@@YGXJ@Z ; ATL::AtlThrowImpl $LN2@ThrowMemor: ; 774 : } 00013 5f pop edi 00014 5e pop esi 00015 5b pop ebx 00016 8b e5 mov esp, ebp 00018 5d pop ebp 00019 c3 ret 0 ?ThrowMemoryException@?$CSimpleStringT@_W$0A@@ATL@@KAXXZ ENDP ; ATL::CSimpleStringT::ThrowMemoryException _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z _TEXT SEGMENT __$EHRec$ = -12 ; size = 12 _psz$ = 8 ; size = 4 ?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z PROC ; ATL::CSimpleStringT::StringLength, COMDAT ; 729 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 40 sub esp, 64 ; 00000040H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax ; 730 : if( psz == NULL ) 00028 83 7d 08 00 cmp DWORD PTR _psz$[ebp], 0 0002c 75 04 jne SHORT $LN2@StringLeng ; 731 : { ; 732 : return( 0 ); 0002e 33 c0 xor eax, eax 00030 eb 0c jmp SHORT $LN1@StringLeng $LN2@StringLeng: ; 733 : } ; 734 : return( int( wcslen( psz ) ) ); 00032 8b 45 08 mov eax, DWORD PTR _psz$[ebp] 00035 50 push eax 00036 e8 00 00 00 00 call _wcslen 0003b 83 c4 04 add esp, 4 $LN1@StringLeng: ; 735 : } 0003e 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 00041 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 00048 59 pop ecx 00049 5f pop edi 0004a 5e pop esi 0004b 5b pop ebx 0004c 8b e5 mov esp, ebp 0004e 5d pop ebp 0004f c3 ret 0 00050 cc int 3 00051 cc int 3 00052 cc int 3 00053 cc int 3 00054 cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a b0 mov ecx, DWORD PTR [edx-80] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z ENDP ; ATL::CSimpleStringT::StringLength ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z _TEXT SEGMENT __$EHRec$ = -12 ; size = 12 _pchDest$ = 8 ; size = 4 _nDestLen$ = 12 ; size = 4 _pchSrc$ = 16 ; size = 4 _nChars$ = 20 ; size = 4 ?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z PROC ; ATL::CSimpleStringT::CopyCharsOverlapped, COMDAT ; 716 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 40 sub esp, 64 ; 00000040H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax ; 717 : memmove_s( pchDest, nDestLen*sizeof( XCHAR ), 00028 8b 45 14 mov eax, DWORD PTR _nChars$[ebp] 0002b d1 e0 shl eax, 1 0002d 50 push eax 0002e 8b 4d 10 mov ecx, DWORD PTR _pchSrc$[ebp] 00031 51 push ecx 00032 8b 55 0c mov edx, DWORD PTR _nDestLen$[ebp] 00035 d1 e2 shl edx, 1 00037 52 push edx 00038 8b 45 08 mov eax, DWORD PTR _pchDest$[ebp] 0003b 50 push eax 0003c e8 00 00 00 00 call _memmove_s 00041 83 c4 10 add esp, 16 ; 00000010H ; 718 : pchSrc, nChars*sizeof( XCHAR ) ); ; 719 : } 00044 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 00047 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 0004e 59 pop ecx 0004f 5f pop edi 00050 5e pop esi 00051 5b pop ebx 00052 8b e5 mov esp, ebp 00054 5d pop ebp 00055 c3 ret 0 00056 cc int 3 00057 cc int 3 00058 cc int 3 00059 cc int 3 0005a cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a b0 mov ecx, DWORD PTR [edx-80] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z ENDP ; ATL::CSimpleStringT::CopyCharsOverlapped ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_WH@Z _TEXT SEGMENT _pszBuffer$1 = -16 ; size = 4 _nOffset$2 = -12 ; size = 4 _nOldLength$3 = -8 ; size = 4 _this$ = -4 ; size = 4 _pszSrc$ = 8 ; size = 4 _nLength$ = 12 ; size = 4 ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_WH@Z PROC ; ATL::CSimpleStringT::SetString, COMDAT ; _this$ = ecx ; 607 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 50 sub esp, 80 ; 00000050H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 608 : if( nLength == 0 ) 0000c 83 7d 0c 00 cmp DWORD PTR _nLength$[ebp], 0 00010 75 0d jne SHORT $LN2@SetString ; 609 : { ; 610 : Empty(); 00012 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00015 e8 00 00 00 00 call ?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ ; ATL::CSimpleStringT::Empty ; 611 : } 0001a e9 96 00 00 00 jmp $LN7@SetString $LN2@SetString: ; 612 : else ; 613 : { ; 614 : // It is possible that pszSrc points to a location inside of our ; 615 : // buffer. GetBuffer() might change m_pszData if (1) the buffer ; 616 : // is shared or (2) the buffer is too small to hold the new ; 617 : // string. We detect this aliasing, and modify pszSrc to point ; 618 : // into the newly allocated buffer instead. ; 619 : ; 620 : if(pszSrc == NULL) 0001f 83 7d 08 00 cmp DWORD PTR _pszSrc$[ebp], 0 00023 75 0a jne SHORT $LN4@SetString ; 621 : AtlThrow(E_INVALIDARG); 00025 68 57 00 07 80 push -2147024809 ; 80070057H 0002a e8 00 00 00 00 call ?AtlThrowImpl@ATL@@YGXJ@Z ; ATL::AtlThrowImpl $LN4@SetString: ; 622 : ; 623 : UINT nOldLength = GetLength(); 0002f 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00032 e8 00 00 00 00 call ?GetLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ ; ATL::CSimpleStringT::GetLength 00037 89 45 f8 mov DWORD PTR _nOldLength$3[ebp], eax ; 624 : UINT_PTR nOffset = pszSrc-GetString(); 0003a 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0003d e8 00 00 00 00 call ?GetString@?$CSimpleStringT@_W$0A@@ATL@@QBEPB_WXZ ; ATL::CSimpleStringT::GetString 00042 8b 4d 08 mov ecx, DWORD PTR _pszSrc$[ebp] 00045 2b c8 sub ecx, eax 00047 d1 f9 sar ecx, 1 00049 89 4d f4 mov DWORD PTR _nOffset$2[ebp], ecx ; 625 : // If 0 <= nOffset <= nOldLength, then pszSrc points into our ; 626 : // buffer ; 627 : ; 628 : PXSTR pszBuffer = GetBuffer( nLength ); 0004c 8b 45 0c mov eax, DWORD PTR _nLength$[ebp] 0004f 50 push eax 00050 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00053 e8 00 00 00 00 call ?GetBuffer@?$CSimpleStringT@_W$0A@@ATL@@QAEPA_WH@Z ; ATL::CSimpleStringT::GetBuffer 00058 89 45 f0 mov DWORD PTR _pszBuffer$1[ebp], eax ; 629 : if( nOffset <= nOldLength ) 0005b 8b 45 f4 mov eax, DWORD PTR _nOffset$2[ebp] 0005e 3b 45 f8 cmp eax, DWORD PTR _nOldLength$3[ebp] 00061 77 25 ja SHORT $LN5@SetString ; 630 : { ; 631 : CopyCharsOverlapped( pszBuffer, GetAllocLength(), 00063 8b 45 0c mov eax, DWORD PTR _nLength$[ebp] 00066 50 push eax 00067 8b 4d f4 mov ecx, DWORD PTR _nOffset$2[ebp] 0006a 8b 55 f0 mov edx, DWORD PTR _pszBuffer$1[ebp] 0006d 8d 04 4a lea eax, DWORD PTR [edx+ecx*2] 00070 50 push eax 00071 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00074 e8 00 00 00 00 call ?GetAllocLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ ; ATL::CSimpleStringT::GetAllocLength 00079 50 push eax 0007a 8b 4d f0 mov ecx, DWORD PTR _pszBuffer$1[ebp] 0007d 51 push ecx 0007e e8 00 00 00 00 call ?CopyCharsOverlapped@?$CSimpleStringT@_W$0A@@ATL@@SAXPA_WIPB_WH@Z ; ATL::CSimpleStringT::CopyCharsOverlapped 00083 83 c4 10 add esp, 16 ; 00000010H ; 632 : pszBuffer+nOffset, nLength ); ; 633 : } 00086 eb 21 jmp SHORT $LN6@SetString $LN5@SetString: ; 634 : else ; 635 : { ; 636 : memcpy_s( pszBuffer, GetAllocLength() * sizeof( XCHAR ), pszSrc, nLength * sizeof( XCHAR )); 00088 8b 45 0c mov eax, DWORD PTR _nLength$[ebp] 0008b d1 e0 shl eax, 1 0008d 50 push eax 0008e 8b 4d 08 mov ecx, DWORD PTR _pszSrc$[ebp] 00091 51 push ecx 00092 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00095 e8 00 00 00 00 call ?GetAllocLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ ; ATL::CSimpleStringT::GetAllocLength 0009a d1 e0 shl eax, 1 0009c 50 push eax 0009d 8b 55 f0 mov edx, DWORD PTR _pszBuffer$1[ebp] 000a0 52 push edx 000a1 e8 00 00 00 00 call _memcpy_s 000a6 83 c4 10 add esp, 16 ; 00000010H $LN6@SetString: ; 637 : } ; 638 : ReleaseBufferSetLength( nLength ); 000a9 8b 45 0c mov eax, DWORD PTR _nLength$[ebp] 000ac 50 push eax 000ad 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 000b0 e8 00 00 00 00 call ?ReleaseBufferSetLength@?$CSimpleStringT@_W$0A@@ATL@@QAEXH@Z ; ATL::CSimpleStringT::ReleaseBufferSetLength $LN7@SetString: ; 639 : } ; 640 : } 000b5 5f pop edi 000b6 5e pop esi 000b7 5b pop ebx 000b8 8b e5 mov esp, ebp 000ba 5d pop ebp 000bb c2 08 00 ret 8 ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_WH@Z ENDP ; ATL::CSimpleStringT::SetString _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_W@Z _TEXT SEGMENT _this$ = -4 ; size = 4 _pszSrc$ = 8 ; size = 4 ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_W@Z PROC ; ATL::CSimpleStringT::SetString, COMDAT ; _this$ = ecx ; 601 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 602 : SetString( pszSrc, StringLength( pszSrc ) ); 0000c 8b 45 08 mov eax, DWORD PTR _pszSrc$[ebp] 0000f 50 push eax 00010 e8 00 00 00 00 call ?StringLength@?$CSimpleStringT@_W$0A@@ATL@@SAHPB_W@Z ; ATL::CSimpleStringT::StringLength 00015 83 c4 04 add esp, 4 00018 50 push eax 00019 8b 4d 08 mov ecx, DWORD PTR _pszSrc$[ebp] 0001c 51 push ecx 0001d 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00020 e8 00 00 00 00 call ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_WH@Z ; ATL::CSimpleStringT::SetString ; 603 : } 00025 5f pop edi 00026 5e pop esi 00027 5b pop ebx 00028 8b e5 mov esp, ebp 0002a 5d pop ebp 0002b c2 04 00 ret 4 ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_W@Z ENDP ; ATL::CSimpleStringT::SetString _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?ReleaseBufferSetLength@?$CSimpleStringT@_W$0A@@ATL@@QAEXH@Z _TEXT SEGMENT _this$ = -4 ; size = 4 _nNewLength$ = 8 ; size = 4 ?ReleaseBufferSetLength@?$CSimpleStringT@_W$0A@@ATL@@QAEXH@Z PROC ; ATL::CSimpleStringT::ReleaseBufferSetLength, COMDAT ; _this$ = ecx ; 566 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 567 : ATLASSERT( nNewLength >= 0 ); ; 568 : SetLength( nNewLength ); 0000c 8b 45 08 mov eax, DWORD PTR _nNewLength$[ebp] 0000f 50 push eax 00010 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00013 e8 00 00 00 00 call ?SetLength@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::SetLength ; 569 : } 00018 5f pop edi 00019 5e pop esi 0001a 5b pop ebx 0001b 8b e5 mov esp, ebp 0001d 5d pop ebp 0001e c2 04 00 ret 4 ?ReleaseBufferSetLength@?$CSimpleStringT@_W$0A@@ATL@@QAEXH@Z ENDP ; ATL::CSimpleStringT::ReleaseBufferSetLength _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?GetString@?$CSimpleStringT@_W$0A@@ATL@@QBEPB_WXZ _TEXT SEGMENT _this$ = -4 ; size = 4 ?GetString@?$CSimpleStringT@_W$0A@@ATL@@QBEPB_WXZ PROC ; ATL::CSimpleStringT::GetString, COMDAT ; _this$ = ecx ; 528 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 529 : return( m_pszData ); 0000c 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0000f 8b 00 mov eax, DWORD PTR [eax] ; 530 : } 00011 5f pop edi 00012 5e pop esi 00013 5b pop ebx 00014 8b e5 mov esp, ebp 00016 5d pop ebp 00017 c3 ret 0 ?GetString@?$CSimpleStringT@_W$0A@@ATL@@QBEPB_WXZ ENDP ; ATL::CSimpleStringT::GetString _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?GetLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ _TEXT SEGMENT _this$ = -4 ; size = 4 ?GetLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ PROC ; ATL::CSimpleStringT::GetLength, COMDAT ; _this$ = ecx ; 518 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 519 : return( GetData()->nDataLength ); 0000c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0000f e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00014 8b 40 04 mov eax, DWORD PTR [eax+4] ; 520 : } 00017 5f pop edi 00018 5e pop esi 00019 5b pop ebx 0001a 8b e5 mov esp, ebp 0001c 5d pop ebp 0001d c3 ret 0 ?GetLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ ENDP ; ATL::CSimpleStringT::GetLength _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?GetBuffer@?$CSimpleStringT@_W$0A@@ATL@@QAEPA_WH@Z _TEXT SEGMENT _this$ = -4 ; size = 4 _nMinBufferLength$ = 8 ; size = 4 ?GetBuffer@?$CSimpleStringT@_W$0A@@ATL@@QAEPA_WH@Z PROC ; ATL::CSimpleStringT::GetBuffer, COMDAT ; _this$ = ecx ; 507 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 508 : return( PrepareWrite( nMinBufferLength ) ); 0000c 8b 45 08 mov eax, DWORD PTR _nMinBufferLength$[ebp] 0000f 50 push eax 00010 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00013 e8 00 00 00 00 call ?PrepareWrite@?$CSimpleStringT@_W$0A@@ATL@@AAEPA_WH@Z ; ATL::CSimpleStringT::PrepareWrite ; 509 : } 00018 5f pop edi 00019 5e pop esi 0001a 5b pop ebx 0001b 8b e5 mov esp, ebp 0001d 5d pop ebp 0001e c2 04 00 ret 4 ?GetBuffer@?$CSimpleStringT@_W$0A@@ATL@@QAEPA_WH@Z ENDP ; ATL::CSimpleStringT::GetBuffer _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?GetAllocLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ _TEXT SEGMENT _this$ = -4 ; size = 4 ?GetAllocLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ PROC ; ATL::CSimpleStringT::GetAllocLength, COMDAT ; _this$ = ecx ; 485 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 486 : return( GetData()->nAllocLength ); 0000c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0000f e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00014 8b 40 08 mov eax, DWORD PTR [eax+8] ; 487 : } 00017 5f pop edi 00018 5e pop esi 00019 5b pop ebx 0001a 8b e5 mov esp, ebp 0001c 5d pop ebp 0001d c3 ret 0 ?GetAllocLength@?$CSimpleStringT@_W$0A@@ATL@@QBEHXZ ENDP ; ATL::CSimpleStringT::GetAllocLength _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ _TEXT SEGMENT _pNewData$2 = -28 ; size = 4 _pStringMgr$ = -24 ; size = 4 _pOldData$ = -20 ; size = 4 _this$ = -16 ; size = 4 __$EHRec$ = -12 ; size = 12 ?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ PROC ; ATL::CSimpleStringT::Empty, COMDAT ; _this$ = ecx ; 436 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 50 sub esp, 80 ; 00000050H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax 00028 89 4d f0 mov DWORD PTR _this$[ebp], ecx ; 437 : CStringData* pOldData = GetData(); 0002b 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 0002e e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00033 89 45 ec mov DWORD PTR _pOldData$[ebp], eax ; 438 : IAtlStringMgr* pStringMgr = pOldData->pStringMgr; 00036 8b 45 ec mov eax, DWORD PTR _pOldData$[ebp] 00039 8b 08 mov ecx, DWORD PTR [eax] 0003b 89 4d e8 mov DWORD PTR _pStringMgr$[ebp], ecx ; 439 : if( pOldData->nDataLength == 0 ) 0003e 8b 45 ec mov eax, DWORD PTR _pOldData$[ebp] 00041 83 78 04 00 cmp DWORD PTR [eax+4], 0 00045 75 02 jne SHORT $LN2@Empty ; 440 : { ; 441 : return; 00047 eb 3f jmp SHORT $LN1@Empty $LN2@Empty: ; 442 : } ; 443 : ; 444 : if( pOldData->IsLocked() ) 00049 8b 4d ec mov ecx, DWORD PTR _pOldData$[ebp] 0004c e8 00 00 00 00 call ?IsLocked@CStringData@ATL@@QBE_NXZ ; ATL::CStringData::IsLocked 00051 0f b6 c0 movzx eax, al 00054 85 c0 test eax, eax 00056 74 0c je SHORT $LN3@Empty ; 445 : { ; 446 : // Don't reallocate a locked buffer that's shrinking ; 447 : SetLength( 0 ); 00058 6a 00 push 0 0005a 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 0005d e8 00 00 00 00 call ?SetLength@?$CSimpleStringT@_W$0A@@ATL@@AAEXH@Z ; ATL::CSimpleStringT::SetLength ; 448 : } 00062 eb 24 jmp SHORT $LN1@Empty $LN3@Empty: ; 449 : else ; 450 : { ; 451 : pOldData->Release(); 00064 8b 4d ec mov ecx, DWORD PTR _pOldData$[ebp] 00067 e8 00 00 00 00 call ?Release@CStringData@ATL@@QAEXXZ ; ATL::CStringData::Release ; 452 : CStringData* pNewData = pStringMgr->GetNilString(); 0006c 8b 45 e8 mov eax, DWORD PTR _pStringMgr$[ebp] 0006f 8b 10 mov edx, DWORD PTR [eax] 00071 8b 4d e8 mov ecx, DWORD PTR _pStringMgr$[ebp] 00074 8b 42 0c mov eax, DWORD PTR [edx+12] 00077 ff d0 call eax 00079 89 45 e4 mov DWORD PTR _pNewData$2[ebp], eax ; 453 : Attach( pNewData ); 0007c 8b 45 e4 mov eax, DWORD PTR _pNewData$2[ebp] 0007f 50 push eax 00080 8b 4d f0 mov ecx, DWORD PTR _this$[ebp] 00083 e8 00 00 00 00 call ?Attach@?$CSimpleStringT@_W$0A@@ATL@@AAEXPAUCStringData@2@@Z ; ATL::CSimpleStringT::Attach $LN1@Empty: ; 454 : } ; 455 : } 00088 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 0008b 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 00092 59 pop ecx 00093 5f pop edi 00094 5e pop esi 00095 5b pop ebx 00096 8b e5 mov esp, ebp 00098 5d pop ebp 00099 c3 ret 0 0009a cc int 3 0009b cc int 3 0009c cc int 3 0009d cc int 3 0009e cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a a0 mov ecx, DWORD PTR [edx-96] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?Empty@?$CSimpleStringT@_W$0A@@ATL@@QAEXXZ ENDP ; ATL::CSimpleStringT::Empty ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ??4?$CSimpleStringT@_W$0A@@ATL@@QAEAAV01@PB_W@Z _TEXT SEGMENT _this$ = -4 ; size = 4 _pszSrc$ = 8 ; size = 4 ??4?$CSimpleStringT@_W$0A@@ATL@@QAEAAV01@PB_W@Z PROC ; ATL::CSimpleStringT::operator=, COMDAT ; _this$ = ecx ; 313 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 314 : SetString( pszSrc ); 0000c 8b 45 08 mov eax, DWORD PTR _pszSrc$[ebp] 0000f 50 push eax 00010 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00013 e8 00 00 00 00 call ?SetString@?$CSimpleStringT@_W$0A@@ATL@@QAEXPB_W@Z ; ATL::CSimpleStringT::SetString ; 315 : ; 316 : return( *this ); 00018 8b 45 fc mov eax, DWORD PTR _this$[ebp] ; 317 : } 0001b 5f pop edi 0001c 5e pop esi 0001d 5b pop ebx 0001e 8b e5 mov esp, ebp 00020 5d pop ebp 00021 c2 04 00 ret 4 ??4?$CSimpleStringT@_W$0A@@ATL@@QAEAAV01@PB_W@Z ENDP ; ATL::CSimpleStringT::operator= _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ??1?$CSimpleStringT@_W$0A@@ATL@@QAE@XZ _TEXT SEGMENT _pData$ = -8 ; size = 4 _this$ = -4 ; size = 4 ??1?$CSimpleStringT@_W$0A@@ATL@@QAE@XZ PROC ; ATL::CSimpleStringT::~CSimpleStringT, COMDAT ; _this$ = ecx ; 260 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 48 sub esp, 72 ; 00000048H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 261 : CStringData* pData = GetData(); 0000c 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 0000f e8 00 00 00 00 call ?GetData@?$CSimpleStringT@_W$0A@@ATL@@ABEPAUCStringData@2@XZ ; ATL::CSimpleStringT::GetData 00014 89 45 f8 mov DWORD PTR _pData$[ebp], eax ; 262 : pData->Release(); 00017 8b 4d f8 mov ecx, DWORD PTR _pData$[ebp] 0001a e8 00 00 00 00 call ?Release@CStringData@ATL@@QAEXXZ ; ATL::CStringData::Release ; 263 : } 0001f 5f pop edi 00020 5e pop esi 00021 5b pop ebx 00022 8b e5 mov esp, ebp 00024 5d pop ebp 00025 c3 ret 0 ??1?$CSimpleStringT@_W$0A@@ATL@@QAE@XZ ENDP ; ATL::CSimpleStringT::~CSimpleStringT _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ??0?$CSimpleStringT@_W$0A@@ATL@@QAE@PAUIAtlStringMgr@1@@Z _TEXT SEGMENT tv65 = -80 ; size = 4 _pData$ = -12 ; size = 4 ___atl_condVal$1 = -8 ; size = 4 _this$ = -4 ; size = 4 _pStringMgr$ = 8 ; size = 4 ??0?$CSimpleStringT@_W$0A@@ATL@@QAE@PAUIAtlStringMgr@1@@Z PROC ; ATL::CSimpleStringT::CSimpleStringT, COMDAT ; _this$ = ecx ; 203 : explicit CSimpleStringT(_Inout_ IAtlStringMgr* pStringMgr) 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 50 sub esp, 80 ; 00000050H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx $LN4@CSimpleStr: ; 204 : { ; 205 : ATLENSURE( pStringMgr != NULL ); 0000c 83 7d 08 00 cmp DWORD PTR _pStringMgr$[ebp], 0 00010 74 09 je SHORT $LN10@CSimpleStr 00012 c7 45 b0 01 00 00 00 mov DWORD PTR tv65[ebp], 1 00019 eb 07 jmp SHORT $LN11@CSimpleStr $LN10@CSimpleStr: 0001b c7 45 b0 00 00 00 00 mov DWORD PTR tv65[ebp], 0 $LN11@CSimpleStr: 00022 8b 45 b0 mov eax, DWORD PTR tv65[ebp] 00025 89 45 f8 mov DWORD PTR ___atl_condVal$1[ebp], eax $LN5@CSimpleStr: 00028 33 c0 xor eax, eax 0002a 75 fc jne SHORT $LN5@CSimpleStr 0002c 83 7d f8 00 cmp DWORD PTR ___atl_condVal$1[ebp], 0 00030 75 0a jne SHORT $LN2@CSimpleStr 00032 68 05 40 00 80 push -2147467259 ; 80004005H 00037 e8 00 00 00 00 call ?AtlThrowImpl@ATL@@YGXJ@Z ; ATL::AtlThrowImpl $LN2@CSimpleStr: 0003c 33 c0 xor eax, eax 0003e 75 cc jne SHORT $LN4@CSimpleStr ; 206 : CStringData* pData = pStringMgr->GetNilString(); 00040 8b 45 08 mov eax, DWORD PTR _pStringMgr$[ebp] 00043 8b 10 mov edx, DWORD PTR [eax] 00045 8b 4d 08 mov ecx, DWORD PTR _pStringMgr$[ebp] 00048 8b 42 0c mov eax, DWORD PTR [edx+12] 0004b ff d0 call eax 0004d 89 45 f4 mov DWORD PTR _pData$[ebp], eax ; 207 : Attach( pData ); 00050 8b 45 f4 mov eax, DWORD PTR _pData$[ebp] 00053 50 push eax 00054 8b 4d fc mov ecx, DWORD PTR _this$[ebp] 00057 e8 00 00 00 00 call ?Attach@?$CSimpleStringT@_W$0A@@ATL@@AAEXPAUCStringData@2@@Z ; ATL::CSimpleStringT::Attach ; 208 : } 0005c 8b 45 fc mov eax, DWORD PTR _this$[ebp] $LN9@CSimpleStr: 0005f 5f pop edi 00060 5e pop esi 00061 5b pop ebx 00062 8b e5 mov esp, ebp 00064 5d pop ebp 00065 c2 04 00 ret 4 ??0?$CSimpleStringT@_W$0A@@ATL@@QAE@PAUIAtlStringMgr@1@@Z ENDP ; ATL::CSimpleStringT::CSimpleStringT _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ?ConvertToBaseType@?$ChTraitsCRT@_W@ATL@@SAXPA_WHPB_WH@Z _TEXT SEGMENT _pszDest$ = 8 ; size = 4 _nDestLength$ = 12 ; size = 4 _pszSrc$ = 16 ; size = 4 _nSrcLength$ = 20 ; size = 4 ?ConvertToBaseType@?$ChTraitsCRT@_W@ATL@@SAXPA_WHPB_WH@Z PROC ; ATL::ChTraitsCRT::ConvertToBaseType, COMDAT ; 789 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 790 : if (nSrcLength == -1) { nSrcLength=1 + GetBaseTypeLength(pszSrc); } 00009 83 7d 14 ff cmp DWORD PTR _nSrcLength$[ebp], -1 0000d 75 12 jne SHORT $LN2@ConvertToB 0000f 8b 45 10 mov eax, DWORD PTR _pszSrc$[ebp] 00012 50 push eax 00013 e8 00 00 00 00 call ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z ; ATL::ChTraitsCRT::GetBaseTypeLength 00018 83 c4 04 add esp, 4 0001b 83 c0 01 add eax, 1 0001e 89 45 14 mov DWORD PTR _nSrcLength$[ebp], eax $LN2@ConvertToB: ; 791 : // nLen is in wchar_ts ; 792 : Checked::wmemcpy_s(pszDest, nDestLength, pszSrc, nSrcLength); 00021 8b 45 14 mov eax, DWORD PTR _nSrcLength$[ebp] 00024 50 push eax 00025 8b 4d 10 mov ecx, DWORD PTR _pszSrc$[ebp] 00028 51 push ecx 00029 8b 55 0c mov edx, DWORD PTR _nDestLength$[ebp] 0002c 52 push edx 0002d 8b 45 08 mov eax, DWORD PTR _pszDest$[ebp] 00030 50 push eax 00031 e8 00 00 00 00 call ?wmemcpy_s@Checked@ATL@@YAXPA_WIPB_WI@Z ; ATL::Checked::wmemcpy_s 00036 83 c4 10 add esp, 16 ; 00000010H ; 793 : } 00039 5f pop edi 0003a 5e pop esi 0003b 5b pop ebx 0003c 8b e5 mov esp, ebp 0003e 5d pop ebp 0003f c3 ret 0 ?ConvertToBaseType@?$ChTraitsCRT@_W@ATL@@SAXPA_WHPB_WH@Z ENDP ; ATL::ChTraitsCRT::ConvertToBaseType _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_WH@Z _TEXT SEGMENT _pszSrc$ = 8 ; size = 4 _nLength$ = 12 ; size = 4 ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_WH@Z PROC ; ATL::ChTraitsCRT::GetBaseTypeLength, COMDAT ; 768 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 769 : (void)pszSrc; ; 770 : // Returns required buffer size in wchar_ts ; 771 : return nLength; 00009 8b 45 0c mov eax, DWORD PTR _nLength$[ebp] ; 772 : } 0000c 5f pop edi 0000d 5e pop esi 0000e 5b pop ebx 0000f 8b e5 mov esp, ebp 00011 5d pop ebp 00012 c3 ret 0 ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_WH@Z ENDP ; ATL::ChTraitsCRT::GetBaseTypeLength _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\cstringt.h ; COMDAT ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z _TEXT SEGMENT __$EHRec$ = -12 ; size = 12 _pszSrc$ = 8 ; size = 4 ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z PROC ; ATL::ChTraitsCRT::GetBaseTypeLength, COMDAT ; 760 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 40 sub esp, 64 ; 00000040H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax ; 761 : // Returns required buffer size in wchar_ts ; 762 : return AtlStrLen( pszSrc ); 00028 8b 45 08 mov eax, DWORD PTR _pszSrc$[ebp] 0002b 50 push eax 0002c e8 00 00 00 00 call ?AtlStrLen@ATL@@YAHPB_W@Z ; ATL::AtlStrLen 00031 83 c4 04 add esp, 4 ; 763 : } 00034 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 00037 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 0003e 59 pop ecx 0003f 5f pop edi 00040 5e pop esi 00041 5b pop ebx 00042 8b e5 mov esp, ebp 00044 5d pop ebp 00045 c3 ret 0 00046 cc int 3 00047 cc int 3 00048 cc int 3 00049 cc int 3 0004a cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a b0 mov ecx, DWORD PTR [edx-80] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?GetBaseTypeLength@?$ChTraitsCRT@_W@ATL@@SAHPB_W@Z ENDP ; ATL::ChTraitsCRT::GetBaseTypeLength ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?Release@CStringData@ATL@@QAEXXZ _TEXT SEGMENT tv79 = -76 ; size = 4 tv77 = -72 ; size = 4 _this$ = -4 ; size = 4 ?Release@CStringData@ATL@@QAEXXZ PROC ; ATL::CStringData::Release, COMDAT ; _this$ = ecx ; 85 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 4c sub esp, 76 ; 0000004cH 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 86 : ATLASSERT( nRefs != 0 ); ; 87 : ; 88 : if( _InterlockedDecrement( &nRefs ) <= 0 ) 0000c 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0000f 83 c0 0c add eax, 12 ; 0000000cH 00012 83 c9 ff or ecx, -1 00015 f0 0f c1 08 lock xadd DWORD PTR [eax], ecx 00019 49 dec ecx 0001a 85 c9 test ecx, ecx 0001c 7f 1f jg SHORT $LN1@Release ; 89 : { ; 90 : pStringMgr->Free( this ); 0001e 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00021 8b 08 mov ecx, DWORD PTR [eax] 00023 89 4d b8 mov DWORD PTR tv77[ebp], ecx 00026 8b 55 fc mov edx, DWORD PTR _this$[ebp] 00029 8b 02 mov eax, DWORD PTR [edx] 0002b 8b 08 mov ecx, DWORD PTR [eax] 0002d 8b 51 04 mov edx, DWORD PTR [ecx+4] 00030 89 55 b4 mov DWORD PTR tv79[ebp], edx 00033 8b 45 fc mov eax, DWORD PTR _this$[ebp] 00036 50 push eax 00037 8b 4d b8 mov ecx, DWORD PTR tv77[ebp] 0003a ff 55 b4 call DWORD PTR tv79[ebp] $LN1@Release: ; 91 : } ; 92 : } 0003d 5f pop edi 0003e 5e pop esi 0003f 5b pop ebx 00040 8b e5 mov esp, ebp 00042 5d pop ebp 00043 c3 ret 0 ?Release@CStringData@ATL@@QAEXXZ ENDP ; ATL::CStringData::Release _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?IsShared@CStringData@ATL@@QBE_NXZ _TEXT SEGMENT tv66 = -72 ; size = 4 _this$ = -4 ; size = 4 ?IsShared@CStringData@ATL@@QBE_NXZ PROC ; ATL::CStringData::IsShared, COMDAT ; _this$ = ecx ; 72 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 48 sub esp, 72 ; 00000048H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 73 : return( nRefs > 1 ); 0000c 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0000f 83 78 0c 01 cmp DWORD PTR [eax+12], 1 00013 7e 09 jle SHORT $LN3@IsShared 00015 c7 45 b8 01 00 00 00 mov DWORD PTR tv66[ebp], 1 0001c eb 07 jmp SHORT $LN4@IsShared $LN3@IsShared: 0001e c7 45 b8 00 00 00 00 mov DWORD PTR tv66[ebp], 0 $LN4@IsShared: 00025 8a 45 b8 mov al, BYTE PTR tv66[ebp] ; 74 : } 00028 5f pop edi 00029 5e pop esi 0002a 5b pop ebx 0002b 8b e5 mov esp, ebp 0002d 5d pop ebp 0002e c3 ret 0 ?IsShared@CStringData@ATL@@QBE_NXZ ENDP ; ATL::CStringData::IsShared _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?IsLocked@CStringData@ATL@@QBE_NXZ _TEXT SEGMENT tv66 = -72 ; size = 4 _this$ = -4 ; size = 4 ?IsLocked@CStringData@ATL@@QBE_NXZ PROC ; ATL::CStringData::IsLocked, COMDAT ; _this$ = ecx ; 68 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 48 sub esp, 72 ; 00000048H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 69 : return nRefs < 0; 0000c 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0000f 83 78 0c 00 cmp DWORD PTR [eax+12], 0 00013 7d 09 jge SHORT $LN3@IsLocked 00015 c7 45 b8 01 00 00 00 mov DWORD PTR tv66[ebp], 1 0001c eb 07 jmp SHORT $LN4@IsLocked $LN3@IsLocked: 0001e c7 45 b8 00 00 00 00 mov DWORD PTR tv66[ebp], 0 $LN4@IsLocked: 00025 8a 45 b8 mov al, BYTE PTR tv66[ebp] ; 70 : } 00028 5f pop edi 00029 5e pop esi 0002a 5b pop ebx 0002b 8b e5 mov esp, ebp 0002d 5d pop ebp 0002e c3 ret 0 ?IsLocked@CStringData@ATL@@QBE_NXZ ENDP ; ATL::CStringData::IsLocked _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlsimpstr.h ; COMDAT ?data@CStringData@ATL@@QAEPAXXZ _TEXT SEGMENT _this$ = -4 ; size = 4 ?data@CStringData@ATL@@QAEPAXXZ PROC ; ATL::CStringData::data, COMDAT ; _this$ = ecx ; 58 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 89 4d fc mov DWORD PTR _this$[ebp], ecx ; 59 : return (this+1); 0000c 8b 45 fc mov eax, DWORD PTR _this$[ebp] 0000f 83 c0 10 add eax, 16 ; 00000010H ; 60 : } 00012 5f pop edi 00013 5e pop esi 00014 5b pop ebx 00015 8b e5 mov esp, ebp 00017 5d pop ebp 00018 c3 ret 0 ?data@CStringData@ATL@@QAEPAXXZ ENDP ; ATL::CStringData::data _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlcore.h ; COMDAT ?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z _TEXT SEGMENT _hResource$ = -16 ; size = 4 __$EHRec$ = -12 ; size = 12 _hInstance$ = 8 ; size = 4 _id$ = 12 ; size = 4 ?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z PROC ; ATL::AtlGetStringResourceImage, COMDAT ; 370 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 44 sub esp, 68 ; 00000044H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax ; 371 : HRSRC hResource; ; 372 : /* ; 373 : The and operation (& static_cast(~0)) protects the expression from being greater ; 374 : than WORD - this would cause a runtime error when the application is compiled with /RTCc flag. ; 375 : */ ; 376 : hResource = ::FindResourceW(hInstance, MAKEINTRESOURCEW( (((id>>4)+1) & static_cast(~0)) ), (LPWSTR) RT_STRING); 00028 6a 06 push 6 0002a 8b 45 0c mov eax, DWORD PTR _id$[ebp] 0002d c1 e8 04 shr eax, 4 00030 83 c0 01 add eax, 1 00033 25 ff ff 00 00 and eax, 65535 ; 0000ffffH 00038 0f b7 c8 movzx ecx, ax 0003b 51 push ecx 0003c 8b 55 08 mov edx, DWORD PTR _hInstance$[ebp] 0003f 52 push edx 00040 ff 15 00 00 00 00 call DWORD PTR __imp__FindResourceW@12 00046 89 45 f0 mov DWORD PTR _hResource$[ebp], eax ; 377 : if( hResource == NULL ) 00049 83 7d f0 00 cmp DWORD PTR _hResource$[ebp], 0 0004d 75 04 jne SHORT $LN2@AtlGetStri ; 378 : { ; 379 : return( NULL ); 0004f 33 c0 xor eax, eax 00051 eb 14 jmp SHORT $LN1@AtlGetStri $LN2@AtlGetStri: ; 380 : } ; 381 : ; 382 : return _AtlGetStringResourceImage( hInstance, hResource, id ); 00053 8b 45 0c mov eax, DWORD PTR _id$[ebp] 00056 50 push eax 00057 8b 4d f0 mov ecx, DWORD PTR _hResource$[ebp] 0005a 51 push ecx 0005b 8b 55 08 mov edx, DWORD PTR _hInstance$[ebp] 0005e 52 push edx 0005f e8 00 00 00 00 call ?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z ; ATL::_AtlGetStringResourceImage 00064 83 c4 0c add esp, 12 ; 0000000cH $LN1@AtlGetStri: ; 383 : } 00067 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 0006a 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 00071 59 pop ecx 00072 5f pop edi 00073 5e pop esi 00074 5b pop ebx 00075 8b e5 mov esp, ebp 00077 5d pop ebp 00078 c3 ret 0 00079 cc int 3 0007a cc int 3 0007b cc int 3 0007c cc int 3 0007d cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a ac mov ecx, DWORD PTR [edx-84] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@I@Z ENDP ; ATL::AtlGetStringResourceImage ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlcore.h ; COMDAT ?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z _TEXT SEGMENT _iIndex$ = -32 ; size = 4 _hGlobal$ = -28 ; size = 4 _nResourceSize$ = -24 ; size = 4 _pImageEnd$ = -20 ; size = 4 _pImage$ = -16 ; size = 4 __$EHRec$ = -12 ; size = 12 _hInstance$ = 8 ; size = 4 _hResource$ = 12 ; size = 4 _id$ = 16 ; size = 4 ?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z PROC ; ATL::_AtlGetStringResourceImage, COMDAT ; 327 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 6a ff push -1 00005 68 00 00 00 00 push __ehhandler$?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z 0000a 64 a1 00 00 00 00 mov eax, DWORD PTR fs:0 00010 50 push eax 00011 83 ec 54 sub esp, 84 ; 00000054H 00014 53 push ebx 00015 56 push esi 00016 57 push edi 00017 a1 00 00 00 00 mov eax, DWORD PTR ___security_cookie 0001c 33 c5 xor eax, ebp 0001e 50 push eax 0001f 8d 45 f4 lea eax, DWORD PTR __$EHRec$[ebp] 00022 64 a3 00 00 00 00 mov DWORD PTR fs:0, eax ; 328 : const ATLSTRINGRESOURCEIMAGE* pImage; ; 329 : const ATLSTRINGRESOURCEIMAGE* pImageEnd; ; 330 : ULONG nResourceSize; ; 331 : HGLOBAL hGlobal; ; 332 : UINT iIndex; ; 333 : ; 334 : hGlobal = ::LoadResource( hInstance, hResource ); 00028 8b 45 0c mov eax, DWORD PTR _hResource$[ebp] 0002b 50 push eax 0002c 8b 4d 08 mov ecx, DWORD PTR _hInstance$[ebp] 0002f 51 push ecx 00030 ff 15 00 00 00 00 call DWORD PTR __imp__LoadResource@8 00036 89 45 e4 mov DWORD PTR _hGlobal$[ebp], eax ; 335 : if( hGlobal == NULL ) 00039 83 7d e4 00 cmp DWORD PTR _hGlobal$[ebp], 0 0003d 75 07 jne SHORT $LN4@AtlGetStri ; 336 : { ; 337 : return( NULL ); 0003f 33 c0 xor eax, eax 00041 e9 80 00 00 00 jmp $LN1@AtlGetStri $LN4@AtlGetStri: ; 338 : } ; 339 : ; 340 : pImage = (const ATLSTRINGRESOURCEIMAGE*)::LockResource( hGlobal ); 00046 8b 45 e4 mov eax, DWORD PTR _hGlobal$[ebp] 00049 50 push eax 0004a ff 15 00 00 00 00 call DWORD PTR __imp__LockResource@4 00050 89 45 f0 mov DWORD PTR _pImage$[ebp], eax ; 341 : if( pImage == NULL ) 00053 83 7d f0 00 cmp DWORD PTR _pImage$[ebp], 0 00057 75 04 jne SHORT $LN5@AtlGetStri ; 342 : { ; 343 : return( NULL ); 00059 33 c0 xor eax, eax 0005b eb 69 jmp SHORT $LN1@AtlGetStri $LN5@AtlGetStri: ; 344 : } ; 345 : ; 346 : nResourceSize = ::SizeofResource( hInstance, hResource ); 0005d 8b 45 0c mov eax, DWORD PTR _hResource$[ebp] 00060 50 push eax 00061 8b 4d 08 mov ecx, DWORD PTR _hInstance$[ebp] 00064 51 push ecx 00065 ff 15 00 00 00 00 call DWORD PTR __imp__SizeofResource@8 0006b 89 45 e8 mov DWORD PTR _nResourceSize$[ebp], eax ; 347 : pImageEnd = (const ATLSTRINGRESOURCEIMAGE*)(LPBYTE( pImage )+nResourceSize); 0006e 8b 45 f0 mov eax, DWORD PTR _pImage$[ebp] 00071 03 45 e8 add eax, DWORD PTR _nResourceSize$[ebp] 00074 89 45 ec mov DWORD PTR _pImageEnd$[ebp], eax ; 348 : iIndex = id&0x000f; 00077 8b 45 10 mov eax, DWORD PTR _id$[ebp] 0007a 83 e0 0f and eax, 15 ; 0000000fH 0007d 89 45 e0 mov DWORD PTR _iIndex$[ebp], eax $LN2@AtlGetStri: ; 349 : ; 350 : while( (iIndex > 0) && (pImage < pImageEnd) ) 00080 83 7d e0 00 cmp DWORD PTR _iIndex$[ebp], 0 00084 76 23 jbe SHORT $LN3@AtlGetStri 00086 8b 45 f0 mov eax, DWORD PTR _pImage$[ebp] 00089 3b 45 ec cmp eax, DWORD PTR _pImageEnd$[ebp] 0008c 73 1b jae SHORT $LN3@AtlGetStri ; 351 : { ; 352 : pImage = (const ATLSTRINGRESOURCEIMAGE*)(LPBYTE( pImage )+(sizeof( ATLSTRINGRESOURCEIMAGE )+(pImage->nLength*sizeof( WCHAR )))); 0008e 8b 45 f0 mov eax, DWORD PTR _pImage$[ebp] 00091 0f b7 08 movzx ecx, WORD PTR [eax] 00094 8b 55 f0 mov edx, DWORD PTR _pImage$[ebp] 00097 8d 44 4a 02 lea eax, DWORD PTR [edx+ecx*2+2] 0009b 89 45 f0 mov DWORD PTR _pImage$[ebp], eax ; 353 : iIndex--; 0009e 8b 45 e0 mov eax, DWORD PTR _iIndex$[ebp] 000a1 83 e8 01 sub eax, 1 000a4 89 45 e0 mov DWORD PTR _iIndex$[ebp], eax ; 354 : } 000a7 eb d7 jmp SHORT $LN2@AtlGetStri $LN3@AtlGetStri: ; 355 : if( pImage >= pImageEnd ) 000a9 8b 45 f0 mov eax, DWORD PTR _pImage$[ebp] 000ac 3b 45 ec cmp eax, DWORD PTR _pImageEnd$[ebp] 000af 72 04 jb SHORT $LN6@AtlGetStri ; 356 : { ; 357 : return( NULL ); 000b1 33 c0 xor eax, eax 000b3 eb 11 jmp SHORT $LN1@AtlGetStri $LN6@AtlGetStri: ; 358 : } ; 359 : if( pImage->nLength == 0 ) 000b5 8b 45 f0 mov eax, DWORD PTR _pImage$[ebp] 000b8 0f b7 08 movzx ecx, WORD PTR [eax] 000bb 85 c9 test ecx, ecx 000bd 75 04 jne SHORT $LN7@AtlGetStri ; 360 : { ; 361 : return( NULL ); 000bf 33 c0 xor eax, eax 000c1 eb 03 jmp SHORT $LN1@AtlGetStri $LN7@AtlGetStri: ; 362 : } ; 363 : ; 364 : return( pImage ); 000c3 8b 45 f0 mov eax, DWORD PTR _pImage$[ebp] $LN1@AtlGetStri: ; 365 : } 000c6 8b 4d f4 mov ecx, DWORD PTR __$EHRec$[ebp] 000c9 64 89 0d 00 00 00 00 mov DWORD PTR fs:0, ecx 000d0 59 pop ecx 000d1 5f pop edi 000d2 5e pop esi 000d3 5b pop ebx 000d4 8b e5 mov esp, ebp 000d6 5d pop ebp 000d7 c3 ret 0 000d8 cc int 3 000d9 cc int 3 000da cc int 3 000db cc int 3 000dc cc int 3 _TEXT ENDS ; COMDAT text$x text$x SEGMENT __ehhandler$?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z: 00000 90 npad 1 00001 90 npad 1 00002 8b 54 24 08 mov edx, DWORD PTR [esp+8] 00006 8d 42 0c lea eax, DWORD PTR [edx+12] 00009 8b 4a 9c mov ecx, DWORD PTR [edx-100] 0000c 33 c8 xor ecx, eax 0000e e8 00 00 00 00 call @__security_check_cookie@4 00013 b8 00 00 00 00 mov eax, OFFSET __ehfuncinfo$?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z 00018 e9 00 00 00 00 jmp ___CxxFrameHandler3 text$x ENDS ?_AtlGetStringResourceImage@ATL@@YAPBUATLSTRINGRESOURCEIMAGE@1@PAUHINSTANCE__@@PAUHRSRC__@@I@Z ENDP ; ATL::_AtlGetStringResourceImage ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlcore.h ; COMDAT ?AtlStrLen@ATL@@YAHPB_W@Z _TEXT SEGMENT _str$ = 8 ; size = 4 ?AtlStrLen@ATL@@YAHPB_W@Z PROC ; ATL::AtlStrLen, COMDAT ; 60 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 61 : if (str == NULL) 00009 83 7d 08 00 cmp DWORD PTR _str$[ebp], 0 0000d 75 04 jne SHORT $LN2@AtlStrLen ; 62 : return 0; 0000f 33 c0 xor eax, eax 00011 eb 0c jmp SHORT $LN1@AtlStrLen $LN2@AtlStrLen: ; 63 : return static_cast(::wcslen(str)); 00013 8b 45 08 mov eax, DWORD PTR _str$[ebp] 00016 50 push eax 00017 e8 00 00 00 00 call _wcslen 0001c 83 c4 04 add esp, 4 $LN1@AtlStrLen: ; 64 : } 0001f 5f pop edi 00020 5e pop esi 00021 5b pop ebx 00022 8b e5 mov esp, ebp 00024 5d pop ebp 00025 c3 ret 0 ?AtlStrLen@ATL@@YAHPB_W@Z ENDP ; ATL::AtlStrLen _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlchecked.h ; COMDAT ?wmemcpy_s@Checked@ATL@@YAXPA_WIPB_WI@Z _TEXT SEGMENT __S1$ = 8 ; size = 4 __N1$ = 12 ; size = 4 __S2$ = 16 ; size = 4 __N$ = 20 ; size = 4 ?wmemcpy_s@Checked@ATL@@YAXPA_WIPB_WI@Z PROC ; ATL::Checked::wmemcpy_s, COMDAT ; 77 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 78 : ATLMFC_CRT_ERRORCHECK(::wmemcpy_s(_S1, _N1, _S2, _N)); 00009 8b 45 14 mov eax, DWORD PTR __N$[ebp] 0000c 50 push eax 0000d 8b 4d 10 mov ecx, DWORD PTR __S2$[ebp] 00010 51 push ecx 00011 8b 55 0c mov edx, DWORD PTR __N1$[ebp] 00014 52 push edx 00015 8b 45 08 mov eax, DWORD PTR __S1$[ebp] 00018 50 push eax 00019 e8 00 00 00 00 call _wmemcpy_s 0001e 83 c4 10 add esp, 16 ; 00000010H 00021 50 push eax 00022 e8 00 00 00 00 call ?AfxCrtErrorCheck@@YAHH@Z ; AfxCrtErrorCheck 00027 83 c4 04 add esp, 4 ; 79 : } 0002a 5f pop edi 0002b 5e pop esi 0002c 5b pop ebx 0002d 8b e5 mov esp, ebp 0002f 5d pop ebp 00030 c3 ret 0 ?wmemcpy_s@Checked@ATL@@YAXPA_WIPB_WI@Z ENDP ; ATL::Checked::wmemcpy_s _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\atlexcept.h ; COMDAT ?AtlThrowImpl@ATL@@YGXJ@Z _TEXT SEGMENT _hr$ = 8 ; size = 4 ?AtlThrowImpl@ATL@@YGXJ@Z PROC ; ATL::AtlThrowImpl, COMDAT ; 65 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 66 : ATLTRACE(atlTraceException, 0, _T("AtlThrow: hr = 0x%x\n"), hr ); ; 67 : #ifdef _AFX ; 68 : if( hr == E_OUTOFMEMORY ) 00009 81 7d 08 0e 00 07 80 cmp DWORD PTR _hr$[ebp], -2147024882 ; 8007000eH 00010 75 07 jne SHORT $LN2@AtlThrowIm ; 69 : { ; 70 : AfxThrowMemoryException(); 00012 e8 00 00 00 00 call ?AfxThrowMemoryException@@YGXXZ ; AfxThrowMemoryException ; 71 : } 00017 eb 09 jmp SHORT $LN4@AtlThrowIm $LN2@AtlThrowIm: ; 72 : else ; 73 : { ; 74 : AfxThrowOleException( hr ); 00019 8b 45 08 mov eax, DWORD PTR _hr$[ebp] 0001c 50 push eax 0001d e8 00 00 00 00 call ?AfxThrowOleException@@YGXJ@Z ; AfxThrowOleException $LN4@AtlThrowIm: ; 75 : } ; 76 : #else ; 77 : throw CAtlException( hr ); ; 78 : #endif ; 79 : }; 00022 5f pop edi 00023 5e pop esi 00024 5b pop ebx 00025 8b e5 mov esp, ebp 00027 5d pop ebp 00028 c2 04 00 ret 4 ?AtlThrowImpl@ATL@@YGXJ@Z ENDP ; ATL::AtlThrowImpl _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files\Microsoft Visual Studio\2022\Community\VC\Tools\MSVC\14.34.31933\atlmfc\include\afx.h ; COMDAT ?AfxCrtErrorCheck@@YAHH@Z _TEXT SEGMENT tv64 = -68 ; size = 4 _error$ = 8 ; size = 4 ?AfxCrtErrorCheck@@YAHH@Z PROC ; AfxCrtErrorCheck, COMDAT ; 506 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 44 sub esp, 68 ; 00000044H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 507 : switch(error) 00009 8b 45 08 mov eax, DWORD PTR _error$[ebp] 0000c 89 45 bc mov DWORD PTR tv64[ebp], eax 0000f 83 7d bc 50 cmp DWORD PTR tv64[ebp], 80 ; 00000050H 00013 77 21 ja SHORT $LN9@AfxCrtErro 00015 8b 4d bc mov ecx, DWORD PTR tv64[ebp] 00018 0f b6 91 00 00 00 00 movzx edx, BYTE PTR $LN11@AfxCrtErro[ecx] 0001f ff 24 95 00 00 00 00 jmp DWORD PTR $LN12@AfxCrtErro[edx*4] $LN4@AfxCrtErro: ; 508 : { ; 509 : case ENOMEM: ; 510 : AfxThrowMemoryException(); 00026 e8 00 00 00 00 call ?AfxThrowMemoryException@@YGXXZ ; AfxThrowMemoryException ; 511 : break; 0002b eb 0e jmp SHORT $LN2@AfxCrtErro $LN6@AfxCrtErro: ; 512 : case EINVAL: ; 513 : case ERANGE: ; 514 : AfxThrowInvalidArgException(); 0002d e8 00 00 00 00 call ?AfxThrowInvalidArgException@@YGXXZ ; AfxThrowInvalidArgException ; 515 : break; 00032 eb 07 jmp SHORT $LN2@AfxCrtErro $LN8@AfxCrtErro: ; 516 : case STRUNCATE: ; 517 : case 0: ; 518 : break; 00034 eb 05 jmp SHORT $LN2@AfxCrtErro $LN9@AfxCrtErro: ; 519 : default: ; 520 : AfxThrowInvalidArgException(); 00036 e8 00 00 00 00 call ?AfxThrowInvalidArgException@@YGXXZ ; AfxThrowInvalidArgException $LN2@AfxCrtErro: ; 521 : break; ; 522 : } ; 523 : return error; 0003b 8b 45 08 mov eax, DWORD PTR _error$[ebp] $LN10@AfxCrtErro: ; 524 : } 0003e 5f pop edi 0003f 5e pop esi 00040 5b pop ebx 00041 8b e5 mov esp, ebp 00043 5d pop ebp 00044 c3 ret 0 00045 0f 1f 00 npad 3 $LN12@AfxCrtErro: 00048 00 00 00 00 DD $LN8@AfxCrtErro 0004c 00 00 00 00 DD $LN4@AfxCrtErro 00050 00 00 00 00 DD $LN6@AfxCrtErro 00054 00 00 00 00 DD $LN9@AfxCrtErro $LN11@AfxCrtErro: 00058 00 DB 0 00059 03 DB 3 0005a 03 DB 3 0005b 03 DB 3 0005c 03 DB 3 0005d 03 DB 3 0005e 03 DB 3 0005f 03 DB 3 00060 03 DB 3 00061 03 DB 3 00062 03 DB 3 00063 03 DB 3 00064 01 DB 1 00065 03 DB 3 00066 03 DB 3 00067 03 DB 3 00068 03 DB 3 00069 03 DB 3 0006a 03 DB 3 0006b 03 DB 3 0006c 03 DB 3 0006d 03 DB 3 0006e 02 DB 2 0006f 03 DB 3 00070 03 DB 3 00071 03 DB 3 00072 03 DB 3 00073 03 DB 3 00074 03 DB 3 00075 03 DB 3 00076 03 DB 3 00077 03 DB 3 00078 03 DB 3 00079 03 DB 3 0007a 02 DB 2 0007b 03 DB 3 0007c 03 DB 3 0007d 03 DB 3 0007e 03 DB 3 0007f 03 DB 3 00080 03 DB 3 00081 03 DB 3 00082 03 DB 3 00083 03 DB 3 00084 03 DB 3 00085 03 DB 3 00086 03 DB 3 00087 03 DB 3 00088 03 DB 3 00089 03 DB 3 0008a 03 DB 3 0008b 03 DB 3 0008c 03 DB 3 0008d 03 DB 3 0008e 03 DB 3 0008f 03 DB 3 00090 03 DB 3 00091 03 DB 3 00092 03 DB 3 00093 03 DB 3 00094 03 DB 3 00095 03 DB 3 00096 03 DB 3 00097 03 DB 3 00098 03 DB 3 00099 03 DB 3 0009a 03 DB 3 0009b 03 DB 3 0009c 03 DB 3 0009d 03 DB 3 0009e 03 DB 3 0009f 03 DB 3 000a0 03 DB 3 000a1 03 DB 3 000a2 03 DB 3 000a3 03 DB 3 000a4 03 DB 3 000a5 03 DB 3 000a6 03 DB 3 000a7 03 DB 3 000a8 00 DB 0 ?AfxCrtErrorCheck@@YAHH@Z ENDP ; AfxCrtErrorCheck _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\ucrt\corecrt_memcpy_s.h ; COMDAT _memmove_s _TEXT SEGMENT tv74 = -80 ; size = 4 tv70 = -80 ; size = 4 tv66 = -80 ; size = 4 __Expr_val$1 = -12 ; size = 4 __Expr_val$2 = -8 ; size = 4 __Expr_val$3 = -4 ; size = 4 __Destination$ = 8 ; size = 4 __DestinationSize$ = 12 ; size = 4 __Source$ = 16 ; size = 4 __SourceSize$ = 20 ; size = 4 _memmove_s PROC ; COMDAT ; 73 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 50 sub esp, 80 ; 00000050H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 74 : if (_SourceSize == 0) 00009 83 7d 14 00 cmp DWORD PTR __SourceSize$[ebp], 0 0000d 75 07 jne SHORT $LN2@memmove_s ; 75 : { ; 76 : return 0; 0000f 33 c0 xor eax, eax 00011 e9 c6 00 00 00 jmp $LN1@memmove_s $LN2@memmove_s: ; 77 : } ; 78 : ; 79 : _CRT_MEMCPY_S_VALIDATE_RETURN_ERRCODE(_Destination != NULL, EINVAL); 00016 83 7d 08 00 cmp DWORD PTR __Destination$[ebp], 0 0001a 74 09 je SHORT $LN7@memmove_s 0001c c7 45 b0 01 00 00 00 mov DWORD PTR tv66[ebp], 1 00023 eb 07 jmp SHORT $LN8@memmove_s $LN7@memmove_s: 00025 c7 45 b0 00 00 00 00 mov DWORD PTR tv66[ebp], 0 $LN8@memmove_s: 0002c 8b 45 b0 mov eax, DWORD PTR tv66[ebp] 0002f 89 45 fc mov DWORD PTR __Expr_val$3[ebp], eax 00032 83 7d fc 00 cmp DWORD PTR __Expr_val$3[ebp], 0 00036 75 1a jne SHORT $LN3@memmove_s 00038 e8 00 00 00 00 call __errno 0003d c7 00 16 00 00 00 mov DWORD PTR [eax], 22 ; 00000016H 00043 e8 00 00 00 00 call __invalid_parameter_noinfo 00048 b8 16 00 00 00 mov eax, 22 ; 00000016H 0004d e9 8a 00 00 00 jmp $LN1@memmove_s $LN3@memmove_s: ; 80 : _CRT_MEMCPY_S_VALIDATE_RETURN_ERRCODE(_Source != NULL, EINVAL); 00052 83 7d 10 00 cmp DWORD PTR __Source$[ebp], 0 00056 74 09 je SHORT $LN9@memmove_s 00058 c7 45 b0 01 00 00 00 mov DWORD PTR tv70[ebp], 1 0005f eb 07 jmp SHORT $LN10@memmove_s $LN9@memmove_s: 00061 c7 45 b0 00 00 00 00 mov DWORD PTR tv70[ebp], 0 $LN10@memmove_s: 00068 8b 45 b0 mov eax, DWORD PTR tv70[ebp] 0006b 89 45 f8 mov DWORD PTR __Expr_val$2[ebp], eax 0006e 83 7d f8 00 cmp DWORD PTR __Expr_val$2[ebp], 0 00072 75 17 jne SHORT $LN4@memmove_s 00074 e8 00 00 00 00 call __errno 00079 c7 00 16 00 00 00 mov DWORD PTR [eax], 22 ; 00000016H 0007f e8 00 00 00 00 call __invalid_parameter_noinfo 00084 b8 16 00 00 00 mov eax, 22 ; 00000016H 00089 eb 51 jmp SHORT $LN1@memmove_s $LN4@memmove_s: ; 81 : _CRT_MEMCPY_S_VALIDATE_RETURN_ERRCODE(_DestinationSize >= _SourceSize, ERANGE); 0008b 8b 45 0c mov eax, DWORD PTR __DestinationSize$[ebp] 0008e 3b 45 14 cmp eax, DWORD PTR __SourceSize$[ebp] 00091 72 09 jb SHORT $LN11@memmove_s 00093 c7 45 b0 01 00 00 00 mov DWORD PTR tv74[ebp], 1 0009a eb 07 jmp SHORT $LN12@memmove_s $LN11@memmove_s: 0009c c7 45 b0 00 00 00 00 mov DWORD PTR tv74[ebp], 0 $LN12@memmove_s: 000a3 8b 4d b0 mov ecx, DWORD PTR tv74[ebp] 000a6 89 4d f4 mov DWORD PTR __Expr_val$1[ebp], ecx 000a9 83 7d f4 00 cmp DWORD PTR __Expr_val$1[ebp], 0 000ad 75 17 jne SHORT $LN5@memmove_s 000af e8 00 00 00 00 call __errno 000b4 c7 00 22 00 00 00 mov DWORD PTR [eax], 34 ; 00000022H 000ba e8 00 00 00 00 call __invalid_parameter_noinfo 000bf b8 22 00 00 00 mov eax, 34 ; 00000022H 000c4 eb 16 jmp SHORT $LN1@memmove_s $LN5@memmove_s: ; 82 : ; 83 : memmove(_Destination, _Source, _SourceSize); 000c6 8b 45 14 mov eax, DWORD PTR __SourceSize$[ebp] 000c9 50 push eax 000ca 8b 4d 10 mov ecx, DWORD PTR __Source$[ebp] 000cd 51 push ecx 000ce 8b 55 08 mov edx, DWORD PTR __Destination$[ebp] 000d1 52 push edx 000d2 e8 00 00 00 00 call _memmove 000d7 83 c4 0c add esp, 12 ; 0000000cH ; 84 : return 0; 000da 33 c0 xor eax, eax $LN1@memmove_s: ; 85 : } 000dc 5f pop edi 000dd 5e pop esi 000de 5b pop ebx 000df 8b e5 mov esp, ebp 000e1 5d pop ebp 000e2 c3 ret 0 _memmove_s ENDP _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\ucrt\corecrt_memcpy_s.h ; COMDAT _memcpy_s _TEXT SEGMENT tv79 = -80 ; size = 4 tv75 = -80 ; size = 4 tv66 = -80 ; size = 4 __Expr_val$1 = -12 ; size = 4 __Expr_val$2 = -8 ; size = 4 __Expr_val$3 = -4 ; size = 4 __Destination$ = 8 ; size = 4 __DestinationSize$ = 12 ; size = 4 __Source$ = 16 ; size = 4 __SourceSize$ = 20 ; size = 4 _memcpy_s PROC ; COMDAT ; 45 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 50 sub esp, 80 ; 00000050H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 46 : if (_SourceSize == 0) 00009 83 7d 14 00 cmp DWORD PTR __SourceSize$[ebp], 0 0000d 75 07 jne SHORT $LN2@memcpy_s ; 47 : { ; 48 : return 0; 0000f 33 c0 xor eax, eax 00011 e9 f1 00 00 00 jmp $LN1@memcpy_s $LN2@memcpy_s: ; 49 : } ; 50 : ; 51 : _CRT_MEMCPY_S_VALIDATE_RETURN_ERRCODE(_Destination != NULL, EINVAL); 00016 83 7d 08 00 cmp DWORD PTR __Destination$[ebp], 0 0001a 74 09 je SHORT $LN9@memcpy_s 0001c c7 45 b0 01 00 00 00 mov DWORD PTR tv66[ebp], 1 00023 eb 07 jmp SHORT $LN10@memcpy_s $LN9@memcpy_s: 00025 c7 45 b0 00 00 00 00 mov DWORD PTR tv66[ebp], 0 $LN10@memcpy_s: 0002c 8b 45 b0 mov eax, DWORD PTR tv66[ebp] 0002f 89 45 fc mov DWORD PTR __Expr_val$3[ebp], eax 00032 83 7d fc 00 cmp DWORD PTR __Expr_val$3[ebp], 0 00036 75 1a jne SHORT $LN3@memcpy_s 00038 e8 00 00 00 00 call __errno 0003d c7 00 16 00 00 00 mov DWORD PTR [eax], 22 ; 00000016H 00043 e8 00 00 00 00 call __invalid_parameter_noinfo 00048 b8 16 00 00 00 mov eax, 22 ; 00000016H 0004d e9 b5 00 00 00 jmp $LN1@memcpy_s $LN3@memcpy_s: ; 52 : if (_Source == NULL || _DestinationSize < _SourceSize) 00052 83 7d 10 00 cmp DWORD PTR __Source$[ebp], 0 00056 74 0c je SHORT $LN5@memcpy_s 00058 8b 45 0c mov eax, DWORD PTR __DestinationSize$[ebp] 0005b 3b 45 14 cmp eax, DWORD PTR __SourceSize$[ebp] 0005e 0f 83 8d 00 00 00 jae $LN4@memcpy_s $LN5@memcpy_s: ; 53 : { ; 54 : memset(_Destination, 0, _DestinationSize); 00064 8b 45 0c mov eax, DWORD PTR __DestinationSize$[ebp] 00067 50 push eax 00068 6a 00 push 0 0006a 8b 4d 08 mov ecx, DWORD PTR __Destination$[ebp] 0006d 51 push ecx 0006e e8 00 00 00 00 call _memset 00073 83 c4 0c add esp, 12 ; 0000000cH ; 55 : ; 56 : _CRT_MEMCPY_S_VALIDATE_RETURN_ERRCODE(_Source != NULL, EINVAL); 00076 83 7d 10 00 cmp DWORD PTR __Source$[ebp], 0 0007a 74 09 je SHORT $LN11@memcpy_s 0007c c7 45 b0 01 00 00 00 mov DWORD PTR tv75[ebp], 1 00083 eb 07 jmp SHORT $LN12@memcpy_s $LN11@memcpy_s: 00085 c7 45 b0 00 00 00 00 mov DWORD PTR tv75[ebp], 0 $LN12@memcpy_s: 0008c 8b 45 b0 mov eax, DWORD PTR tv75[ebp] 0008f 89 45 f8 mov DWORD PTR __Expr_val$2[ebp], eax 00092 83 7d f8 00 cmp DWORD PTR __Expr_val$2[ebp], 0 00096 75 17 jne SHORT $LN6@memcpy_s 00098 e8 00 00 00 00 call __errno 0009d c7 00 16 00 00 00 mov DWORD PTR [eax], 22 ; 00000016H 000a3 e8 00 00 00 00 call __invalid_parameter_noinfo 000a8 b8 16 00 00 00 mov eax, 22 ; 00000016H 000ad eb 58 jmp SHORT $LN1@memcpy_s $LN6@memcpy_s: ; 57 : _CRT_MEMCPY_S_VALIDATE_RETURN_ERRCODE(_DestinationSize >= _SourceSize, ERANGE); 000af 8b 45 0c mov eax, DWORD PTR __DestinationSize$[ebp] 000b2 3b 45 14 cmp eax, DWORD PTR __SourceSize$[ebp] 000b5 72 09 jb SHORT $LN13@memcpy_s 000b7 c7 45 b0 01 00 00 00 mov DWORD PTR tv79[ebp], 1 000be eb 07 jmp SHORT $LN14@memcpy_s $LN13@memcpy_s: 000c0 c7 45 b0 00 00 00 00 mov DWORD PTR tv79[ebp], 0 $LN14@memcpy_s: 000c7 8b 4d b0 mov ecx, DWORD PTR tv79[ebp] 000ca 89 4d f4 mov DWORD PTR __Expr_val$1[ebp], ecx 000cd 83 7d f4 00 cmp DWORD PTR __Expr_val$1[ebp], 0 000d1 75 17 jne SHORT $LN7@memcpy_s 000d3 e8 00 00 00 00 call __errno 000d8 c7 00 22 00 00 00 mov DWORD PTR [eax], 34 ; 00000022H 000de e8 00 00 00 00 call __invalid_parameter_noinfo 000e3 b8 22 00 00 00 mov eax, 34 ; 00000022H 000e8 eb 1d jmp SHORT $LN1@memcpy_s $LN7@memcpy_s: ; 58 : ; 59 : // Unreachable, but required to suppress /analyze warnings: ; 60 : return EINVAL; 000ea b8 16 00 00 00 mov eax, 22 ; 00000016H 000ef eb 16 jmp SHORT $LN1@memcpy_s $LN4@memcpy_s: ; 61 : } ; 62 : memcpy(_Destination, _Source, _SourceSize); 000f1 8b 45 14 mov eax, DWORD PTR __SourceSize$[ebp] 000f4 50 push eax 000f5 8b 4d 10 mov ecx, DWORD PTR __Source$[ebp] 000f8 51 push ecx 000f9 8b 55 08 mov edx, DWORD PTR __Destination$[ebp] 000fc 52 push edx 000fd e8 00 00 00 00 call _memcpy 00102 83 c4 0c add esp, 12 ; 0000000cH ; 63 : return 0; 00105 33 c0 xor eax, eax $LN1@memcpy_s: ; 64 : } 00107 5f pop edi 00108 5e pop esi 00109 5b pop ebx 0010a 8b e5 mov esp, ebp 0010c 5d pop ebp 0010d c3 ret 0 _memcpy_s ENDP _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\ucrt\corecrt_wstdio.h ; COMDAT __swprintf _TEXT SEGMENT __ArgList$ = -8 ; size = 4 __Result$ = -4 ; size = 4 __Buffer$ = 8 ; size = 4 __Format$ = 12 ; size = 4 __swprintf PROC ; COMDAT ; 1445 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 4c sub esp, 76 ; 0000004cH 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 1446 : int _Result; ; 1447 : va_list _ArgList; ; 1448 : __crt_va_start(_ArgList, _Format); 00009 8d 45 10 lea eax, DWORD PTR __Format$[ebp+4] 0000c 89 45 f8 mov DWORD PTR __ArgList$[ebp], eax ; 1449 : _Result = __vswprintf_l(_Buffer, _Format, NULL, _ArgList); 0000f 8b 45 f8 mov eax, DWORD PTR __ArgList$[ebp] 00012 50 push eax 00013 6a 00 push 0 00015 8b 4d 0c mov ecx, DWORD PTR __Format$[ebp] 00018 51 push ecx 00019 8b 55 08 mov edx, DWORD PTR __Buffer$[ebp] 0001c 52 push edx 0001d e8 00 00 00 00 call ___vswprintf_l 00022 83 c4 10 add esp, 16 ; 00000010H 00025 89 45 fc mov DWORD PTR __Result$[ebp], eax ; 1450 : __crt_va_end(_ArgList); 00028 c7 45 f8 00 00 00 00 mov DWORD PTR __ArgList$[ebp], 0 ; 1451 : return _Result; 0002f 8b 45 fc mov eax, DWORD PTR __Result$[ebp] ; 1452 : } 00032 5f pop edi 00033 5e pop esi 00034 5b pop ebx 00035 8b e5 mov esp, ebp 00037 5d pop ebp 00038 c3 ret 0 __swprintf ENDP _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\ucrt\corecrt_wstdio.h ; COMDAT ___vswprintf_l _TEXT SEGMENT __Buffer$ = 8 ; size = 4 __Format$ = 12 ; size = 4 __Locale$ = 16 ; size = 4 __ArgList$ = 20 ; size = 4 ___vswprintf_l PROC ; COMDAT ; 1208 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 1209 : return _vswprintf_l(_Buffer, (size_t)-1, _Format, _Locale, _ArgList); 00009 8b 45 14 mov eax, DWORD PTR __ArgList$[ebp] 0000c 50 push eax 0000d 8b 4d 10 mov ecx, DWORD PTR __Locale$[ebp] 00010 51 push ecx 00011 8b 55 0c mov edx, DWORD PTR __Format$[ebp] 00014 52 push edx 00015 6a ff push -1 00017 8b 45 08 mov eax, DWORD PTR __Buffer$[ebp] 0001a 50 push eax 0001b e8 00 00 00 00 call __vswprintf_l 00020 83 c4 14 add esp, 20 ; 00000014H ; 1210 : } 00023 5f pop edi 00024 5e pop esi 00025 5b pop ebx 00026 8b e5 mov esp, ebp 00028 5d pop ebp 00029 c3 ret 0 ___vswprintf_l ENDP _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\ucrt\corecrt_wstdio.h ; COMDAT __vswprintf_l _TEXT SEGMENT __Buffer$ = 8 ; size = 4 __BufferCount$ = 12 ; size = 4 __Format$ = 16 ; size = 4 __Locale$ = 20 ; size = 4 __ArgList$ = 24 ; size = 4 __vswprintf_l PROC ; COMDAT ; 1192 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 1193 : return _vswprintf_c_l(_Buffer, _BufferCount, _Format, _Locale, _ArgList); 00009 8b 45 18 mov eax, DWORD PTR __ArgList$[ebp] 0000c 50 push eax 0000d 8b 4d 14 mov ecx, DWORD PTR __Locale$[ebp] 00010 51 push ecx 00011 8b 55 10 mov edx, DWORD PTR __Format$[ebp] 00014 52 push edx 00015 8b 45 0c mov eax, DWORD PTR __BufferCount$[ebp] 00018 50 push eax 00019 8b 4d 08 mov ecx, DWORD PTR __Buffer$[ebp] 0001c 51 push ecx 0001d e8 00 00 00 00 call __vswprintf_c_l 00022 83 c4 14 add esp, 20 ; 00000014H ; 1194 : } 00025 5f pop edi 00026 5e pop esi 00027 5b pop ebx 00028 8b e5 mov esp, ebp 0002a 5d pop ebp 0002b c3 ret 0 __vswprintf_l ENDP _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\ucrt\corecrt_wstdio.h ; COMDAT __vswprintf_c_l _TEXT SEGMENT tv73 = -72 ; size = 4 __Result$ = -4 ; size = 4 __Buffer$ = 8 ; size = 4 __BufferCount$ = 12 ; size = 4 __Format$ = 16 ; size = 4 __Locale$ = 20 ; size = 4 __ArgList$ = 24 ; size = 4 __vswprintf_c_l PROC ; COMDAT ; 1155 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 48 sub esp, 72 ; 00000048H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 1156 : int const _Result = __stdio_common_vswprintf( 00009 8b 45 18 mov eax, DWORD PTR __ArgList$[ebp] 0000c 50 push eax 0000d 8b 4d 14 mov ecx, DWORD PTR __Locale$[ebp] 00010 51 push ecx 00011 8b 55 10 mov edx, DWORD PTR __Format$[ebp] 00014 52 push edx 00015 8b 45 0c mov eax, DWORD PTR __BufferCount$[ebp] 00018 50 push eax 00019 8b 4d 08 mov ecx, DWORD PTR __Buffer$[ebp] 0001c 51 push ecx 0001d e8 00 00 00 00 call ___local_stdio_printf_options 00022 8b 50 04 mov edx, DWORD PTR [eax+4] 00025 52 push edx 00026 8b 00 mov eax, DWORD PTR [eax] 00028 50 push eax 00029 e8 00 00 00 00 call ___stdio_common_vswprintf 0002e 83 c4 1c add esp, 28 ; 0000001cH 00031 89 45 fc mov DWORD PTR __Result$[ebp], eax ; 1157 : _CRT_INTERNAL_LOCAL_PRINTF_OPTIONS, ; 1158 : _Buffer, _BufferCount, _Format, _Locale, _ArgList); ; 1159 : ; 1160 : return _Result < 0 ? -1 : _Result; 00034 83 7d fc 00 cmp DWORD PTR __Result$[ebp], 0 00038 7d 09 jge SHORT $LN3@vswprintf_ 0003a c7 45 b8 ff ff ff ff mov DWORD PTR tv73[ebp], -1 00041 eb 06 jmp SHORT $LN4@vswprintf_ $LN3@vswprintf_: 00043 8b 45 fc mov eax, DWORD PTR __Result$[ebp] 00046 89 45 b8 mov DWORD PTR tv73[ebp], eax $LN4@vswprintf_: 00049 8b 45 b8 mov eax, DWORD PTR tv73[ebp] ; 1161 : } 0004c 5f pop edi 0004d 5e pop esi 0004e 5b pop ebx 0004f 8b e5 mov esp, ebp 00051 5d pop ebp 00052 c3 ret 0 __vswprintf_c_l ENDP _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File C:\Program Files (x86)\Windows Kits\10\Include\10.0.19041.0\ucrt\corecrt_stdio_config.h ; COMDAT ___local_stdio_printf_options _TEXT SEGMENT ___local_stdio_printf_options PROC ; COMDAT ; 90 : { 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi ; 91 : static unsigned __int64 _OptionsStorage; ; 92 : return &_OptionsStorage; 00009 b8 00 00 00 00 mov eax, OFFSET ?_OptionsStorage@?1??__local_stdio_printf_options@@9@4_KA ; `__local_stdio_printf_options'::`2'::_OptionsStorage ; 93 : } 0000e 5f pop edi 0000f 5e pop esi 00010 5b pop ebx 00011 8b e5 mov esp, ebp 00013 5d pop ebp 00014 c3 ret 0 ___local_stdio_printf_options ENDP _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?__empty_global_delete@@YAXPAXIW4align_val_t@std@@@Z _TEXT SEGMENT ___formal$ = 8 ; size = 4 ___formal$ = 12 ; size = 4 ___formal$ = 16 ; size = 4 ?__empty_global_delete@@YAXPAXIW4align_val_t@std@@@Z PROC ; __empty_global_delete, COMDAT 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 5f pop edi 0000a 5e pop esi 0000b 5b pop ebx 0000c 8b e5 mov esp, ebp 0000e 5d pop ebp 0000f c3 ret 0 ?__empty_global_delete@@YAXPAXIW4align_val_t@std@@@Z ENDP ; __empty_global_delete _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?__empty_global_delete@@YAXPAXW4align_val_t@std@@@Z _TEXT SEGMENT ___formal$ = 8 ; size = 4 ___formal$ = 12 ; size = 4 ?__empty_global_delete@@YAXPAXW4align_val_t@std@@@Z PROC ; __empty_global_delete, COMDAT 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 5f pop edi 0000a 5e pop esi 0000b 5b pop ebx 0000c 8b e5 mov esp, ebp 0000e 5d pop ebp 0000f c3 ret 0 ?__empty_global_delete@@YAXPAXW4align_val_t@std@@@Z ENDP ; __empty_global_delete _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?__empty_global_delete@@YAXPAXI@Z _TEXT SEGMENT ___formal$ = 8 ; size = 4 ___formal$ = 12 ; size = 4 ?__empty_global_delete@@YAXPAXI@Z PROC ; __empty_global_delete, COMDAT 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 5f pop edi 0000a 5e pop esi 0000b 5b pop ebx 0000c 8b e5 mov esp, ebp 0000e 5d pop ebp 0000f c3 ret 0 ?__empty_global_delete@@YAXPAXI@Z ENDP ; __empty_global_delete _TEXT ENDS ; Function compile flags: /Odtp /ZI ; File D:\Works\Corpsms_2010\SmsCenter\IOCP\KeyList.cpp ; COMDAT ?__empty_global_delete@@YAXPAX@Z _TEXT SEGMENT ___formal$ = 8 ; size = 4 ?__empty_global_delete@@YAXPAX@Z PROC ; __empty_global_delete, COMDAT 00000 55 push ebp 00001 8b ec mov ebp, esp 00003 83 ec 40 sub esp, 64 ; 00000040H 00006 53 push ebx 00007 56 push esi 00008 57 push edi 00009 5f pop edi 0000a 5e pop esi 0000b 5b pop ebx 0000c 8b e5 mov esp, ebp 0000e 5d pop ebp 0000f c3 ret 0 ?__empty_global_delete@@YAXPAX@Z ENDP ; __empty_global_delete _TEXT ENDS END