Fix iterator invalidation bug, identified by Coverity.
authorChris Lattner <sabre@nondot.org>
Fri, 12 May 2006 18:13:11 +0000 (18:13 +0000)
committerChris Lattner <sabre@nondot.org>
Fri, 12 May 2006 18:13:11 +0000 (18:13 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28257 91177308-0d34-0410-b5e6-96231b3b80d8

lib/System/DynamicLibrary.cpp
lib/System/Unix/Process.inc

index 0c179fc2f7eb4045e21f9526afd089191102d5fe..056fed0eb38e5493a378704bb0df759f87861aff 100644 (file)
@@ -93,6 +93,7 @@ DynamicLibrary::~DynamicLibrary() {
       if (*I == a_handle) {
         // Note: don't use the swap/pop_back trick here. Order is important.
         OpenedHandles.erase(I);
+        return;
       }
     }
   }
index 32733d61366863bf47d203584d2b44eb265d3598..f4bc873a8299c59ce0f37a17034ad9e091b921c5 100644 (file)
@@ -95,7 +95,7 @@ Process::GetTimeUsage(TimeValue& elapsed, TimeValue& user_time,
                       TimeValue& sys_time)
 {
   elapsed = TimeValue::now();
-#if defined(HAVE_GETRUSAGE)
+#if 0 // defined(HAVE_GETRUSAGE)
   struct rusage usage;
   ::getrusage(RUSAGE_SELF, &usage);
   user_time = TimeValue(