| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417 | /* ///////////////////////////////////////////////////////////////////////////// * File:        b64/b64.h * * Purpose:     Header file for the b64 library * * Created:     18th October 2004 * Updated:     15th March 2008 * * Thanks:      To Adam McLaurin, for ideas regarding the b64_decode2() and *              b64_encode2(). * * Home:        http://synesis.com.au/software/ * * Copyright (c) 2004-2008, Matthew Wilson and Synesis Software * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * - Redistributions of source code must retain the above copyright notice, this *   list of conditions and the following disclaimer. * - Redistributions in binary form must reproduce the above copyright notice, *   this list of conditions and the following disclaimer in the documentation *   and/or other materials provided with the distribution. * - Neither the name(s) of Matthew Wilson and Synesis Software nor the names of *   any contributors may be used to endorse or promote products derived from *   this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. * * ////////////////////////////////////////////////////////////////////////// *//** \file b64/b64.h * * \brief [C/C++] Header file for the b64 library. */#ifndef B64_INCL_B64_H_B64#define B64_INCL_B64_H_B64/* ///////////////////////////////////////////////////////////////////////////// * Version information */#ifndef B64_DOCUMENTATION_SKIP_SECTION# define B64_VER_B64_H_B64_MAJOR    1# define B64_VER_B64_H_B64_MINOR    5# define B64_VER_B64_H_B64_REVISION 1# define B64_VER_B64_H_B64_EDIT     25#endif /* !B64_DOCUMENTATION_SKIP_SECTION *//** \def B64_VER_MAJOR * The major version number of b64 *//** \def B64_VER_MINOR * The minor version number of b64 *//** \def B64_VER_REVISION * The revision version number of b64 *//** \def B64_VER * The current composite version number of b64 */#ifndef B64_DOCUMENTATION_SKIP_SECTION# define B64_VER_1_0_1      0x01000100# define B64_VER_1_0_2      0x01000200# define B64_VER_1_0_3      0x01000300# define B64_VER_1_1_1      0x01010100# define B64_VER_1_1_2      0x01010200# define B64_VER_1_1_3      0x01010300# define B64_VER_1_2_1      0x01020100# define B64_VER_1_2_2      0x01020200# define B64_VER_1_2_3      0x01020300# define B64_VER_1_2_4      0x01020400# define B64_VER_1_2_5      0x01020500# define B64_VER_1_2_6      0x01020600# define B64_VER_1_2_7      0x01020700# define B64_VER_1_3_1      0x010301ff# define B64_VER            B64_VER_1_3_1#else /* ? B64_DOCUMENTATION_SKIP_SECTION */# define B64_VER            0x010301ff#endif /* !B64_DOCUMENTATION_SKIP_SECTION */#define B64_VER_MAJOR       1#define B64_VER_MINOR       3#define B64_VER_REVISION    1/* ///////////////////////////////////////////////////////////////////////////// * Includes */#include <stddef.h>/* ///////////////////////////////////////////////////////////////////////////// * Namespace */#if !defined(B64_NO_NAMESPACE) && \    !defined(__cplusplus)# define B64_NO_NAMESPACE#endif /* !B64_NO_NAMESPACE && !__cplusplus */#ifdef B64_NAMESPACE# undef B64_NAMESPACE#endif /* B64_NAMESPACE */#ifdef B64_NAMESPACE_QUALIFIER# undef B64_NAMESPACE_QUALIFIER#endif /* B64_NAMESPACE_QUALIFIER */#ifndef B64_NO_NAMESPACE# ifdef B64_CUSTOM_NAMESPACE#  define B64_NAMESPACE     B64_CUSTOM_NAMESPACE# else /* ? B64_CUSTOM_NAMESPACE */#  define B64_NAMESPACE     b64# endif /* B64_CUSTOM_NAMESPACE */# if defined(B64_CUSTOM_NAMESPACE) && \     defined(B64_CUSTOM_NAMESPACE_QUALIFIER)#  define B64_NAMESPACE_QUALIFIER       B64_CUSTOM_NAMESPACE_QUALIFIER# else /* B64_CUSTOM_NAMESPACE && B64_CUSTOM_NAMESPACE_QUALIFIER */#  define B64_NAMESPACE_QUALIFIER       ::B64_NAMESPACE# endif /* B64_CUSTOM_NAMESPACE && B64_CUSTOM_NAMESPACE_QUALIFIER *//** \brief [C/C++] The b64 namespace, within which the core library types and functions * reside in C++ compilation. In C compilation, they all reside in the global * namespace. * * \htmlonly * <hr> * \endhtmlonly */namespace B64_NAMESPACE{#endif /* !B64_NO_NAMESPACE *//* ///////////////////////////////////////////////////////////////////////////// * Enumerations *//** \brief Return codes (from b64_encode2() / b64_decode2()) */enum B64_RC{        B64_RC_OK                   =   0   /*!< Operation was successful. */    ,   B64_RC_INSUFFICIENT_BUFFER  =   1   /*!< The given translation buffer was not of sufficient size. */    ,   B64_RC_TRUNCATED_INPUT      =   2   /*!< The input did not represent a fully formed stream of octet couplings. */    ,   B64_RC_DATA_ERROR           =   3   /*!< Invalid data. */#ifndef B64_DOCUMENTATION_SKIP_SECTION    ,   B64_max_RC_value#endif /* !B64_DOCUMENTATION_SKIP_SECTION */};#ifndef __cplusplustypedef enum B64_RC B64_RC;#endif /* !__cplusplus *//** \brief Coding behaviour modification flags (for b64_encode2() / b64_decode2()) */enum B64_FLAGS{        B64_F_LINE_LEN_USE_PARAM    =   0x0000  /*!< Uses the lineLen parameter to b64_encode2(). Ignored by b64_decode2(). */    ,   B64_F_LINE_LEN_INFINITE     =   0x0001  /*!< Ignores the lineLen parameter to b64_encode2(). Line length is infinite. Ignored by b64_decode2(). */    ,   B64_F_LINE_LEN_64           =   0x0002  /*!< Ignores the lineLen parameter to b64_encode2(). Line length is 64. Ignored by b64_decode2(). */    ,   B64_F_LINE_LEN_76           =   0x0003  /*!< Ignores the lineLen parameter to b64_encode2(). Line length is 76. Ignored by b64_decode2(). */    ,   B64_F_LINE_LEN_MASK         =   0x000f  /*!< Mask for testing line length flags to b64_encode2(). Ignored by b64_encode2(). */    ,   B64_F_STOP_ON_NOTHING       =   0x0000  /*!< Decoding ignores all invalid characters in the input data. Ignored by b64_encode2(). */    ,   B64_F_STOP_ON_UNKNOWN_CHAR  =   0x0100  /*!< Causes decoding to break if any non-Base-64 [a-zA-Z0-9=+/], non-whitespace character is encountered. Ignored by b64_encode2(). */    ,   B64_F_STOP_ON_UNEXPECTED_WS =   0x0200  /*!< Causes decoding to break if any unexpected whitespace is encountered. Ignored by b64_encode2(). */    ,   B64_F_STOP_ON_BAD_CHAR      =   0x0300  /*!< Causes decoding to break if any non-Base-64 [a-zA-Z0-9=+/] character is encountered. Ignored by b64_encode2(). */};#ifndef __cplusplustypedef enum B64_FLAGS  B64_FLAGS;#endif /* !__cplusplus *//* ///////////////////////////////////////////////////////////////////////////// * Functions */#ifdef __cplusplusextern "C" {#endif /* __cplusplus *//** \brief Encodes a block of binary data into Base-64 * * \param src Pointer to the block to be encoded. May not be NULL, except when *   \c dest is NULL, in which case it is ignored. * \param srcSize Length of block to be encoded * \param dest Pointer to the buffer into which the result is to be written. May *   be NULL, in which case the function returns the required length * \param destLen Length of the buffer into which the result is to be written. Must *   be at least as large as that indicated by the return value from *   \link b64::b64_encode b64_encode(NULL, srcSize, NULL, 0)\endlink. * * \return 0 if the size of the buffer was insufficient, or the length of the * converted buffer was longer than \c destLen * * \note The function returns the required length if \c dest is NULL * * \note The function returns the required length if \c dest is NULL. The returned size *   might be larger than the actual required size, but will never be smaller. * * \note Threading: The function is fully re-entrant. * * \see b64::encode() */size_t b64_encode(void const *src, size_t srcSize, char *dest, size_t destLen);/** \brief Encodes a block of binary data into Base-64 * * \param src Pointer to the block to be encoded. May not be NULL, except when *   \c dest is NULL, in which case it is ignored. * \param srcSize Length of block to be encoded * \param dest Pointer to the buffer into which the result is to be written. May *   be NULL, in which case the function returns the required length * \param destLen Length of the buffer into which the result is to be written. Must *   be at least as large as that indicated by the return value from *   \link b64::b64_encode2 b64_encode2(NULL, srcSize, NULL, 0, flags, lineLen, rc)\endlink. * \param flags A combination of the B64_FLAGS enumeration, that moderate the *   behaviour of the function * \param lineLen If the flags parameter contains B64_F_LINE_LEN_USE_PARAM, then *   this parameter represents the length of the lines into which the encoded form is split, *   with a hard line break ('\\r\\n'). If this value is 0, then the line is not *   split. If it is <0, then the RFC-1113 recommended line length of 64 is used * \param rc The return code representing the status of the operation. May be NULL. * * \return 0 if the size of the buffer was insufficient, or the length of the *   converted buffer was longer than \c destLen * * \note The function returns the required length if \c dest is NULL. The returned size *   might be larger than the actual required size, but will never be smaller. * * \note Threading: The function is fully re-entrant. * * \see b64::encode() */size_t b64_encode2( void const  *src                ,   size_t      srcSize                ,   char        *dest                ,   size_t      destLen                ,   unsigned    flags                ,   int         lineLen /* = 0 */                ,   B64_RC      *rc     /* = NULL */);/** \brief Decodes a sequence of Base-64 into a block of binary data * * \param src Pointer to the Base-64 block to be decoded. May not be NULL, except when *   \c dest is NULL, in which case it is ignored. If \c dest is NULL, and \c src is *   <b>not</b> NULL, then the returned value is calculated exactly, otherwise a value *   is returned that is guaranteed to be large enough to hold the decoded block. * * \param srcLen Length of block to be encoded. Must be an integral of 4, the Base-64 *   encoding quantum, otherwise the Base-64 block is assumed to be invalid * \param dest Pointer to the buffer into which the result is to be written. May *   be NULL, in which case the function returns the required length * \param destSize Length of the buffer into which the result is to be written. Must *   be at least as large as that indicated by the return value from *   \c b64_decode(src, srcSize, NULL, 0), even in the case where the encoded form *   contains a number of characters that will be ignored, resulting in a lower total *   length of converted form. * * \return 0 if the size of the buffer was insufficient, or the length of the *   converted buffer was longer than \c destSize * * \note The function returns the required length if \c dest is NULL. The returned size *   might be larger than the actual required size, but will never be smaller. * * \note \anchor anchor__4_characters The behaviour of both * \link b64::b64_encode2 b64_encode2()\endlink * and * \link b64::b64_decode2 b64_decode2()\endlink * are undefined if the line length is not a multiple of 4. * * \note Threading: The function is fully re-entrant. * * \see b64::decode() */size_t b64_decode(char const *src, size_t srcLen, void *dest, size_t destSize);/** \brief Decodes a sequence of Base-64 into a block of binary data * * \param src Pointer to the Base-64 block to be decoded. May not be NULL, except when * \c dest is NULL, in which case it is ignored. If \c dest is NULL, and \c src is * <b>not</b> NULL, then the returned value is calculated exactly, otherwise a value * is returned that is guaranteed to be large enough to hold the decoded block. * * \param srcLen Length of block to be encoded. Must be an integral of 4, the Base-64 *   encoding quantum, otherwise the Base-64 block is assumed to be invalid * \param dest Pointer to the buffer into which the result is to be written. May *   be NULL, in which case the function returns the required length * \param destSize Length of the buffer into which the result is to be written. Must *   be at least as large as that indicated by the return value from *   \c b64_decode(src, srcSize, NULL, 0), even in the case where the encoded form *   contains a number of characters that will be ignored, resulting in a lower total *   length of converted form. * \param flags A combination of the B64_FLAGS enumeration, that moderate the *   behaviour of the function. * \param rc The return code representing the status of the operation. May be NULL. * \param badChar If the flags parameter does not contain B64_F_STOP_ON_NOTHING, this *   parameter specifies the address of a pointer that will be set to point to any *   character in the sequence that stops the parsing, as dictated by the flags *   parameter. May be NULL. * * \return 0 if the size of the buffer was insufficient, or the length of the * converted buffer was longer than \c destSize, or a bad character stopped parsing. * * \note The function returns the required length if \c dest is NULL. The returned size *   might be larger than the actual required size, but will never be smaller. * * \note The behaviour of both * \link b64::b64_encode2 b64_encode2()\endlink * and * \link b64::b64_decode2 b64_decode2()\endlink * are undefined if the line length is not a multiple of 4. * * \note Threading: The function is fully re-entrant. * * \see b64::decode() */size_t b64_decode2( char const  *src                ,   size_t      srcLen                ,   void        *dest                ,   size_t      destSize                ,   unsigned    flags                ,   char const  **badChar   /* = NULL */                ,   B64_RC      *rc         /* = NULL */);/** \brief Returns the textual description of the error * * \param code The \link b64::B64_RC error code\endlink */char const *b64_getErrorString(B64_RC code);/** \brief Returns the length of the textual description of the error * * \see b64_getErrorString() * * \param code The \link b64::B64_RC error code\endlink */size_t b64_getErrorStringLength(B64_RC code);#ifdef __cplusplus} /* extern "C" */#endif /* __cplusplus *//* ///////////////////////////////////////////////////////////////////////////// * Namespace */#ifndef B64_NO_NAMESPACE} /* namespace B64_NAMESPACE */# ifndef B64_DOCUMENTATION_SKIP_SECTIONnamespace stlsoft{    inline char const *c_str_data_a( B64_NAMESPACE_QUALIFIER::B64_RC code)    {        return B64_NAMESPACE_QUALIFIER::b64_getErrorString(code);    }    inline char const *c_str_data( B64_NAMESPACE_QUALIFIER::B64_RC code)    {        return B64_NAMESPACE_QUALIFIER::b64_getErrorString(code);    }    inline size_t c_str_len_a( B64_NAMESPACE_QUALIFIER::B64_RC code)    {        return B64_NAMESPACE_QUALIFIER::b64_getErrorStringLength(code);    }    inline size_t c_str_len( B64_NAMESPACE_QUALIFIER::B64_RC code)    {        return B64_NAMESPACE_QUALIFIER::b64_getErrorStringLength(code);    }    inline char const *c_str_ptr_a( B64_NAMESPACE_QUALIFIER::B64_RC code)    {        return B64_NAMESPACE_QUALIFIER::b64_getErrorString(code);    }    inline char const *c_str_ptr( B64_NAMESPACE_QUALIFIER::B64_RC code)    {        return B64_NAMESPACE_QUALIFIER::b64_getErrorString(code);    }} /* namespace stlsoft */# endif /* !B64_DOCUMENTATION_SKIP_SECTION */#endif /* !B64_NO_NAMESPACE *//* ////////////////////////////////////////////////////////////////////////// */#endif /* B64_INCL_B64_H_B64 *//* ////////////////////////////////////////////////////////////////////////// */
 |