Base64.hh 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. /**********
  2. This library is free software; you can redistribute it and/or modify it under
  3. the terms of the GNU Lesser General Public License as published by the
  4. Free Software Foundation; either version 3 of the License, or (at your
  5. option) any later version. (See <http://www.gnu.org/copyleft/lesser.html>.)
  6. This library is distributed in the hope that it will be useful, but WITHOUT
  7. ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
  8. FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for
  9. more details.
  10. You should have received a copy of the GNU Lesser General Public License
  11. along with this library; if not, write to the Free Software Foundation, Inc.,
  12. 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  13. **********/
  14. // "liveMedia"
  15. // Copyright (c) 1996-2019 Live Networks, Inc. All rights reserved.
  16. // Base64 encoding and decoding
  17. // C++ header
  18. #ifndef _BASE64_HH
  19. #define _BASE64_HH
  20. #ifndef _BOOLEAN_HH
  21. #include "Boolean.hh"
  22. #endif
  23. unsigned char* base64Decode(char const* in, unsigned& resultSize,
  24. Boolean trimTrailingZeros = True);
  25. // returns a newly allocated array - of size "resultSize" - that
  26. // the caller is responsible for delete[]ing.
  27. unsigned char* base64Decode(char const* in, unsigned inSize,
  28. unsigned& resultSize,
  29. Boolean trimTrailingZeros = True);
  30. // As above, but includes the size of the input string (i.e., the number of bytes to decode) as a parameter.
  31. // This saves an extra call to "strlen()" if we already know the length of the input string.
  32. char* base64Encode(char const* orig, unsigned origLength);
  33. // returns a 0-terminated string that
  34. // the caller is responsible for delete[]ing.
  35. #endif