Skip to content

Library written in C for encoding and decoding data using base32 or base64 (RFC-4648)

License

Notifications You must be signed in to change notification settings

think-biq/libbaseencode

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

60 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

libbaseencode

Coverity Scan Build Status

Library written in C for encoding and decoding data using base32 or base64 according to RFC-4648

Requiremens

  • GCC or Clang
  • CMake

Build and Install

$ git clone https://github.com/paolostivanin/libbaseencode.git
$ cd libbaseencode
$ mkdir build && cd $_
$ cmake -DCMAKE_INSTALL_PREFIX:PATH=/usr ../
$ make
# make install

How To Use It

char *b32_encoded = base32_encode(unsigned char *input, size_t input_length, baseencode_error_t *err);

unsigned char *b32_decoded = base32_decode(char *input, size_t input_length, baseencode_error_t *err);

char *b64_encoded = base64_encode(unsigned char *input, size_t input_length, baseencode_error_t *err);

unsigned char *b64_decoded = base64_decode(char *input, size_t input_length, baseencode_error_t *err);

Please note that all the returned value must be freed once not needed any more.

Errors

In case of errors, NULL is returned and err is set to either one of:

INVALID_INPUT, EMPTY_STRING, INPUT_TOO_BIG, INVALID_B32_DATA, INVALID_B64_DATA, MEMORY_ALLOCATION,

otherwise, err is set to SUCCESS

About

Library written in C for encoding and decoding data using base32 or base64 (RFC-4648)

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C 85.8%
  • Shell 6.4%
  • CMake 4.8%
  • Dockerfile 3.0%