Blame attr-2.4.43-leak.patch
|
|
b0ac91b |
diff --git a/libattr/attr_copy_action.c b/libattr/attr_copy_action.c
|
|
|
b0ac91b |
index 0d7aca5..dc94224 100644
|
|
|
b0ac91b |
--- a/libattr/attr_copy_action.c
|
|
|
b0ac91b |
+++ b/libattr/attr_copy_action.c
|
|
|
b0ac91b |
@@ -53,7 +53,7 @@ free_attr_actions(void)
|
|
|
b0ac91b |
static int
|
|
|
b0ac91b |
attr_parse_attr_conf(struct error_context *ctx)
|
|
|
b0ac91b |
{
|
|
|
b0ac91b |
- char *text, *t;
|
|
|
b0ac91b |
+ char *text = NULL, *t;
|
|
|
b0ac91b |
size_t size_guess = 4096, len;
|
|
|
b0ac91b |
FILE *file;
|
|
|
b0ac91b |
char *pattern = NULL;
|
|
|
b0ac91b |
@@ -64,15 +64,16 @@ attr_parse_attr_conf(struct error_context *ctx)
|
|
|
b0ac91b |
return 0;
|
|
|
b0ac91b |
|
|
|
b0ac91b |
repeat:
|
|
|
b0ac91b |
- text = malloc(size_guess + 1);
|
|
|
b0ac91b |
- if (!text)
|
|
|
b0ac91b |
- goto fail;
|
|
|
b0ac91b |
-
|
|
|
b0ac91b |
if ((file = fopen(ATTR_CONF, "r")) == NULL) {
|
|
|
b0ac91b |
if (errno == ENOENT)
|
|
|
b0ac91b |
return 0;
|
|
|
b0ac91b |
goto fail;
|
|
|
b0ac91b |
}
|
|
|
b0ac91b |
+
|
|
|
b0ac91b |
+ text = malloc(size_guess + 1);
|
|
|
b0ac91b |
+ if (!text)
|
|
|
b0ac91b |
+ goto fail;
|
|
|
b0ac91b |
+
|
|
|
b0ac91b |
len = fread(text, 1, size_guess, file);
|
|
|
b0ac91b |
if (ferror(file))
|
|
|
b0ac91b |
goto fail;
|