loudmouth/base64.c
author Senko Rasic <senko.rasic@collabora.co.uk>
Sun, 30 Nov 2008 10:20:08 +0100
changeset 575 daad23d59b56
parent 278 3976427b4f7e
permissions -rw-r--r--
Don't check for sync dns problems when using asyncns [#33] lm_socket_create() checks for sync DNS failure, but the check is executed even if Loudmouth is using asyncns, in which case Loudmouth crashes. committer: Mikael Hallendal <micke@imendio.com>
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
217
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     1
/*
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     2
 * base64.c - Base 64 encoding/decoding implementation
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     3
 * Copyright (C) 2006 Collabora Ltd.
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     4
 *
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     5
 * This library is free software; you can redistribute it and/or
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     6
 * modify it under the terms of the GNU Lesser General Public
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     7
 * License as published by the Free Software Foundation; either
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     8
 * version 2.1 of the License, or (at your option) any later version.
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
     9
 *
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    10
 * This library is distributed in the hope that it will be useful,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    12
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    13
 * Lesser General Public License for more details.
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    14
 *
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    15
 * You should have received a copy of the GNU Lesser General Public
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    16
 * License along with this library; if not, write to the Free Software
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    17
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    18
 */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    19
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    20
#include <ctype.h>
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    21
#include <string.h>
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    22
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    23
#include <glib.h>
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    24
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    25
#include "base64.h"
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    26
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    27
/*
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    28
|AAAA AABB|BBBB CCCC|CCDD DDDD|
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    29
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    30
0xFC = 1111 1100
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    31
0x03 = 0000 0011
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    32
0xF0 = 1111 0000
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    33
0x0F = 0000 1111
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    34
0xC0 = 1100 0000
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    35
0x3F = 0011 1111
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    36
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    37
3 input bytes = 4 output bytes;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    38
2 input bytes = 2 output bytes;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    39
1 input byte  = 1 output byte.
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    40
*/
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    41
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    42
static const gchar *encoding =
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    43
  "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    44
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    45
static const guint decoding[256] =
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    46
{
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    47
  /* ... */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    48
   0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    49
   0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    50
   0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    51
   0, 0, 0, 0, 0, 0, 0, 0, 0, 0,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    52
   0, 0, 0,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    53
  /* + */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    54
  62,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    55
  /* ... */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    56
   0, 0, 0,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    57
  /* / , 0-9 */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    58
  63,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    59
  52, 53, 54, 55, 56, 57, 58, 59, 60, 61,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    60
  /* ... */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    61
   0, 0, 0, 0, 0, 0, 0,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    62
  /* A */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    63
   0,  1,  2,  3,  4,  5,  6,  7,  8,  9, 10, 11, 12,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    64
  13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    65
  /* ... */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    66
   0, 0, 0, 0, 0, 0,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    67
  /* a */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    68
  26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38,
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    69
  39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    70
};
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    71
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    72
#define GET_6_BITS_0(s) (((s)[0] & 0xFC) >> 2)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    73
#define GET_6_BITS_1(s) (((s)[0] & 0x03) << 4) | \
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    74
                        (((s)[1] & 0xF0) >> 4)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    75
#define GET_6_BITS_2(s) (((s)[1] & 0x0F) << 2) | \
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    76
                        (((s)[2] & 0xC0) >> 6)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    77
