From 9d337ccc01e2d33fc0bed197e7c754b5af949695 Mon Sep 17 00:00:00 2001 From: Ingo Weinhold Date: Sun, 7 Oct 2007 14:41:55 +0000 Subject: [PATCH] Aesthetical changes. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@22467 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/kits/storage/PartitioningInfo.cpp | 31 ++++++++++++++++----------- 1 file changed, 18 insertions(+), 13 deletions(-) diff --git a/src/kits/storage/PartitioningInfo.cpp b/src/kits/storage/PartitioningInfo.cpp index e6680b4852..ab72425755 100644 --- a/src/kits/storage/PartitioningInfo.cpp +++ b/src/kits/storage/PartitioningInfo.cpp @@ -67,24 +67,28 @@ status_t BPartitioningInfo::_SetTo(partition_id partition, int32 changeCounter) { Unset(); + status_t error = B_OK; - partitionable_space_data *buffer = NULL; + partitionable_space_data* buffer = NULL; int32 count = 0; int32 actualCount = 0; - do { + while (true) { error = _kern_get_partitionable_spaces(partition, changeCounter, - buffer, count, &actualCount); - if (error == B_BUFFER_OVERFLOW) { - // buffer to small re-allocate it - if (buffer) - delete[] buffer; - buffer = new(nothrow) partitionable_space_data[actualCount]; - if (buffer) - count = actualCount; - else - error = B_NO_MEMORY; + buffer, count, &actualCount); + if (error != B_BUFFER_OVERFLOW) + break; + + // buffer too small re-allocate it + delete[] buffer; + buffer = new(nothrow) partitionable_space_data[actualCount]; + if (!buffer) { + error = B_NO_MEMORY; + break; } - } while (error == B_BUFFER_OVERFLOW); + + count = actualCount; + } + // set data / cleanup on failure if (error == B_OK) { fPartitionID = partition; @@ -92,6 +96,7 @@ BPartitioningInfo::_SetTo(partition_id partition, int32 changeCounter) fCount = actualCount; } else if (buffer) delete[] buffer; + return error; }