[Bf-blender-cvs] [447d277] master: Fix IRC reported by elubie: windows crash with audio animation

Jörg Müller noreply at git.blender.org
Wed Nov 20 00:31:19 CET 2013


Commit: 447d2774989cd2df249e1d48cf44ef7e1a109a36
Author: Jörg Müller
Date:   Wed Nov 20 00:20:51 2013 +0100
http://developer.blender.org/rB447d2774989cd2df249e1d48cf44ef7e1a109a36

Fix IRC reported by elubie: windows crash with audio animation

There was a bug in how the iterators of STL list was used when erasing during iteration of a list, which was triggered by the STL implementation of MSVC, but hid well with gcc.

===================================================================

M	intern/audaspace/intern/AUD_AnimateableProperty.cpp

===================================================================

diff --git a/intern/audaspace/intern/AUD_AnimateableProperty.cpp b/intern/audaspace/intern/AUD_AnimateableProperty.cpp
index 6d1a307..61adae4 100644
--- a/intern/audaspace/intern/AUD_AnimateableProperty.cpp
+++ b/intern/audaspace/intern/AUD_AnimateableProperty.cpp
@@ -112,8 +112,12 @@ void AUD_AnimateableProperty::write(const float* data, int position, int count)
 	// otherwise it's not at the end, let's check if some unknown part got filled
 	else
 	{
-		for(std::list<Unknown>::iterator it = m_unknown.begin(); it != m_unknown.end(); it++)
+		bool erased = false;
+
+		for(std::list<Unknown>::iterator it = m_unknown.begin(); it != m_unknown.end(); erased ? it : it++)
 		{
+			erased = false;
+
 			// unknown area before position
 			if(it->end < position)
 				continue;
@@ -130,9 +134,8 @@ void AUD_AnimateableProperty::write(const float* data, int position, int count)
 				if(position + count > it->end)
 				{
 					// simply delete
-					std::list<Unknown>::iterator it2 = it;
-					it++;
-					m_unknown.erase(it2);
+					it = m_unknown.erase(it);
+					erased = true;
 				}
 				// the end is excluded, a second part remains
 				else




More information about the Bf-blender-cvs mailing list