summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--glib/gbase64.c8
-rw-r--r--tests/base64-test.c19
3 files changed, 23 insertions, 11 deletions
diff --git a/ChangeLog b/ChangeLog
index 1567dea7b..ab51a35d6 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,12 @@
2007-11-23 Matthias Clasen <mclasen@redhat.com>
+ * glib/gbase64.c (g_base64_encode): Don't refuse to encode
+ a single byte. (Milan Crha)
+
+ * tests/base64-test.c: Test encoding short strings.
+
+2007-11-23 Matthias Clasen <mclasen@redhat.com>
+
* glib/gi18n-lib.h:
* glib/gi18n.h: Define a two-argument macro C_() for marking
translatable strings with context and implement C_() and Q_()
diff --git a/glib/gbase64.c b/glib/gbase64.c
index 344ce0b80..437c4c983 100644
--- a/glib/gbase64.c
+++ b/glib/gbase64.c
@@ -231,16 +231,14 @@ g_base64_encode (const guchar *data,
gint save = 0;
g_return_val_if_fail (data != NULL, NULL);
- g_return_val_if_fail (len > 1, NULL);
+ g_return_val_if_fail (len > 0, NULL);
/* We can use a smaller limit here, since we know the saved state is 0 */
out = g_malloc (len * 4 / 3 + 4);
outlen = g_base64_encode_step (data, len, FALSE, out, &state, &save);
- outlen += g_base64_encode_close (FALSE,
- out + outlen,
- &state,
- &save);
+ outlen += g_base64_encode_close (FALSE, out + outlen, &state, &save);
out[outlen] = '\0';
+
return (gchar *) out;
}
diff --git a/tests/base64-test.c b/tests/base64-test.c
index 4cb703693..4d7472184 100644
--- a/tests/base64-test.c
+++ b/tests/base64-test.c
@@ -83,24 +83,24 @@ test_incremental (gboolean line_break,
}
static void
-test_full (void)
+test_full (gint length)
{
char *text;
guchar *data2;
gsize len;
- text = g_base64_encode (data, DATA_SIZE);
+ text = g_base64_encode (data, length);
data2 = g_base64_decode (text, &len);
g_free (text);
- if (len != DATA_SIZE)
+ if (len != length)
{
g_print ("Wrong decoded length: got %d, expected %d\n",
- len, DATA_SIZE);
+ len, length);
exit (1);
}
- if (memcmp (data, data2, DATA_SIZE) != 0)
+ if (memcmp (data, data2, length) != 0)
{
g_print ("Wrong decoded base64 data\n");
exit (1);
@@ -116,7 +116,10 @@ main (int argc, char *argv[])
for (i = 0; i < DATA_SIZE; i++)
data[i] = (guchar)i;
- test_full ();
+ test_full (DATA_SIZE);
+ test_full (1);
+ test_full (2);
+ test_full (3);
test_incremental (FALSE, DATA_SIZE);
test_incremental (TRUE, DATA_SIZE);
@@ -127,5 +130,9 @@ main (int argc, char *argv[])
test_incremental (FALSE, DATA_SIZE - 2);
test_incremental (TRUE, DATA_SIZE - 2);
+ test_incremental (FALSE, 1);
+ test_incremental (FALSE, 2);
+ test_incremental (FALSE, 3);
+
return 0;
}