#define GET_6_BITS_3(s) (((s)[2] & 0x3F) << 0)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    78
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    79
#define GET_BYTE_0(s) (((decoding[(guchar)(s)[0]] & 0x3F) << 2) | \
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    80
                       ((decoding[(guchar)(s)[1]] & 0x30) >> 4))
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    81
#define GET_BYTE_1(s) (((decoding[(guchar)(s)[1]] & 0x0F) << 4) | \
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    82
                       ((decoding[(guchar)(s)[2]] & 0x3C) >> 2))
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    83
#define GET_BYTE_2(s) (((decoding[(guchar)(s)[2]] & 0x03) << 6) | \
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    84
                       ((decoding[(guchar)(s)[3]] & 0xFF) << 0))
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    85
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    86
gchar *_lm_base64_encode (const gchar *txt, gsize n)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    87
{
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    88
  guint i;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    89
  guint len;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    90
  GString *tmp;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    91
  GString *str = g_string_new_len (txt, n);
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    92
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    93
  len = str->len;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    94
  /* TODO: calculate requisite output string length and allocate that big a
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    95
   * GString */
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    96
  tmp = g_string_new ("");
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    97
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    98
  for (i = 0; i < len; i += 3)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
    99
    {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   100
      guint c1, c2, c3, c4;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   101
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   102
      switch (i + 3 - len)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   103
        {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   104
        case 1:
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   105
          c1 = encoding[GET_6_BITS_0 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   106
          c2 = encoding[GET_6_BITS_1 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   107
          c3 = encoding[GET_6_BITS_2 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   108
          c4 = '=';
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   109
          break;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   110
        case 2:
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   111
          c1 = encoding[GET_6_BITS_0 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   112
          c2 = encoding[GET_6_BITS_1 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   113
          c3 = '=';
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   114
          c4 = '=';
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   115
          break;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   116
        default:
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   117
          c1 = encoding[GET_6_BITS_0 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   118
          c2 = encoding[GET_6_BITS_1 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   119
          c3 = encoding[GET_6_BITS_2 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   120
          c4 = encoding[GET_6_BITS_3 (str->str + i)];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   121
        }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   122
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   123
      g_string_append_printf (tmp, "%c%c%c%c", c1, c2, c3, c4);
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   124
    }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   125
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   126
  return g_string_free (tmp, FALSE);
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   127
}
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   128
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   129
gchar *_lm_base64_decode (const gchar *str, gsize *len)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   130
{
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   131
  guint i;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   132
  GString *tmp;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   133
  char group[4];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   134
  guint filled = 0;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   135
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   136
  *len = 0;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   137
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   138
  for (i = 0; str[i]; i++)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   139
    {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   140
      if (str[i] != 'A' &&
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   141
          str[i] != '=' &&
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   142
          !isspace(str[i]) &&
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   143
          decoding[(guchar) str[i]] == 0)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   144
        {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   145
          g_debug ("bad character %x at byte %u", (guchar)str[i], i);
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   146
          return NULL;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   147
        }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   148
    }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   149
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   150
  tmp = g_string_new ("");
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   151
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   152
  for (i = 0; str[i]; i++)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   153
    {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   154
      if (isspace(str[i]))
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   155
        continue;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   156
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   157
      group[filled++] = str[i];
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   158
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   159
      if (filled == 4)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   160
        {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   161
          if (group[3] == '=')
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   162
            {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   163
              if (group[2] == '=')
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   164
                {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   165
                  g_string_append_c (tmp, GET_BYTE_0(group));
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   166
                }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   167
              else
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   168
                {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   169
                  g_string_append_c (tmp, GET_BYTE_0(group));
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   170
                  g_string_append_c (tmp, GET_BYTE_1(group));
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   171
                }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   172
             }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   173
           else
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   174
            {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   175
              g_string_append_c (tmp, GET_BYTE_0(group));
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   176
              g_string_append_c (tmp, GET_BYTE_1(group));
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   177
              g_string_append_c (tmp, GET_BYTE_2(group));
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   178
            }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   179
          filled = 0;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   180
        }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   181
    }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   182
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   183
  if (filled)
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   184
    {
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   185
      g_debug ("insufficient padding at end of base64 string:\n%s", str);
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   186
      g_string_free (tmp, TRUE);
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   187
      return NULL;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   188
    }
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   189
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   190
  *len = tmp->len;
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   191
  return g_string_free (tmp, FALSE);
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   192
}
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   193
16d512c3ce31 Added base64.[ch] and md5.[ch] from Senko
Mikael Hallendal <micke@imendio.com>
parents:
diff changeset
   194