diff --git a/libstdc++-v3/ChangeLog b/libstdc++-v3/ChangeLog index ef719c83be7..9a3980f6b35 100644 --- a/libstdc++-v3/ChangeLog +++ b/libstdc++-v3/ChangeLog @@ -1,3 +1,8 @@ +2004-03-24 Paolo Carlini + + * include/ext/mt_allocator.h (__mt_alloc<>::allocate, + __mt_alloc<>::deallocate): Avoid redundant conditionals. + 2004-03-23 Benjamin Kosnik * include/bits/locale_facets.h: Tweaks for 80 column. diff --git a/libstdc++-v3/include/ext/mt_allocator.h b/libstdc++-v3/include/ext/mt_allocator.h index 7204d841745..ce080c797a2 100644 --- a/libstdc++-v3/include/ext/mt_allocator.h +++ b/libstdc++-v3/include/ext/mt_allocator.h @@ -353,16 +353,8 @@ namespace __gnu_cxx tmp = __bin.first[0]->next; block = __bin.first[0]; - if (__bin.first[__thread_id] == NULL) - { - __bin.first[__thread_id] = block; - block->next = NULL; - } - else - { - block->next = __bin.first[__thread_id]; - __bin.first[__thread_id] = block; - } + block->next = __bin.first[__thread_id]; + __bin.first[__thread_id] = block; block->thread_id = __thread_id; __bin.free[__thread_id]++; @@ -466,16 +458,8 @@ namespace __gnu_cxx while (remove > 0) { tmp = __bin.first[thread_id]->next; - if (__bin.first[0] == NULL) - { - __bin.first[0] = __bin.first[thread_id]; - __bin.first[0]->next = NULL; - } - else - { - __bin.first[thread_id]->next = __bin.first[0]; - __bin.first[0] = __bin.first[thread_id]; - } + __bin.first[thread_id]->next = __bin.first[0]; + __bin.first[0] = __bin.first[thread_id]; __bin.first[thread_id] = tmp; __bin.free[thread_id]--; @@ -486,41 +470,20 @@ namespace __gnu_cxx // Return this block to our list and update counters and // owner id as needed. - if (__bin.first[thread_id] == NULL) - { - __bin.first[thread_id] = block; - block->next = NULL; - } - else - { - block->next = __bin.first[thread_id]; - __bin.first[thread_id] = block; - } + block->next = __bin.first[thread_id]; + __bin.first[thread_id] = block; __bin.free[thread_id]++; - if (thread_id == block->thread_id) - __bin.used[thread_id]--; - else - { - __bin.used[block->thread_id]--; - block->thread_id = thread_id; - } + __bin.used[block->thread_id]--; + block->thread_id = thread_id; } else #endif { // Single threaded application - return to global pool. - if (__bin.first[0] == NULL) - { - __bin.first[0] = block; - block->next = NULL; - } - else - { - block->next = __bin.first[0]; - __bin.first[0] = block; - } + block->next = __bin.first[0]; + __bin.first[0] = block; } }