]> git.saurik.com Git - wxWidgets.git/blame - include/wx/base64.h
Generate clipboard events for wxComboBox in wxGTK too.
[wxWidgets.git] / include / wx / base64.h
CommitLineData
4db03d26
VZ
1///////////////////////////////////////////////////////////////////////////////
2// Name: wx/base64.h
3// Purpose: declaration of BASE64 encoding/decoding functionality
4// Author: Charles Reimers, Vadim Zeitlin
5// Created: 2007-06-18
6// RCS-ID: $Id$
7// Licence: wxWindows licence
8///////////////////////////////////////////////////////////////////////////////
9
10#ifndef _WX_BASE64_H_
11#define _WX_BASE64_H_
12
13#if wxUSE_BASE64
14
15#include "wx/string.h"
16#include "wx/buffer.h"
17
18// ----------------------------------------------------------------------------
19// encoding functions
20// ----------------------------------------------------------------------------
21
22// return the size needed for the buffer containing the encoded representation
23// of a buffer of given length
24inline size_t wxBase64EncodedSize(size_t len) { return 4*((len+2)/3); }
25
26// raw base64 encoding function which encodes the contents of a buffer of the
27// specified length into the buffer of the specified size
28//
29// returns the length of the encoded data or wxCONV_FAILED if the buffer is not
30// large enough; to determine the needed size you can either allocate a buffer
31// of wxBase64EncodedSize(srcLen) size or call the function with NULL buffer in
32// which case the required size will be returned
33WXDLLIMPEXP_BASE size_t
34wxBase64Encode(char *dst, size_t dstLen, const void *src, size_t srcLen);
35
36// encode the contents of the given buffer using base64 and return as string
37// (there is no error return)
38inline wxString wxBase64Encode(const void *src, size_t srcLen)
39{
40 const size_t dstLen = wxBase64EncodedSize(srcLen);
41 wxCharBuffer dst(dstLen);
42 wxBase64Encode(dst.data(), dstLen, src, srcLen);
43
44 return dst;
45}
46
47inline wxString wxBase64Encode(const wxMemoryBuffer& buf)
48{
49 return wxBase64Encode(buf.GetData(), buf.GetDataLen());
50}
51
52// ----------------------------------------------------------------------------
53// decoding functions
54// ----------------------------------------------------------------------------
55
56// elements of this enum specify the possible behaviours of wxBase64Decode()
57// when an invalid character is encountered
58enum wxBase64DecodeMode
59{
60 // normal behaviour: stop at any invalid characters
61 wxBase64DecodeMode_Strict,
62
63 // skip whitespace characters
64 wxBase64DecodeMode_SkipWS,
65
66 // the most lenient behaviour: simply ignore all invalid characters
67 wxBase64DecodeMode_Relaxed
68};
69
70// return the buffer size necessary for decoding a base64 string of the given
71// length
72inline size_t wxBase64DecodedSize(size_t srcLen) { return 3*srcLen/4; }
73
74// raw decoding function which decodes the contents of the string of specified
75// length (or NUL-terminated by default) into the provided buffer of the given
76// size
77//
78// the function normally stops at any character invalid inside a base64-encoded
79// string (i.e. not alphanumeric nor '+' nor '/') but can be made to skip the
80// whitespace or all invalid characters using its mode argument
81//
82// returns the length of the decoded data or wxCONV_FAILED if an error occurs
83// such as the buffer is too small or the encoded string is invalid; in the
84// latter case the posErr is filled with the position where the decoding
85// stopped if it is not NULL
86WXDLLIMPEXP_BASE size_t
87wxBase64Decode(void *dst, size_t dstLen,
88 const char *src, size_t srcLen = wxNO_LEN,
89 wxBase64DecodeMode mode = wxBase64DecodeMode_Strict,
90 size_t *posErr = NULL);
91
869bc90d
VZ
92inline size_t
93wxBase64Decode(void *dst, size_t dstLen,
94 const wxString& src,
95 wxBase64DecodeMode mode = wxBase64DecodeMode_Strict,
96 size_t *posErr = NULL)
97{
98 // don't use str.length() here as the ASCII buffer is shorter than it for
99 // strings with embedded NULs
100 return wxBase64Decode(dst, dstLen, src.ToAscii(), wxNO_LEN, mode, posErr);
101}
102
4db03d26
VZ
103// decode the contents of the given string; the returned buffer is empty if an
104// error occurs during decoding
105WXDLLIMPEXP_BASE wxMemoryBuffer
106wxBase64Decode(const char *src, size_t srcLen = wxNO_LEN,
107 wxBase64DecodeMode mode = wxBase64DecodeMode_Strict,
108 size_t *posErr = NULL);
109
e3408b70
VZ
110inline wxMemoryBuffer
111wxBase64Decode(const wxString& src,
112 wxBase64DecodeMode mode = wxBase64DecodeMode_Strict,
113 size_t *posErr = NULL)
114{
115 // don't use str.length() here as the ASCII buffer is shorter than it for
116 // strings with embedded NULs
117 return wxBase64Decode(src.ToAscii(), wxNO_LEN, mode, posErr);
118}
119
4db03d26
VZ
120#endif // wxUSE_BASE64
121
122#endif // _WX_BASE64_H_