about summary refs log tree commit diff
path: root/third_party/git/json-writer.h
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/git/json-writer.h')
-rw-r--r--third_party/git/json-writer.h107
1 files changed, 0 insertions, 107 deletions
diff --git a/third_party/git/json-writer.h b/third_party/git/json-writer.h
deleted file mode 100644
index 83906b09c1..0000000000
--- a/third_party/git/json-writer.h
+++ /dev/null
@@ -1,107 +0,0 @@
-#ifndef JSON_WRITER_H
-#define JSON_WRITER_H
-
-/*
- * JSON data structures are defined at:
- * [1] http://www.ietf.org/rfc/rfc7159.txt
- * [2] http://json.org/
- *
- * The JSON-writer API allows one to build JSON data structures using a
- * simple wrapper around a "struct strbuf" buffer.  It is intended as a
- * simple API to build output strings; it is not intended to be a general
- * object model for JSON data.  In particular, it does not re-order keys
- * in an object (dictionary), it does not de-dup keys in an object, and
- * it does not allow lookup or parsing of JSON data.
- *
- * All string values (both keys and string r-values) are properly quoted
- * and escaped if they contain special characters.
- *
- * These routines create compact JSON data (with no unnecessary whitespace,
- * newlines, or indenting).  If you get an unexpected response, verify
- * that you're not expecting a pretty JSON string.
- *
- * Both "JSON objects" (aka sets of k/v pairs) and "JSON array" can be
- * constructed using a 'begin append* end' model.
- *
- * Nested objects and arrays can either be constructed bottom up (by
- * creating sub object/arrays first and appending them to the super
- * object/array) -or- by building them inline in one pass.  This is a
- * personal style and/or data shape choice.
- *
- * See t/helper/test-json-writer.c for various usage examples.
- *
- * LIMITATIONS:
- * ============
- *
- * The JSON specification [1,2] defines string values as Unicode data
- * and probably UTF-8 encoded.  The current json-writer API does not
- * enforce this and will write any string as received.  However, it will
- * properly quote and backslash-escape them as necessary.  It is up to
- * the caller to UTF-8 encode their strings *before* passing them to this
- * API.  This layer should not have to try to guess the encoding or locale
- * of the given strings.
- */
-
-#include "strbuf.h"
-
-struct json_writer
-{
-	/*
-	 * Buffer of the in-progress JSON currently being composed.
-	 */
-	struct strbuf json;
-
-	/*
-	 * Simple stack of the currently open array and object forms.
-	 * This is a string of '{' and '[' characters indicating the
-	 * currently unterminated forms.  This is used to ensure the
-	 * properly closing character is used when popping a level and
-	 * to know when the JSON is completely closed.
-	 */
-	struct strbuf open_stack;
-
-	unsigned int need_comma:1;
-	unsigned int pretty:1;
-};
-
-#define JSON_WRITER_INIT { STRBUF_INIT, STRBUF_INIT, 0, 0 }
-
-void jw_init(struct json_writer *jw);
-void jw_release(struct json_writer *jw);
-
-void jw_object_begin(struct json_writer *jw, int pretty);
-void jw_array_begin(struct json_writer *jw, int pretty);
-
-void jw_object_string(struct json_writer *jw, const char *key,
-		      const char *value);
-void jw_object_intmax(struct json_writer *jw, const char *key, intmax_t value);
-void jw_object_double(struct json_writer *jw, const char *key, int precision,
-		      double value);
-void jw_object_true(struct json_writer *jw, const char *key);
-void jw_object_false(struct json_writer *jw, const char *key);
-void jw_object_bool(struct json_writer *jw, const char *key, int value);
-void jw_object_null(struct json_writer *jw, const char *key);
-void jw_object_sub_jw(struct json_writer *jw, const char *key,
-		      const struct json_writer *value);
-
-void jw_object_inline_begin_object(struct json_writer *jw, const char *key);
-void jw_object_inline_begin_array(struct json_writer *jw, const char *key);
-
-void jw_array_string(struct json_writer *jw, const char *value);
-void jw_array_intmax(struct json_writer *jw, intmax_t value);
-void jw_array_double(struct json_writer *jw, int precision, double value);
-void jw_array_true(struct json_writer *jw);
-void jw_array_false(struct json_writer *jw);
-void jw_array_bool(struct json_writer *jw, int value);
-void jw_array_null(struct json_writer *jw);
-void jw_array_sub_jw(struct json_writer *jw, const struct json_writer *value);
-void jw_array_argc_argv(struct json_writer *jw, int argc, const char **argv);
-void jw_array_argv(struct json_writer *jw, const char **argv);
-
-void jw_array_inline_begin_object(struct json_writer *jw);
-void jw_array_inline_begin_array(struct json_writer *jw);
-
-int jw_is_terminated(const struct json_writer *jw);
-void jw_end(struct json_writer *jw);
-
-#endif /* JSON_WRITER_H */