aboutsummaryrefslogtreecommitdiffstats
path: root/libical/src
diff options
context:
space:
mode:
authorDamon Chaplin <damon@ximian.com>2001-10-31 13:17:49 +0800
committerDamon Chaplin <damon@src.gnome.org>2001-10-31 13:17:49 +0800
commit3453ef724b891a0286c436b28b0b4fd50edc74f4 (patch)
tree0a79d7054d7523ded655a3f374e14f8c0012d118 /libical/src
parentbe7fbc93cd71cb913bbe279ea55ee81bfbe5f876 (diff)
downloadgsoc2013-evolution-3453ef724b891a0286c436b28b0b4fd50edc74f4.tar.gz
gsoc2013-evolution-3453ef724b891a0286c436b28b0b4fd50edc74f4.tar.zst
gsoc2013-evolution-3453ef724b891a0286c436b28b0b4fd50edc74f4.zip
forgot to account for the spaces added, so it could have been writing over
2001-10-30 Damon Chaplin <damon@ximian.com> * src/libical/icalproperty.c (fold_property_line): forgot to account for the spaces added, so it could have been writing over the end of the allocated memory. Added check for buffer overflow as well. This could well have been the problem causing bug #14067. svn path=/trunk/; revision=14517
Diffstat (limited to 'libical/src')
-rw-r--r--libical/src/libical/icalproperty.c13
1 files changed, 9 insertions, 4 deletions
diff --git a/libical/src/libical/icalproperty.c b/libical/src/libical/icalproperty.c
index a872b17b7f..331443e3dd 100644
--- a/libical/src/libical/icalproperty.c
+++ b/libical/src/libical/icalproperty.c
@@ -270,18 +270,19 @@ icalproperty_free (icalproperty* prop)
static char*
fold_property_line (char *text)
{
- int len, max_lines, line_length;
+ int len, max_lines, line_length, buf_len;
char *buf, *src, *dest, ch;
len = strlen (text);
/* The minimum length we split a line at is 65 characters, so calculate
the maximum number of newlines we will need. */
- max_lines = ((len - 1) / 65);
+ max_lines = len / 65;
/* Calculate the maximum size for the buffer we need, if we add a newline
- character for each line, and a '\0' at the end. */
- buf = icalmemory_tmp_buffer (len + max_lines + 1);
+ and a space character for each line, and a '\0' at the end. */
+ buf_len = len + (max_lines * 2);
+ buf = icalmemory_tmp_buffer (buf_len + 1);
src = text;
dest = buf;
@@ -299,6 +300,10 @@ fold_property_line (char *text)
line_length++;
src++;
+
+ if (dest - buf > buf_len) {
+ icalerror_warn ("Buffer overflow.");
+ }
}
*dest = '\0';