summaryrefslogtreecommitdiff
path: root/src/base64
diff options
context:
space:
mode:
authorVivien Kraus <vivien@planete-kraus.eu>2020-11-27 19:28:50 +0100
committerVivien Kraus <vivien@planete-kraus.eu>2021-06-19 15:44:24 +0200
commit7c81a49d762e67b21c99a95b86d1e7886d91de02 (patch)
tree41134870f6edc1b7b5567638f3740758ba5d0fe4 /src/base64
parent9012da74345b0eea06ab36c93f2f36d5584a014c (diff)
Add a base64 encoder and decoder
Diffstat (limited to 'src/base64')
-rw-r--r--src/base64/Makefile.am11
-rw-r--r--src/base64/libwebidoidc-base64.c38
2 files changed, 49 insertions, 0 deletions
diff --git a/src/base64/Makefile.am b/src/base64/Makefile.am
new file mode 100644
index 0000000..11fdc5a
--- /dev/null
+++ b/src/base64/Makefile.am
@@ -0,0 +1,11 @@
+noinst_LTLIBRARIES += %reldir%/libwebidoidc-base64.la
+EXTRA_DIST += %reldir%/libwebidoidc-base64.x
+BUILT_SOURCES += %reldir%/libwebidoidc-base64.x
+
+%canon_reldir%_libwebidoidc_base64_la_LIBADD = $(GUILE_LIBS) $(NETTLE_LIBS)
+
+AM_CFLAGS += -I %reldir% -I $(srcdir)/%reldir%
+
+INDENTED += %reldir%/libwebidoidc-base64.c
+
+%reldir%/libwebidoidc-base64.o: %reldir%/libwebidoidc-base64.x
diff --git a/src/base64/libwebidoidc-base64.c b/src/base64/libwebidoidc-base64.c
new file mode 100644
index 0000000..8eb29b8
--- /dev/null
+++ b/src/base64/libwebidoidc-base64.c
@@ -0,0 +1,38 @@
+#include <utilities.h>
+
+#define _(s) dgettext (PACKAGE, s)
+
+void init_webidoidc_base64 (void);
+
+SCM_DEFINE (webidoidc_base64_encode_g, "base64-encode", 1, 0, 0, (SCM data),
+ "Encode @var{data} as base64. If @var{data} is a string, first encode it to UTF-8.")
+{
+ size_t c_size;
+ uint8_t *c_data;
+ if (scm_is_string (data))
+ {
+ return webidoidc_base64_encode_g (scm_string_to_utf8 (data));
+ }
+ c_size = scm_c_bytevector_length (data);
+ c_data = scm_gc_malloc_pointerless (c_size, "data");
+ memcpy (c_data, SCM_BYTEVECTOR_CONTENTS (data), c_size);
+ return wrap_bytevector (c_size, c_data);
+}
+
+SCM_DEFINE (webidoidc_base64_decode_g, "base64-decode", 1, 0, 0, (SCM data),
+ "Decode @var{data} from base64.")
+{
+ size_t c_size;
+ uint8_t *c_data = get_as_bytevector (data, &c_size, 1);
+ SCM ret = scm_c_make_bytevector (c_size);
+ memcpy (SCM_BYTEVECTOR_CONTENTS (ret), c_data, c_size);
+ return ret;
+}
+
+void
+init_webidoidc_base64 (void)
+{
+#ifndef SCM_MAGIC_SNARFER
+#include "libwebidoidc-base64.x"
+#endif /* not SCM_MAGIC_SNARFER */
+}