Radish alpha
H
rad:z3QDZAW2FAfuLvihrhiyDC9fAD8G9
HardenedBSD Package Manager
Radicle
Git
Add forgotten files.
Vsevolod Stakhov committed 11 years ago
commit 3319f10fa954ab1df1048f897833a3cfb6eb06d9
parent 7e88f03
2 files changed +632 -0
added external/libucl/src/ucl_emitter_streamline.c
@@ -0,0 +1,166 @@
+
/* Copyright (c) 2014, Vsevolod Stakhov
+
 * All rights reserved.
+
 *
+
 * Redistribution and use in source and binary forms, with or without
+
 * modification, are permitted provided that the following conditions are met:
+
 *       * Redistributions of source code must retain the above copyright
+
 *         notice, this list of conditions and the following disclaimer.
+
 *       * Redistributions in binary form must reproduce the above copyright
+
 *         notice, this list of conditions and the following disclaimer in the
+
 *         documentation and/or other materials provided with the distribution.
+
 *
+
 * THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY
+
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+
 * DISCLAIMED. IN NO EVENT SHALL AUTHOR BE LIABLE FOR ANY
+
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
 */
+

+
#ifdef HAVE_CONFIG_H
+
#include "config.h"
+
#endif
+

+
#include "ucl.h"
+
#include "ucl_internal.h"
+
#include "ucl_chartable.h"
+

+
struct ucl_emitter_streamline_stack {
+
	bool is_array;
+
	bool empty;
+
	const ucl_object_t *obj;
+
	struct ucl_emitter_streamline_stack *next;
+
};
+

+
struct ucl_emitter_context_streamline {
+
	/* Inherited from the main context */
+
	const char *name;
+
	int id;
+
	const struct ucl_emitter_functions *func;
+
	const struct ucl_emitter_operations *ops;
+
	unsigned int ident;
+
	const ucl_object_t *top;
+

+
	/* Streamline specific fields */
+
	struct ucl_emitter_streamline_stack *containers;
+
};
+

+
#define TO_STREAMLINE(ctx) (struct ucl_emitter_context_streamline *)(ctx)
+

+
struct ucl_emitter_context*
+
ucl_object_emit_streamline_new (const ucl_object_t *obj,
+
		enum ucl_emitter emit_type,
+
		struct ucl_emitter_functions *emitter)
+
{
+
	const struct ucl_emitter_context *ctx;
+
	struct ucl_emitter_context_streamline *sctx;
+

+
	ctx = ucl_emit_get_standard_context (emit_type);
+
	if (ctx == NULL) {
+
		return NULL;
+
	}
+

+
	sctx = calloc (1, sizeof (*sctx));
+
	if (sctx == NULL) {
+
		return NULL;
+
	}
+

+
	memcpy (sctx, ctx, sizeof (*ctx));
+
	sctx->func = emitter;
+
	sctx->top = obj;
+

+
	ucl_object_emit_streamline_start_container ((struct ucl_emitter_context *)sctx,
+
			obj);
+

+
	return (struct ucl_emitter_context *)sctx;
+
}
+

+
void
+
ucl_object_emit_streamline_start_container (struct ucl_emitter_context *ctx,
+
		const ucl_object_t *obj)
+
{
+
	struct ucl_emitter_context_streamline *sctx = TO_STREAMLINE(ctx);
+
	struct ucl_emitter_streamline_stack *st, *top;
+
	bool print_key = false;
+

+
	/* Check top object presence */
+
	if (sctx->top == NULL) {
+
		sctx->top = obj;
+
	}
+

+
	top = sctx->containers;
+
	st = malloc (sizeof (*st));
+
	if (st != NULL) {
+
		if (top != NULL && !top->is_array) {
+
			print_key = true;
+
		}
+
		st->empty = true;
+
		st->obj = obj;
+
		if (obj != NULL && obj->type == UCL_ARRAY) {
+
			st->is_array = true;
+
			sctx->ops->ucl_emitter_start_array (ctx, obj, print_key);
+
		}
+
		else {
+
			st->is_array = false;
+
			sctx->ops->ucl_emitter_start_object (ctx, obj, print_key);
+
		}
+
	}
+

+
	LL_PREPEND (sctx->containers, st);
+
}
+

