/** @addtogroup group_funcmacro_misc */
//@{
+/**
+ Elements of this enum specify the possible behaviours of wxBase64Decode
+ when an invalid character is encountered.
+*/
+enum wxBase64DecodeMode
+{
+ wxBase64DecodeMode_Strict, ///< Normal behaviour: stop at any invalid characters.
+ wxBase64DecodeMode_SkipWS, ///< Skip whitespace characters.
+ wxBase64DecodeMode_Relaxed ///< The most lenient behaviour: simply ignore all invalid characters.
+};
+
/**
This function encodes the given data using base64.
This overload is a raw decoding function and decodes the data into the
provided buffer @a dst of the given size @e dstLen. An error is returned if
the buffer is not large enough -- that is not at least
- wxBase64DecodedSize(srcLen) bytes.
+ wxBase64DecodedSize(srcLen) bytes. Notice that the buffer will @e not be
+ @NULL-terminated.
This overload returns the number of bytes written to the buffer or the
necessary buffer size if @a dst was @NULL or @c wxCONV_FAILED on error,
const char* src,
size_t srcLen = wxNO_LEN,
wxBase64DecodeMode mode = wxBase64DecodeMode_Strict,
- size_t posErr = NULL);
+ size_t *posErr = NULL);
/**
- See the wxBase64Decode(void*,size_t,const char*,size_t,wxBase64DecodeMode,size_t)
+ See the wxBase64Decode(void*,size_t,const char*,size_t,wxBase64DecodeMode,size_t*)
overload for more info about the parameters of this function.
This overload allocates memory internally and returns it as wxMemoryBuffer
wxMemoryBuffer wxBase64Decode(const char* src,
size_t srcLen = wxNO_LEN,
wxBase64DecodeMode mode = wxBase64DecodeMode_Strict,
- size_t posErr = NULL);
+ size_t *posErr = NULL);
/**
- See the wxBase64Decode(void*,size_t,const char*,size_t,wxBase64DecodeMode,size_t)
+ See the wxBase64Decode(void*,size_t,const char*,size_t,wxBase64DecodeMode,size_t*)
overload for more info about the parameters of this function.
This overload takes as input a wxString and returns the internally-allocated
*/
wxMemoryBuffer wxBase64Decode(const wxString& src,
wxBase64DecodeMode mode = wxBase64DecodeMode_Strict,
- size_t posErr = NULL);
+ size_t *posErr = NULL);
//@}