aboutsummaryrefslogtreecommitdiffstats
path: root/VES5.0/evel/evel-library/code/evel_library/evel_json_buffer.c
diff options
context:
space:
mode:
authorMarco Platania <platania@research.att.com>2017-05-18 11:09:08 -0400
committerMarco Platania <platania@research.att.com>2017-05-18 11:09:08 -0400
commitfee6de844f9d4c3aad87733734d35df50117b6b0 (patch)
tree3f42567107ac4a10795c8e80c42b479c4502cbda /VES5.0/evel/evel-library/code/evel_library/evel_json_buffer.c
parentf3fe765461685a753c0f5b061c5c47383c75829f (diff)
Change location of VES5.0 code
Change-Id: If8a1173813eb4d5c14c04b132269696a748505e7 Signed-off-by: Marco Platania <platania@research.att.com>
Diffstat (limited to 'VES5.0/evel/evel-library/code/evel_library/evel_json_buffer.c')
-rw-r--r--VES5.0/evel/evel-library/code/evel_library/evel_json_buffer.c883
1 files changed, 0 insertions, 883 deletions
diff --git a/VES5.0/evel/evel-library/code/evel_library/evel_json_buffer.c b/VES5.0/evel/evel-library/code/evel_library/evel_json_buffer.c
deleted file mode 100644
index e0e119da..00000000
--- a/VES5.0/evel/evel-library/code/evel_library/evel_json_buffer.c
+++ /dev/null
@@ -1,883 +0,0 @@
-/**************************************************************************//**
- * @file
- * Source module relating to internal EVEL_JSON_BUFFER manipulation functions.
- *
- * License
- * -------
- *
- * Copyright(c) <2016>, AT&T Intellectual Property. All other rights reserved.
- *
- * Redistribution and use in source and binary forms, with or without
- * modification, are permitted provided that the following conditions are met:
- *
- * 1. Redistributions of source code must retain the above copyright notice,
- * this list of conditions and the following disclaimer.
- * 2. 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.
- * 3. All advertising materials mentioning features or use of this software
- * must display the following acknowledgement: This product includes
- * software developed by the AT&T.
- * 4. Neither the name of AT&T nor the names of its contributors may be used to
- * endorse or promote products derived from this software without specific
- * prior written permission.
- *
- * THIS SOFTWARE IS PROVIDED BY AT&T INTELLECTUAL PROPERTY ''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 AT&T INTELLECTUAL PROPERTY 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.
- *****************************************************************************/
-
-#include <assert.h>
-#include <string.h>
-
-#include "evel_throttle.h"
-
-/*****************************************************************************/
-/* Local prototypes. */
-/*****************************************************************************/
-static char * evel_json_kv_comma(EVEL_JSON_BUFFER * jbuf);
-
-/**************************************************************************//**
- * Initialize a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to the ::EVEL_JSON_BUFFER to initialise.
- * @param json Pointer to the underlying working buffer to use.
- * @param max_size Size of storage available in the JSON buffer.
- * @param throttle_spec Pointer to throttle specification. Can be NULL.
- *****************************************************************************/
-void evel_json_buffer_init(EVEL_JSON_BUFFER * jbuf,
- char * const json,
- const int max_size,
- EVEL_THROTTLE_SPEC * throttle_spec)
-{
- EVEL_ENTER();
-
- assert(jbuf != NULL);
- assert(json != NULL);
- jbuf->json = json;
- jbuf->max_size = max_size;
- jbuf->offset = 0;
- jbuf->throttle_spec = throttle_spec;
- jbuf->depth = 0;
- jbuf->checkpoint = -1;
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Encode an integer value to a JSON buffer.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param value The integer to add to it.
- *****************************************************************************/
-void evel_enc_int(EVEL_JSON_BUFFER * jbuf,
- const int value)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%d", value);
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Encode a string key and string value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param option Pointer to holder of the corresponding value to encode.
- * @return true if the key, value was added, false if it was suppressed.
- *****************************************************************************/
-bool evel_enc_kv_opt_string(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const EVEL_OPTION_STRING * const option)
-{
- bool added = false;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(option != NULL);
-
- if (option->is_set)
- {
- if ((jbuf->depth == EVEL_THROTTLE_FIELD_DEPTH) &&
- (jbuf->throttle_spec != NULL) &&
- evel_throttle_suppress_field(jbuf->throttle_spec, key))
- {
- EVEL_INFO("Suppressed: %s, %s", key, option->value);
- }
- else
- {
- EVEL_DEBUG("Encoded: %s, %s", key, option->value);
- evel_enc_kv_string(jbuf, key, option->value);
- added = true;
- }
- }
-
- EVEL_EXIT();
-
- return added;
-}
-
-/**************************************************************************//**
- * Encode a string key and string value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param value Pointer to the corresponding value to encode.
- *****************************************************************************/
-void evel_enc_kv_string(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const char * const value)
-{
- int index;
- int length;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s\"%s\": \"",
- evel_json_kv_comma(jbuf),
- key);
-
- /***************************************************************************/
- /* We need to escape quotation marks and backslashes in the value. */
- /***************************************************************************/
- length = strlen(value);
-
- for (index = 0; index < length; index++)
- {
- /*************************************************************************/
- /* Drop out if no more space. */
- /*************************************************************************/
- if (jbuf->max_size - jbuf->offset < 2)
- {
- break;
- }
-
- /*************************************************************************/
- /* Add an escape character if necessary, then write the character */
- /* itself. */
- /*************************************************************************/
- if ((value[index] == '\"') || (value[index] == '\\'))
- {
- jbuf->json[jbuf->offset] = '\\';
- jbuf->offset++;
- }
-
- jbuf->json[jbuf->offset] = value[index];
- jbuf->offset++;
- }
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "\"");
-
- EVEL_EXIT();
-}
-
-
-/**************************************************************************//**
- * Encode a string key and integer value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param option Pointer to holder of the corresponding value to encode.
- * @return true if the key, value was added, false if it was suppressed.
- *****************************************************************************/
-bool evel_enc_kv_opt_int(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const EVEL_OPTION_INT * const option)
-{
- bool added = false;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(option != NULL);
-
- if (option->is_set)
- {
- if ((jbuf->depth == EVEL_THROTTLE_FIELD_DEPTH) &&
- (jbuf->throttle_spec != NULL) &&
- evel_throttle_suppress_field(jbuf->throttle_spec, key))
- {
- EVEL_INFO("Suppressed: %s, %d", key, option->value);
- }
- else
- {
- EVEL_DEBUG("Encoded: %s, %d", key, option->value);
- evel_enc_kv_int(jbuf, key, option->value);
- added = true;
- }
- }
-
- EVEL_EXIT();
-
- return added;
-}
-
-/**************************************************************************//**
- * Encode a string key and integer value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param value The corresponding value to encode.
- *****************************************************************************/
-void evel_enc_kv_int(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const int value)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s\"%s\": %d",
- evel_json_kv_comma(jbuf),
- key,
- value);
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Encode a string key and json object value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param value The corresponding json string to encode.
- *****************************************************************************/
-void evel_enc_kv_object(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const char * value)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s\"%s\": %s",
- evel_json_kv_comma(jbuf),
- key,
- value);
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Encode a string key and double value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param option Pointer to holder of the corresponding value to encode.
- * @return true if the key, value was added, false if it was suppressed.
- *****************************************************************************/
-bool evel_enc_kv_opt_double(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const EVEL_OPTION_DOUBLE * const option)
-{
- bool added = false;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(option != NULL);
-
- if (option->is_set)
- {
- if ((jbuf->depth == EVEL_THROTTLE_FIELD_DEPTH) &&
- (jbuf->throttle_spec != NULL) &&
- evel_throttle_suppress_field(jbuf->throttle_spec, key))
- {
- EVEL_INFO("Suppressed: %s, %1f", key, option->value);
- }
- else
- {
- EVEL_DEBUG("Encoded: %s, %1f", key, option->value);
- evel_enc_kv_double(jbuf, key, option->value);
- added = true;
- }
- }
-
- EVEL_EXIT();
-
- return added;
-}
-
-/**************************************************************************//**
- * Encode a string key and double value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param value The corresponding value to encode.
- *****************************************************************************/
-void evel_enc_kv_double(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const double value)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s\"%s\": %1f",
- evel_json_kv_comma(jbuf),
- key,
- value);
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Encode a string key and unsigned long long value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param option Pointer to holder of the corresponding value to encode.
- * @return true if the key, value was added, false if it was suppressed.
- *****************************************************************************/
-bool evel_enc_kv_opt_ull(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const EVEL_OPTION_ULL * const option)
-{
- bool added = false;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(option != NULL);
-
- if (option->is_set)
- {
- if ((jbuf->depth == EVEL_THROTTLE_FIELD_DEPTH) &&
- (jbuf->throttle_spec != NULL) &&
- evel_throttle_suppress_field(jbuf->throttle_spec, key))
- {
- EVEL_INFO("Suppressed: %s, %1lu", key, option->value);
- }
- else
- {
- EVEL_DEBUG("Encoded: %s, %1lu", key, option->value);
- evel_enc_kv_ull(jbuf, key, option->value);
- added = true;
- }
- }
-
- EVEL_EXIT();
-
- return added;
-}
-
-/**************************************************************************//**
- * Encode a string key and unsigned long long value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param value The corresponding value to encode.
- *****************************************************************************/
-void evel_enc_kv_ull(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const unsigned long long value)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s\"%s\": %llu",
- evel_json_kv_comma(jbuf),
- key,
- value);
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Encode a string key and time value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param option Pointer to holder of the corresponding value to encode.
- * @return true if the key, value was added, false if it was suppressed.
- *****************************************************************************/
-bool evel_enc_kv_opt_time(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const EVEL_OPTION_TIME * const option)
-{
- bool added = false;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(option != NULL);
-
- if (option->is_set)
- {
- if ((jbuf->depth == EVEL_THROTTLE_FIELD_DEPTH) &&
- (jbuf->throttle_spec != NULL) &&
- evel_throttle_suppress_field(jbuf->throttle_spec, key))
- {
- EVEL_INFO("Suppressed time: %s", key);
- }
- else
- {
- EVEL_DEBUG("Encoded time: %s", key);
- evel_enc_kv_time(jbuf, key, &option->value);
- added = true;
- }
- }
-
- EVEL_EXIT();
-
- return added;
-}
-
-/**************************************************************************//**
- * Encode a string key and time value to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param time Pointer to the time to encode.
- *****************************************************************************/
-void evel_enc_kv_time(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const time_t * time)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
- assert(time != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s\"%s\": \"",
- evel_json_kv_comma(jbuf),
- key);
- jbuf->offset += strftime(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- EVEL_RFC2822_STRFTIME_FORMAT,
- localtime(time));
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "\"");
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Encode a key and version.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @param major_version The major version to encode.
- * @param minor_version The minor version to encode.
- *****************************************************************************/
-void evel_enc_version(EVEL_JSON_BUFFER * jbuf,
- const char * const key,
- const int major_version,
- const int minor_version)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- evel_enc_kv_int(jbuf, key, major_version);
- if (minor_version != 0)
- {
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- ".%d",
- minor_version);
- }
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Add the key and opening bracket of an optional named list to a JSON buffer.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @return true if the list was opened, false if it was suppressed.
- *****************************************************************************/
-bool evel_json_open_opt_named_list(EVEL_JSON_BUFFER * jbuf,
- const char * const key)
-{
- bool opened = false;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- if ((jbuf->depth == EVEL_THROTTLE_FIELD_DEPTH) &&
- (jbuf->throttle_spec != NULL) &&
- evel_throttle_suppress_field(jbuf->throttle_spec, key))
- {
- EVEL_INFO("Suppressed: %s", key);
- opened = false;
- }
- else
- {
- evel_json_open_named_list(jbuf, key);
- opened = true;
- }
-
- EVEL_EXIT();
-
- return opened;
-}
-
-/**************************************************************************//**
- * Add the key and opening bracket of a named list to a JSON buffer.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- *****************************************************************************/
-void evel_json_open_named_list(EVEL_JSON_BUFFER * jbuf,
- const char * const key)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s\"%s\": [",
- evel_json_kv_comma(jbuf),
- key);
- jbuf->depth++;
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Add the closing bracket of a list to a JSON buffer.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- *****************************************************************************/
-void evel_json_close_list(EVEL_JSON_BUFFER * jbuf)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "]");
- jbuf->depth--;
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Encode a list item with format and param list to a ::EVEL_JSON_BUFFER.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param format Format string in standard printf format.
- * @param ... Variable parameters for format string.
- *****************************************************************************/
-void evel_enc_list_item(EVEL_JSON_BUFFER * jbuf,
- const char * const format,
- ...)
-{
- va_list largs;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(format != NULL);
-
- /***************************************************************************/
- /* Add a comma unless we're at the start of the list. */
- /***************************************************************************/
- if (jbuf->json[jbuf->offset - 1] != '[')
- {
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- ", ");
- }
-
- va_start(largs, format);
- jbuf->offset += vsnprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- format,
- largs);
- va_end(largs);
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Add the opening bracket of an optional named object to a JSON buffer.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- *****************************************************************************/
-bool evel_json_open_opt_named_object(EVEL_JSON_BUFFER * jbuf,
- const char * const key)
-{
- bool opened = false;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- if ((jbuf->depth == EVEL_THROTTLE_FIELD_DEPTH) &&
- (jbuf->throttle_spec != NULL) &&
- evel_throttle_suppress_field(jbuf->throttle_spec, key))
- {
- EVEL_INFO("Suppressed: %s", key);
- opened = false;
- }
- else
- {
- evel_json_open_named_object(jbuf, key);
- opened = true;
- }
-
- EVEL_EXIT();
-
- return opened;
-}
-
-/**************************************************************************//**
- * Add the opening bracket of an object to a JSON buffer.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @param key Pointer to the key to encode.
- * @return true if the object was opened, false if it was suppressed.
- *****************************************************************************/
-void evel_json_open_named_object(EVEL_JSON_BUFFER * jbuf,
- const char * const key)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(key != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s\"%s\": {",
- evel_json_kv_comma(jbuf),
- key);
- jbuf->depth++;
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Add the opening bracket of an object to a JSON buffer.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- *****************************************************************************/
-void evel_json_open_object(EVEL_JSON_BUFFER * jbuf)
-{
- char * comma;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
-
- if ((jbuf->offset != 0) && (jbuf->json[jbuf->offset-1] == '}'))
- {
- comma = ", ";
- }
- else
- {
- comma = "";
- }
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "%s{",
- comma);
- jbuf->depth++;
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Add the closing bracket of an object to a JSON buffer.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- *****************************************************************************/
-void evel_json_close_object(EVEL_JSON_BUFFER * jbuf)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
-
- jbuf->offset += snprintf(jbuf->json + jbuf->offset,
- jbuf->max_size - jbuf->offset,
- "}");
- jbuf->depth--;
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Determine whether to add a comma when adding a key-value pair.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- * @returns A string containing the comma if it is required.
- *****************************************************************************/
-char * evel_json_kv_comma(EVEL_JSON_BUFFER * jbuf)
-{
- char * result;
-
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
-
- if ((jbuf->offset == 0) ||
- (jbuf->json[jbuf->offset-1] == '{') ||
- (jbuf->json[jbuf->offset-1] == '['))
- {
- result = "";
- }
- else
- {
- result = ", ";
- }
-
- EVEL_EXIT();
-
- return result;
-}
-
-/**************************************************************************//**
- * Add a checkpoint - a stake in the ground to which we can rewind.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- *****************************************************************************/
-void evel_json_checkpoint(EVEL_JSON_BUFFER * jbuf)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
-
- /***************************************************************************/
- /* Store the current offset. */
- /***************************************************************************/
- jbuf->checkpoint = jbuf->offset;
-
- EVEL_EXIT();
-}
-
-/**************************************************************************//**
- * Rewind to the latest checkoint.
- *
- * @param jbuf Pointer to working ::EVEL_JSON_BUFFER.
- *****************************************************************************/
-void evel_json_rewind(EVEL_JSON_BUFFER * jbuf)
-{
- EVEL_ENTER();
-
- /***************************************************************************/
- /* Check preconditions. */
- /***************************************************************************/
- assert(jbuf != NULL);
- assert(jbuf->checkpoint >= 0);
- assert(jbuf->checkpoint <= jbuf->offset);
-
- /***************************************************************************/
- /* Reinstate the offset from the last checkpoint. */
- /***************************************************************************/
- jbuf->offset = jbuf->checkpoint;
- jbuf->checkpoint = -1;
-
- EVEL_EXIT();
-}