diff options
author | Niels Möller <nisse@lysator.liu.se> | 2002-11-07 09:27:30 +0100 |
---|---|---|
committer | Niels Möller <nisse@lysator.liu.se> | 2002-11-07 09:27:30 +0100 |
commit | d73ccbc126145f965cc2999bb939d370f5cc1e33 (patch) | |
tree | efd1e690740fd394119ce5f3481b2d2051175d3b /sexp-transport-format.c | |
parent | fe5c484c4e3da3465f63c393a0386c7f87aaae71 (diff) | |
download | nettle-d73ccbc126145f965cc2999bb939d370f5cc1e33.tar.gz |
(sexp_transport_format,
sexp_transport_vformat): New file, new functions.
Rev: src/nettle/sexp-transport-format.c:1.1
Diffstat (limited to 'sexp-transport-format.c')
-rw-r--r-- | sexp-transport-format.c | 84 |
1 files changed, 84 insertions, 0 deletions
diff --git a/sexp-transport-format.c b/sexp-transport-format.c new file mode 100644 index 00000000..feb685dc --- /dev/null +++ b/sexp-transport-format.c @@ -0,0 +1,84 @@ +/* sexp-transport-format.c + * + * Writing s-expressions in transport format. + */ + +/* nettle, low-level cryptographics library + * + * Copyright (C) 2002 Niels Möller + * + * The nettle library is free software; you can redistribute it and/or modify + * it under the terms of the GNU Lesser General Public License as published by + * the Free Software Foundation; either version 2.1 of the License, or (at your + * option) any later version. + * + * The nettle library is distributed in the hope that it will be useful, but + * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY + * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public + * License for more details. + * + * You should have received a copy of the GNU Lesser General Public License + * along with the nettle library; see the file COPYING.LIB. If not, write to + * the Free Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, + * MA 02111-1307, USA. + */ + +#include "sexp.h" + +#include "base64.h" +#include "buffer.h" + +unsigned +sexp_transport_vformat(struct nettle_buffer *buffer, + const char *format, va_list args) +{ + unsigned start = 0; + unsigned length; + unsigned base64_length; + + if (buffer) + { + if (!NETTLE_BUFFER_PUTC(buffer, '{')) + return 0; + + start = buffer->size; + } + + length = sexp_vformat(buffer, format, args); + + if (!length) + return 0; + + base64_length = BASE64_ENCODE_RAW_LENGTH(length); + + if (buffer) + { + /* FIXME: This assumes that data is never removed from the + * buffer. That works for the current buffer, but it would be + * nice to get rid of this restriction. */ + if (!nettle_buffer_space(buffer, base64_length - length)) + return 0; + + base64_encode_raw(buffer->contents + start, + length, buffer->contents + start); + + if (!NETTLE_BUFFER_PUTC(buffer, '}')) + return 0; + } + + return base64_length + 2; +} + +unsigned +sexp_transport_format(struct nettle_buffer *buffer, + const char *format, ...) +{ + unsigned done; + va_list args; + + va_start(args, format); + done = sexp_transport_vformat(buffer, format, args); + va_end(args); + + return done; +} |