From 655b08cd2da3548cffc8c8a6d8efec05741059fe Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Stephan=20A=C3=9Fmus?= Date: Thu, 20 Jan 2005 12:01:56 +0000 Subject: [PATCH] should now handle out of memory situations... git-svn-id: file:///srv/svn/repos/haiku/trunk/current@10889 a95241bf-73f2-0310-859d-f6bbb57e9c96 --- src/apps/bin/catattr.cpp | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/src/apps/bin/catattr.cpp b/src/apps/bin/catattr.cpp index c782616cf3..dcfa3593fe 100644 --- a/src/apps/bin/catattr.cpp +++ b/src/apps/bin/catattr.cpp @@ -7,16 +7,17 @@ */ -#include #include +#include #include -#include -#include -#include #include #include +#include +#include +#include +#include /** Used to present the characters in the raw data view */ @@ -84,16 +85,21 @@ catAttr(const char *attribute, const char *fileName, bool keepRaw = false) if (size > 64 * 1024) size = 64 * 1024; - char* buffer = new char[size]; + char* buffer = (char*)malloc(size); + if (!buffer) { + fprintf(stderr, "Could not allocate read buffer!\n"); + return B_NO_MEMORY; + } + ssize_t bytesRead = fs_read_attr(fd, attribute, info.type, 0, buffer, size); if (bytesRead < 0) { - delete[] buffer; + free(buffer); return errno; } if (bytesRead != size) { fprintf(stderr, "Could only read %ld bytes from attribute!\n", bytesRead); - delete[] buffer; + free(buffer); return B_ERROR; } @@ -125,7 +131,7 @@ catAttr(const char *attribute, const char *fileName, bool keepRaw = false) break; } } - delete[] buffer; + free(buffer); if (written > 0) written = B_OK; return written; @@ -177,7 +183,7 @@ catAttr(const char *attribute, const char *fileName, bool keepRaw = false) break; } - delete[] buffer; + free(buffer); return B_OK; }