/** * \file modp_b36.h * \brief Base 36 encoding and decoding * * This provides a endian-safe base36 encode/decode operations. This * means, the result will be the same on x86 or ibm/sparc chips. */ /* *
* High Performance Base36 Encoder / Decoder * * Copyright © 2013-2016 Nick Galbreath * All rights reserved. * * https://github.com/client9/stringencoders * * Released under MIT license. See LICENSE for details. ** * This provides a endian-safe base36 encode/decode operations. This * means, the result will be the same on x86 or ibm/sparc chips. * * (Note: making it endian-specifc only results in a 5% savings in * the decode operation, so why bother) */ #ifndef COM_MODP_STRINGENCODERS_B36 #define COM_MODP_STRINGENCODERS_B36 #include "extern_c_begin.h" #include "modp_stdint.h" /** * \brief base 36 encode * * \param[out] dest should have at least b36fast_encode_len memory allocated * \param[in] src input string * \param[in] len input string length, must be a multiple of 4 * \return the strlen of the destination, or -1 if error * */ size_t modp_b36_encode(char* dest, const char* src, size_t len); /** * \brief Base 36 decode * \param[out] dest -- destination locations. May equal input. * \param[in] src -- source b36data * \param len -- length of source * \return -1 on decoding error, length of output otherwise * No ending null is added */ size_t modp_b36_decode(char* dest, const char* src, size_t len); /** * \brief Returns the amount of memory to allocate for encoding the input * string. * */ #define modp_b36_encode_len(A) ((A + 3) / 4 * 5 + 1) /** * \brief Return output strlen, without a NULL */ #define modp_b36_encode_strlen(A) ((A + 3) / 4 * 5) /** * \brief Return the amount of memory to allocate for decoding a base 36 * encoded string. * */ #define modp_b36_decode_len(A) ((A + 4) / 5 * 4) #include "extern_c_end.h" #ifdef __cplusplus #include