+
void
+
ucl_object_emit_streamline_add_object (
+
		struct ucl_emitter_context *ctx, const ucl_object_t *obj)
+
{
+
	struct ucl_emitter_context_streamline *sctx = TO_STREAMLINE(ctx);
+
	bool is_array = false, is_first = false;
+

+
	if (sctx->containers != NULL) {
+
		if (sctx->containers->is_array) {
+
			is_array = true;
+
		}
+
		if (sctx->containers->empty) {
+
			is_first = true;
+
			sctx->containers->empty = false;
+
		}
+
	}
+

+
	sctx->ops->ucl_emitter_write_elt (ctx, obj, is_first, !is_array);
+
}
+

+
void
+
ucl_object_emit_streamline_end_container (struct ucl_emitter_context *ctx)
+
{
+
	struct ucl_emitter_context_streamline *sctx = TO_STREAMLINE(ctx);
+
	struct ucl_emitter_streamline_stack *st;
+

+
	if (sctx->containers != NULL) {
+
		st = sctx->containers;
+

+
		if (st->is_array) {
+
			sctx->ops->ucl_emitter_end_array (ctx, st->obj);
+
		}
+
		else {
+
			sctx->ops->ucl_emitter_end_object (ctx, st->obj);
+
		}
+
		sctx->containers = st->next;
+
		free (st);
+
	}
+
}
+

+
void
+
ucl_object_emit_streamline_finish (struct ucl_emitter_context *ctx)
+
{
+
	struct ucl_emitter_context_streamline *sctx = TO_STREAMLINE(ctx);
+

+
	while (sctx->containers != NULL) {
+
		ucl_object_emit_streamline_end_container (ctx);
+
	}
+

+
	free (sctx);
+
}
added external/libucl/src/ucl_emitter_utils.c
@@ -0,0 +1,466 @@
+
/* Copyright (c) 2014, Vsevolod Stakhov
+
 * All rights reserved.
+
 *
+
 * Redistribution and use in source and binary forms, with or without
+
 * modification, are permitted provided that the following conditions are met:
+
 *       * Redistributions of source code must retain the above copyright
+
 *         notice, this list of conditions and the following disclaimer.
+
 *       * Redistributions in binary form must reproduce the above copyright
+
 *         notice, this list of conditions and the following disclaimer in the
+
 *         documentation and/or other materials provided with the distribution.
+
 *
+
 * THIS SOFTWARE IS PROVIDED ''AS IS'' AND ANY
+
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
+
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+
 * DISCLAIMED. IN NO EVENT SHALL AUTHOR BE LIABLE FOR ANY
+
 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
 */
+

+
#ifdef HAVE_CONFIG_H
+
#include "config.h"
+
#endif
+

+
#include "ucl.h"
+
#include "ucl_internal.h"
+
#include "ucl_chartable.h"
+

+
#ifdef HAVE_FLOAT_H
+
#include <float.h>
+
#endif
+
#ifdef HAVE_MATH_H
+
#include <math.h>
+
#endif
+

+
extern const struct ucl_emitter_operations ucl_standartd_emitter_ops[];
+

+
static const struct ucl_emitter_context ucl_standard_emitters[] = {
+
	[UCL_EMIT_JSON] = {
+
		.name = "json",
+
		.id = UCL_EMIT_JSON,
+
		.func = NULL,
+
		.ops = &ucl_standartd_emitter_ops[UCL_EMIT_JSON]
+
	},
+
	[UCL_EMIT_JSON_COMPACT] = {
+
		.name = "json_compact",
+
		.id = UCL_EMIT_JSON_COMPACT,
+
		.func = NULL,
+
		.ops = &ucl_standartd_emitter_ops[UCL_EMIT_JSON_COMPACT]
+
	},
+
	[UCL_EMIT_CONFIG] = {
+
		.name = "config",
+
		.id = UCL_EMIT_CONFIG,
+
		.func = NULL,
+
		.ops = &ucl_standartd_emitter_ops[UCL_EMIT_CONFIG]
+
	},
+
	[UCL_EMIT_YAML] = {
+
		.name = "yaml",
+
		.id = UCL_EMIT_YAML,
+
		.func = NULL,
+
		.ops = &ucl_standartd_emitter_ops[UCL_EMIT_YAML]
+
	}
+
};
+

