ChipMaster's trial hacks on C++CMS starting with v1.2.1. Not sure I'll follow on with the v2 since it looks to be breaking and mostly frivolous.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

67 lines
2.7 KiB

  1. ///////////////////////////////////////////////////////////////////////////////
  2. //
  3. // Copyright (C) 2008-2010 Artyom Beilis (Tonkikh) <artyomtnk@yahoo.com>
  4. //
  5. // This program is free software: you can redistribute it and/or modify
  6. // it under the terms of the GNU Lesser General Public License as published by
  7. // the Free Software Foundation, either version 3 of the License, or
  8. // (at your option) any later version.
  9. //
  10. // This program is distributed in the hope that it will be useful,
  11. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. // GNU Lesser General Public License for more details.
  14. //
  15. // You should have received a copy of the GNU Lesser General Public License
  16. // along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. //
  18. ///////////////////////////////////////////////////////////////////////////////
  19. #ifndef CPPCMS_BASE64_H
  20. #define CPPCMS_BASE64_H
  21. #include "defs.h"
  22. #include <string>
  23. namespace cppcms {
  24. ///
  25. /// \brief this namespace provides functions useful for modified Base64 encoding for URL.
  26. /// This encoding does not insert newline characters, do not pad the text with = character and
  27. /// use "_" and "-" instead of "+" and "/" characters reserved by URL format for special purposes.
  28. ///
  29. namespace b64url {
  30. ///
  31. /// Calculate required buffer size of base64-url compatible encoding for source of size \a s
  32. ///
  33. int CPPCMS_API encoded_size(size_t s);
  34. ///
  35. /// Calculate required buffer size of base64-url compatible decoding for source of size \a s
  36. ///
  37. /// Note, if original size is invalid, negative value is returned
  38. ///
  39. int CPPCMS_API decoded_size(size_t s);
  40. ///
  41. /// Perform base64 URL encoding of the binary data in range [\a begin,\a end), and store it to output buffer
  42. /// \a target. The size of target storage should have a capacity calculated with encoded_size(end-begin).
  43. ///
  44. /// Pointer to the first character directly after text string ends is returned.
  45. ///
  46. unsigned char CPPCMS_API *encode(unsigned char const *begin,unsigned char const *end,unsigned char *target);
  47. ///
  48. /// Perform base64 URL decoding of the binary data in range [\a begin,\a end), and store it to output buffer
  49. /// \a target. The size of target storage should have a capacity calculated with encoded_size(end-begin).
  50. ///
  51. /// Pointer to the first character directly after text string ends is returned. Invalid codes are substituted
  52. /// by 0 values.
  53. ///
  54. ///
  55. unsigned char CPPCMS_API *decode(unsigned char const *begin,unsigned char const *end,unsigned char *target);
  56. }
  57. }
  58. #endif