From b136d05a3db1cbeeded316a31c2d7f30474e142a Mon Sep 17 00:00:00 2001 From: Sergey Lipskiy Date: Thu, 2 Apr 2015 15:43:57 +0600 Subject: [PATCH] Correct FrameBufferList::removeBuffer and FrameBufferList::removeBuffer - null current buffer if removed buffer is the current one. --- FrameBuffer.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/FrameBuffer.cpp b/FrameBuffer.cpp index 61a92ab3..a279ca10 100644 --- a/FrameBuffer.cpp +++ b/FrameBuffer.cpp @@ -428,7 +428,7 @@ void FrameBufferList::removeBuffer(u32 _address ) { for (FrameBuffers::iterator iter = m_list.begin(); iter != m_list.end(); ++iter) if (iter->m_startAddress == _address) { - if (m_pCurrent != NULL && m_pCurrent->m_startAddress == _address) + if (&(*iter) == m_pCurrent) m_pCurrent = NULL; m_list.erase(iter); return; @@ -440,6 +440,8 @@ void FrameBufferList::removeBuffers(u32 _width) m_pCurrent = NULL; for (FrameBuffers::iterator iter = m_list.begin(); iter != m_list.end(); ++iter) { while (iter->m_width == _width) { + if (&(*iter) == m_pCurrent) + m_pCurrent = NULL; iter = m_list.erase(iter); if (iter == m_list.end()) return;