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:
parent
7a5829aab1
commit
655b08cd2d
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user