mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-07 15:21:46 +00:00
(Fbase64_decode_region, Fbase64_decode_string):
Do free malloc'd memory even in case of failure. Use xfree, not free. (Fbase64_encode_region, Fbase64_encode_string): Use xfree, not free. (base64_decode_1): Don't fail for short lines.
This commit is contained in:
parent
2e9537e74b
commit
8c21764540
24
src/fns.c
24
src/fns.c
@ -2859,7 +2859,7 @@ into shorter lines.")
|
|||||||
SET_PT_BOTH (XFASTINT (beg), ibeg);
|
SET_PT_BOTH (XFASTINT (beg), ibeg);
|
||||||
insert (encoded, encoded_length);
|
insert (encoded, encoded_length);
|
||||||
if (allength > MAX_ALLOCA)
|
if (allength > MAX_ALLOCA)
|
||||||
free (encoded);
|
xfree (encoded);
|
||||||
del_range_byte (ibeg + encoded_length, iend + encoded_length, 1);
|
del_range_byte (ibeg + encoded_length, iend + encoded_length, 1);
|
||||||
|
|
||||||
/* If point was outside of the region, restore it exactly; else just
|
/* If point was outside of the region, restore it exactly; else just
|
||||||
@ -2902,7 +2902,7 @@ DEFUN ("base64-encode-string", Fbase64_encode_string, Sbase64_encode_string,
|
|||||||
|
|
||||||
encoded_string = make_unibyte_string (encoded, encoded_length);
|
encoded_string = make_unibyte_string (encoded, encoded_length);
|
||||||
if (allength > MAX_ALLOCA)
|
if (allength > MAX_ALLOCA)
|
||||||
free (encoded);
|
xfree (encoded);
|
||||||
|
|
||||||
return encoded_string;
|
return encoded_string;
|
||||||
}
|
}
|
||||||
@ -3013,8 +3013,12 @@ If the region can't be decoded, return nil and don't modify the buffer.")
|
|||||||
abort ();
|
abort ();
|
||||||
|
|
||||||
if (decoded_length < 0)
|
if (decoded_length < 0)
|
||||||
/* The decoding wasn't possible. */
|
{
|
||||||
return Qnil;
|
/* The decoding wasn't possible. */
|
||||||
|
if (length > MAX_ALLOCA)
|
||||||
|
xfree (decoded);
|
||||||
|
return Qnil;
|
||||||
|
}
|
||||||
|
|
||||||
/* Now we have decoded the region, so we insert the new contents
|
/* Now we have decoded the region, so we insert the new contents
|
||||||
and delete the old. (Insert first in order to preserve markers.) */
|
and delete the old. (Insert first in order to preserve markers.) */
|
||||||
@ -3027,7 +3031,7 @@ If the region can't be decoded, return nil and don't modify the buffer.")
|
|||||||
insert (decoded, decoded_length);
|
insert (decoded, decoded_length);
|
||||||
inserted_chars = PT - (XFASTINT (beg) + 1);
|
inserted_chars = PT - (XFASTINT (beg) + 1);
|
||||||
if (length > MAX_ALLOCA)
|
if (length > MAX_ALLOCA)
|
||||||
free (decoded);
|
xfree (decoded);
|
||||||
/* At first delete the original text. This never cause byte
|
/* At first delete the original text. This never cause byte
|
||||||
combining. */
|
combining. */
|
||||||
del_range_both (PT + 1, PT_BYTE + 1, XFASTINT (end) + inserted_chars + 2,
|
del_range_both (PT + 1, PT_BYTE + 1, XFASTINT (end) + inserted_chars + 2,
|
||||||
@ -3073,11 +3077,13 @@ DEFUN ("base64-decode-string", Fbase64_decode_string, Sbase64_decode_string,
|
|||||||
abort ();
|
abort ();
|
||||||
|
|
||||||
if (decoded_length < 0)
|
if (decoded_length < 0)
|
||||||
return Qnil;
|
/* The decoding wasn't possible. */
|
||||||
|
decoded_string = Qnil;
|
||||||
|
else
|
||||||
|
decoded_string = make_string (decoded, decoded_length);
|
||||||
|
|
||||||
decoded_string = make_string (decoded, decoded_length);
|
|
||||||
if (length > MAX_ALLOCA)
|
if (length > MAX_ALLOCA)
|
||||||
free (decoded);
|
xfree (decoded);
|
||||||
|
|
||||||
return decoded_string;
|
return decoded_string;
|
||||||
}
|
}
|
||||||
@ -3105,8 +3111,6 @@ base64_decode_1 (from, to, length)
|
|||||||
c = from[i++];
|
c = from[i++];
|
||||||
if (i == length)
|
if (i == length)
|
||||||
break;
|
break;
|
||||||
if (counter != MIME_LINE_LENGTH / 4)
|
|
||||||
return -1;
|
|
||||||
counter = 1;
|
counter = 1;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
Loading…
Reference in New Issue
Block a user