From c5f520cd3a2571376d6ae12112f6d4cd82f386a5 Mon Sep 17 00:00:00 2001 From: Bruce Dawson Date: Mon, 5 Jan 2015 15:09:10 -0800 Subject: Get rid of g_timeMap global object. g_timeMap is a global variable with a constructor and destructor so it must be removed. BUG=441899 R=tsepez@chromium.org Review URL: https://codereview.chromium.org/832703003 --- fpdfsdk/src/pdfwindow/PWL_Wnd.cpp | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/fpdfsdk/src/pdfwindow/PWL_Wnd.cpp b/fpdfsdk/src/pdfwindow/PWL_Wnd.cpp index bc3348736b..69535d7d85 100644 --- a/fpdfsdk/src/pdfwindow/PWL_Wnd.cpp +++ b/fpdfsdk/src/pdfwindow/PWL_Wnd.cpp @@ -11,7 +11,12 @@ /* -------------------------- CPWL_Timer -------------------------- */ -static CFX_MapPtrTemplate g_TimeMap; +static CFX_MapPtrTemplate& GetPWLTimeMap() +{ + // Leak the object at shutdown. + static auto timeMap = new CFX_MapPtrTemplate; + return *timeMap; +} CPWL_Timer::CPWL_Timer(CPWL_TimerHandler* pAttached, IFX_SystemHandler* pSystemHandler) : m_nTimerID(0), @@ -31,7 +36,7 @@ FX_INT32 CPWL_Timer::SetPWLTimer(FX_INT32 nElapse) { if (m_nTimerID != 0) KillPWLTimer(); m_nTimerID = m_pSystemHandler->SetTimer(nElapse, TimerProc); - g_TimeMap.SetAt(m_nTimerID, this); + GetPWLTimeMap().SetAt(m_nTimerID, this); return m_nTimerID; } @@ -40,7 +45,7 @@ void CPWL_Timer::KillPWLTimer() if (m_nTimerID != 0) { m_pSystemHandler->KillTimer(m_nTimerID); - g_TimeMap.RemoveKey(m_nTimerID); + GetPWLTimeMap().RemoveKey(m_nTimerID); m_nTimerID = 0; } } @@ -48,7 +53,7 @@ void CPWL_Timer::KillPWLTimer() void CPWL_Timer::TimerProc(FX_INT32 idEvent) { CPWL_Timer* pTimer = NULL; - if (g_TimeMap.Lookup(idEvent, pTimer)) + if (GetPWLTimeMap().Lookup(idEvent, pTimer)) { if (pTimer) { -- cgit v1.2.3