+
/**
+
 * Get standard emitter context for a specified emit_type
+
 * @param emit_type type of emitter
+
 * @return context or NULL if input is invalid
+
 */
+
const struct ucl_emitter_context *
+
ucl_emit_get_standard_context (enum ucl_emitter emit_type)
+
{
+
	if (emit_type >= UCL_EMIT_JSON && emit_type <= UCL_EMIT_YAML) {
+
		return &ucl_standard_emitters[emit_type];
+
	}
+

+
	return NULL;
+
}
+

+
/**
+
 * Serialise string
+
 * @param str string to emit
+
 * @param buf target buffer
+
 */
+
void
+
ucl_elt_string_write_json (const char *str, size_t size,
+
		struct ucl_emitter_context *ctx)
+
{
+
	const char *p = str, *c = str;
+
	size_t len = 0;
+
	const struct ucl_emitter_functions *func = ctx->func;
+

+
	if (ctx->id != UCL_EMIT_YAML) {
+
		func->ucl_emitter_append_character ('"', 1, func->ud);
+
	}
+

+
	while (size) {
+
		if (ucl_test_character (*p, UCL_CHARACTER_JSON_UNSAFE)) {
+
			if (len > 0) {
+
				func->ucl_emitter_append_len (c, len, func->ud);
+
			}
+
			switch (*p) {
+
			case '\n':
+
				func->ucl_emitter_append_len ("\\n", 2, func->ud);
+
				break;
+
			case '\r':
+
				func->ucl_emitter_append_len ("\\r", 2, func->ud);
+
				break;
+
			case '\b':
+
				func->ucl_emitter_append_len ("\\b", 2, func->ud);
+
				break;
+
			case '\t':
+
				func->ucl_emitter_append_len ("\\t", 2, func->ud);
+
				break;
+
			case '\f':
+
				func->ucl_emitter_append_len ("\\f", 2, func->ud);
+
				break;
+
			case '\\':
+
				func->ucl_emitter_append_len ("\\\\", 2, func->ud);
+
				break;
+
			case '"':
+
				func->ucl_emitter_append_len ("\\\"", 2, func->ud);
+
				break;
+
			}
+
			len = 0;
+
			c = ++p;
+
		}
+
		else {
+
			p ++;
+
			len ++;
+
		}
+
		size --;
+
	}
+
	if (len > 0) {
+
		func->ucl_emitter_append_len (c, len, func->ud);
+
	}
+
	if (ctx->id != UCL_EMIT_YAML) {
+
		func->ucl_emitter_append_character ('"', 1, func->ud);
+
	}
+
}
+

+
/*
+
 * Generic utstring output
+
 */
+
static int
+
ucl_utstring_append_character (unsigned char c, size_t len, void *ud)
+
{
+
	UT_string *buf = ud;
+

+
	if (len == 1) {
+
		utstring_append_c (buf, c);
+
	}
+
	else {
+
		utstring_reserve (buf, len);
+
		memset (&buf->d[buf->i], c, len);
+
		buf->i += len;
+
		buf->d[buf->i] = '\0';
+
	}
+

+
	return 0;
+
}
+

+
static int
+
ucl_utstring_append_len (const unsigned char *str, size_t len, void *ud)
+
{
+
	UT_string *buf = ud;
+

+
	utstring_append_len (buf, str, len);
+

+
	return 0;
+
}
+

+
static int
+
ucl_utstring_append_int (int64_t val, void *ud)
+
{
+
	UT_string *buf = ud;
+

+
	utstring_printf (buf, "%jd", (intmax_t)val);
+
	return 0;
+
}
+

