OLD | NEW |
1 /* | 1 /* |
2 * Base64.c | |
3 * Copyright (c) 2006 Ryan Martell. (rdm4@martellventures.com) | 2 * Copyright (c) 2006 Ryan Martell. (rdm4@martellventures.com) |
4 * | 3 * |
5 * This file is part of FFmpeg. | 4 * This file is part of FFmpeg. |
6 * | 5 * |
7 * FFmpeg is free software; you can redistribute it and/or | 6 * FFmpeg is free software; you can redistribute it and/or |
8 * modify it under the terms of the GNU Lesser General Public | 7 * modify it under the terms of the GNU Lesser General Public |
9 * License as published by the Free Software Foundation; either | 8 * License as published by the Free Software Foundation; either |
10 * version 2.1 of the License, or (at your option) any later version. | 9 * version 2.1 of the License, or (at your option) any later version. |
11 * | 10 * |
12 * FFmpeg is distributed in the hope that it will be useful, | 11 * FFmpeg is distributed in the hope that it will be useful, |
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of | 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of |
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
15 * Lesser General Public License for more details. | 14 * Lesser General Public License for more details. |
16 * | 15 * |
17 * You should have received a copy of the GNU Lesser General Public | 16 * You should have received a copy of the GNU Lesser General Public |
18 * License along with FFmpeg; if not, write to the Free Software | 17 * License along with FFmpeg; if not, write to the Free Software |
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA | 18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA |
20 */ | 19 */ |
21 | 20 |
22 #ifndef AVUTIL_BASE64_H | 21 #ifndef AVUTIL_BASE64_H |
23 #define AVUTIL_BASE64_H | 22 #define AVUTIL_BASE64_H |
24 | 23 |
25 #include <stdint.h> | 24 #include <stdint.h> |
26 | 25 |
27 /** | 26 /** |
28 * decodes base64 | 27 * Decodes the base64-encoded string in \p in and puts the decoded |
29 * param order as strncpy() | 28 * data in \p out. |
| 29 * |
| 30 * @param out_size size in bytes of the \p out buffer, it should be at |
| 31 * least 3/4 of the length of \p in |
| 32 * @return the number of bytes written, or a negative value in case of |
| 33 * error |
30 */ | 34 */ |
31 int av_base64_decode(uint8_t * out, const char *in, int out_length); | 35 int av_base64_decode(uint8_t *out, const char *in, int out_size); |
32 | 36 |
33 /** | 37 /** |
34 * encodes base64 | 38 * Encodes in base64 the data in \p in and puts the resulting string |
35 * @param src data, not a string | 39 * in \p out. |
36 * @param buf output string | 40 * |
| 41 * @param out_size size in bytes of the \p out string, it should be at |
| 42 * least ((\p in_size + 2) / 3) * 4 + 1 |
| 43 * @param in_size size in bytes of the \p in buffer |
| 44 * @return the string containing the encoded data, or NULL in case of |
| 45 * error |
37 */ | 46 */ |
38 char *av_base64_encode(char * buf, int buf_len, const uint8_t * src, int len); | 47 char *av_base64_encode(char *out, int out_size, const uint8_t *in, int in_size); |
39 | 48 |
40 #endif /* AVUTIL_BASE64_H */ | 49 #endif /* AVUTIL_BASE64_H */ |
OLD | NEW |