should now handle out of memory situations...

git-svn-id: file:///srv/svn/repos/haiku/trunk/current@10889 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
Stephan Aßmus 2005-01-20 12:01:56 +00:00
parent 7a5829aab1
commit 655b08cd2d

View File

@ -7,16 +7,17 @@
*/ */
#include <TypeConstants.h>
#include <Mime.h> #include <Mime.h>
#include <TypeConstants.h>
#include <fs_attr.h> #include <fs_attr.h>
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <ctype.h> #include <ctype.h>
#include <errno.h> #include <errno.h>
#include <malloc.h>
#include <unistd.h>
#include <stdio.h>
#include <string.h>
/** Used to present the characters in the raw data view */ /** 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) if (size > 64 * 1024)
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); ssize_t bytesRead = fs_read_attr(fd, attribute, info.type, 0, buffer, size);
if (bytesRead < 0) { if (bytesRead < 0) {
delete[] buffer; free(buffer);
return errno; return errno;
} }
if (bytesRead != size) { if (bytesRead != size) {
fprintf(stderr, "Could only read %ld bytes from attribute!\n", bytesRead); fprintf(stderr, "Could only read %ld bytes from attribute!\n", bytesRead);
delete[] buffer; free(buffer);
return B_ERROR; return B_ERROR;
} }
@ -125,7 +131,7 @@ catAttr(const char *attribute, const char *fileName, bool keepRaw = false)
break; break;
} }
} }
delete[] buffer; free(buffer);
if (written > 0) if (written > 0)
written = B_OK; written = B_OK;
return written; return written;
@ -177,7 +183,7 @@ catAttr(const char *attribute, const char *fileName, bool keepRaw = false)
break; break;
} }
delete[] buffer; free(buffer);
return B_OK; return B_OK;
} }