+
static int
+
ucl_utstring_append_double (double val, void *ud)
+
{
+
	UT_string *buf = ud;
+
	const double delta = 0.0000001;
+

+
	if (val == (double)(int)val) {
+
		utstring_printf (buf, "%.1lf", val);
+
	}
+
	else if (fabs (val - (double)(int)val) < delta) {
+
		/* Write at maximum precision */
+
		utstring_printf (buf, "%.*lg", DBL_DIG, val);
+
	}
+
	else {
+
		utstring_printf (buf, "%lf", val);
+
	}
+

+
	return 0;
+
}
+

+
/*
+
 * Generic file output
+
 */
+
static int
+
ucl_file_append_character (unsigned char c, size_t len, void *ud)
+
{
+
	FILE *fp = ud;
+

+
	while (len --) {
+
		fputc (c, fp);
+
	}
+

+
	return 0;
+
}
+

+
static int
+
ucl_file_append_len (const unsigned char *str, size_t len, void *ud)
+
{
+
	FILE *fp = ud;
+

+
	fwrite (str, len, 1, fp);
+

+
	return 0;
+
}
+

+
static int
+
ucl_file_append_int (int64_t val, void *ud)
+
{
+
	FILE *fp = ud;
+

+
	fprintf (fp, "%jd", (intmax_t)val);
+

+
	return 0;
+
}
+

+
static int
+
ucl_file_append_double (double val, void *ud)
+
{
+
	FILE *fp = ud;
+
	const double delta = 0.0000001;
+

+
	if (val == (double)(int)val) {
+
		fprintf (fp, "%.1lf", val);
+
	}
+
	else if (fabs (val - (double)(int)val) < delta) {
+
		/* Write at maximum precision */
+
		fprintf (fp, "%.*lg", DBL_DIG, val);
+
	}
+
	else {
+
		fprintf (fp, "%lf", val);
+
	}
+

+
	return 0;
+
}
+

+
/*
+
 * Generic file descriptor writing functions
+
 */
+
static int
+
ucl_fd_append_character (unsigned char c, size_t len, void *ud)
+
{
+
	int fd = *(int *)ud;
+
	unsigned char *buf;
+

+
	if (len == 1) {
+
		write (fd, &c, 1);
+
	}
+
	else {
+
		buf = malloc (len);
+
		if (buf == NULL) {
+
			/* Fallback */
+
			while (len --) {
+
				write (fd, &c, 1);
+
			}
+
		}
+
		else {
+
			memset (buf, c, len);
+
			write (fd, buf, len);
+
			free (buf);
+
		}
+
	}
+

+
	return 0;
+
}
+

+
static int
+
ucl_fd_append_len (const unsigned char *str, size_t len, void *ud)
+
{
+
	int fd = *(int *)ud;
+

+
	write (fd, str, len);
+

+
	return 0;
+
}
+

+
static int
+
ucl_fd_append_int (int64_t val, void *ud)
+
{
+
	int fd = *(int *)ud;
+
	char intbuf[64];
+

+
	snprintf (intbuf, sizeof (intbuf), "%jd", (intmax_t)val);
+
	write (fd, intbuf, strlen (intbuf));
+

+
	return 0;
+
}
+

+
static int
+
ucl_fd_append_double (double val, void *ud)
+
{
+
	int fd = *(int *)ud;
+
	const double delta = 0.0000001;
+
	char nbuf[64];
+

+
	if (val == (double)(int)val) {
+
		snprintf (nbuf, sizeof (nbuf), "%.1lf", val);
+
	}
+
	else if (fabs (val - (double)(int)val) < delta) {
+
		/* Write at maximum precision */
+
		snprintf (nbuf, sizeof (nbuf), "%.*lg", DBL_DIG, val);
+
	}
+
	else {
+
		snprintf (nbuf, sizeof (nbuf), "%lf", val);
+
	}
+

+
	write (fd, nbuf, strlen (nbuf));
+

+
	return 0;
+
}
+

+
struct ucl_emitter_functions*
+
ucl_object_emit_memory_funcs (void **pmem)
+
{
+
	struct ucl_emitter_functions *f;
+
	UT_string *s;
+

+
	f = calloc (1, sizeof (*f));
+

+
	if (f != NULL) {
+
		f->ucl_emitter_append_character = ucl_utstring_append_character;
+
		f->ucl_emitter_append_double = ucl_utstring_append_double;
+
		f->ucl_emitter_append_int = ucl_utstring_append_int;
+
		f->ucl_emitter_append_len = ucl_utstring_append_len;
+
		f->ucl_emitter_free_func = free;
+
		utstring_new (s);
+
		f->ud = s;
+
		*pmem = s->d;
+
		s->pd = pmem;
+
	}
+

+
	return f;
+
}
+

+
struct ucl_emitter_functions*
+
ucl_object_emit_file_funcs (FILE *fp)
+
{
+
	struct ucl_emitter_functions *f;
+

+
	f = calloc (1, sizeof (*f));
+

+
	if (f != NULL) {
+
		f->ucl_emitter_append_character = ucl_file_append_character;
+
		f->ucl_emitter_append_double = ucl_file_append_double;
+
		f->ucl_emitter_append_int = ucl_file_append_int;
+
		f->ucl_emitter_append_len = ucl_file_append_len;
+
		f->ucl_emitter_free_func = NULL;
+
		f->ud = fp;
+
	}
+

+
	return f;
+
}
+

+
struct ucl_emitter_functions*
+
ucl_object_emit_fd_funcs (int fd)
+
{
+
	struct ucl_emitter_functions *f;
+
	int *ip;
+

+
	f = calloc (1, sizeof (*f));
+

+
	if (f != NULL) {
+
		ip = malloc (sizeof (fd));
+
		if (ip == NULL) {
+
			free (f);
+
			return NULL;
+
		}
+

+
		memcpy (ip, &fd, sizeof (fd));
+
		f->ucl_emitter_append_character = ucl_fd_append_character;
+
		f->ucl_emitter_append_double = ucl_fd_append_double;
+
		f->ucl_emitter_append_int = ucl_fd_append_int;
+
		f->ucl_emitter_append_len = ucl_fd_append_len;
+
		f->ucl_emitter_free_func = free;
+
		f->ud = ip;
+
	}
+

+
	return f;
+
}
+

+
void
+
ucl_object_emit_funcs_free (struct ucl_emitter_functions *f)
+
{
+
	if (f != NULL) {
+
		if (f->ucl_emitter_free_func != NULL) {
+
			f->ucl_emitter_free_func (f->ud);
+
		}
+
		free (f);
+
	}
+
}
+

+

+
unsigned char *
+
ucl_object_emit_single_json (const ucl_object_t *obj)
+
{
+
	UT_string *buf = NULL;
+
	unsigned char *res = NULL;
+

+
	if (obj == NULL) {
+
		return NULL;
+
	}
+

+
	utstring_new (buf);
+

+
	if (buf != NULL) {
+
		switch (obj->type) {
+
		case UCL_OBJECT:
+
			ucl_utstring_append_len ("object", 6, buf);
+
			break;
+
		case UCL_ARRAY:
+
			ucl_utstring_append_len ("array", 5, buf);
+
			break;
+
		case UCL_INT:
+
			ucl_utstring_append_int (obj->value.iv, buf);
+
			break;
+
		case UCL_FLOAT:
+
		case UCL_TIME:
+
			ucl_utstring_append_double (obj->value.dv, buf);
+
			break;
+
		case UCL_NULL:
+
			ucl_utstring_append_len ("null", 4, buf);
+
			break;
+
		case UCL_BOOLEAN:
+
			if (obj->value.iv) {
+
				ucl_utstring_append_len ("true", 4, buf);
+
			}
+
			else {
+
				ucl_utstring_append_len ("false", 5, buf);
+
			}
+
			break;
+
		case UCL_STRING:
+
			ucl_utstring_append_len (obj->value.sv, obj->len, buf);
+
			break;
+
		case UCL_USERDATA:
+
			ucl_utstring_append_len ("userdata", 8, buf);
+
			break;
+
		}
+
		res = utstring_body (buf);
+
		free (buf);
+
	}
+

+
	return res;
+
}