src/cx/json.h

changeset 1097
ef4a6cb318ec
parent 1082
46cdc8689fc4
--- a/src/cx/json.h	Sat Jan 04 18:02:08 2025 +0100
+++ b/src/cx/json.h	Sat Jan 04 18:34:13 2025 +0100
@@ -26,11 +26,11 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 /**
- * \file json.h
- * \brief Interface for parsing data from JSON files.
- * \author Mike Becker
- * \author Olaf Wintermann
- * \copyright 2-Clause BSD License
+ * @file json.h
+ * @brief Interface for parsing data from JSON files.
+ * @author Mike Becker
+ * @author Olaf Wintermann
+ * @copyright 2-Clause BSD License
  */
 
 #ifndef UCX_JSON_H
@@ -146,15 +146,15 @@
  */
 enum cx_json_literal {
     /**
-     * The \c null literal.
+     * The @c null literal.
      */
     CX_JSON_NULL,
     /**
-     * The \c true literal.
+     * The @c true literal.
      */
     CX_JSON_TRUE,
     /**
-     * The \c false literal.
+     * The @c false literal.
      */
     CX_JSON_FALSE
 };
@@ -264,7 +264,7 @@
     /**
      * The type of this value.
      *
-     * Specifies how the \c value union shall be resolved.
+     * Specifies how the @c value union shall be resolved.
      */
     CxJsonValueType type;
     /**
@@ -309,7 +309,7 @@
      */
     CxJsonTokenType tokentype;
     /**
-     * True, iff the \c content must be passed to cx_strfree().
+     * True, iff the @c content must be passed to cx_strfree().
      */
     bool allocated;
     /**
@@ -403,7 +403,7 @@
      * Not used as a status and never returned by any function.
      *
      * You can use this enumerator to check for all "good" status results
-     * by checking if the status is less than \c CX_JSON_OK.
+     * by checking if the status is less than @c CX_JSON_OK.
      *
      * A "good" status means, that you can refill data and continue parsing.
      */
@@ -457,7 +457,7 @@
      */
     bool indent_space;
     /**
-     * If \c indent_space is true, this is the number of spaces per tab.
+     * If @c indent_space is true, this is the number of spaces per tab.
      * Indentation is only used in pretty output.
      */
     uint8_t indent;
@@ -493,7 +493,7 @@
  * The write operation is not atomic in the sense that it might happen
  * that the data is only partially written when an error occurs with no
  * way to indicate how much data was written.
- * To avoid this problem, you can use a CxBuffer as \p target which is
+ * To avoid this problem, you can use a CxBuffer as @p target which is
  * unlikely to fail a write operation and either use the buffer's flush
  * feature to relay the data or use the data in the buffer manually to
  * write it to the actual target.
@@ -501,8 +501,9 @@
  * @param target the buffer or stream where to write to
  * @param value the value that shall be written
  * @param wfunc the write function to use
- * @param settings formatting settings (or \c NULL to use a compact default)
- * @return zero on success, non-zero when no or not all data could be written
+ * @param settings formatting settings (or @c NULL to use a compact default)
+ * @retval zero success
+ * @retval non-zero when no or not all data could be written
  */
 cx_attr_nonnull_arg(1, 2, 3)
 int cxJsonWrite(
@@ -560,7 +561,8 @@
  * @param json the json interface
  * @param buf the source buffer
  * @param len the length of the source buffer
- * @return zero on success, non-zero on internal allocation error
+ * @retval zero success
+ * @retval non-zero internal allocation error
  * @see cxJsonFill()
  */
 cx_attr_nonnull
@@ -600,7 +602,7 @@
 /**
  * Fills the input buffer.
  *
- * @remark The JSON interface tries to avoid copying the input data.
+ * The JSON interface tries to avoid copying the input data.
  * When you use this function and cxJsonNext() interleaving,
  * no copies are performed. However, you must not free the
  * pointer to the data in that case. When you invoke the fill
@@ -609,8 +611,9 @@
  * an allocation of a new buffer and copying the previous contents.
  *
  * @param json the json interface
- * @param buf the source string
- * @return zero on success, non-zero on internal allocation error
+ * @param str the source string
+ * @retval zero success
+ * @retval non-zero internal allocation error
  * @see cxJsonFilln()
  */
 #define cxJsonFill(json, str) _Generic((str), \
@@ -659,7 +662,9 @@
  * Creates a new (empty) JSON object.
  *
  * @param allocator the allocator to use
- * @return the new JSON object or \c NULL if allocation fails
+ * @return the new JSON object or @c NULL if allocation fails
+ * @see cxJsonObjPutObj()
+ * @see cxJsonArrAddValues()
  */
 cx_attr_nodiscard
 CxJsonValue* cxJsonCreateObj(const CxAllocator* allocator);
@@ -668,7 +673,9 @@
  * Creates a new (empty) JSON array.
  *
  * @param allocator the allocator to use
- * @return the new JSON array or \c NULL if allocation fails
+ * @return the new JSON array or @c NULL if allocation fails
+ * @see cxJsonObjPutArr()
+ * @see cxJsonArrAddValues()
  */
 cx_attr_nodiscard
 CxJsonValue* cxJsonCreateArr(const CxAllocator* allocator);
@@ -678,7 +685,7 @@
  *
  * @param allocator the allocator to use
  * @param num the numeric value
- * @return the new JSON value or \c NULL if allocation fails
+ * @return the new JSON value or @c NULL if allocation fails
  * @see cxJsonObjPutNumber()
  * @see cxJsonArrAddNumbers()
  */
@@ -690,7 +697,7 @@
  *
  * @param allocator the allocator to use
  * @param num the numeric value
- * @return the new JSON value or \c NULL if allocation fails
+ * @return the new JSON value or @c NULL if allocation fails
  * @see cxJsonObjPutInteger()
  * @see cxJsonArrAddIntegers()
  */
@@ -702,8 +709,8 @@
  *
  * @param allocator the allocator to use
  * @param str the string data
- * @return the new JSON value or \c NULL if allocation fails
- * @see cxJsonCreateCxString()
+ * @return the new JSON value or @c NULL if allocation fails
+ * @see cxJsonCreateString()
  * @see cxJsonObjPutString()
  * @see cxJsonArrAddStrings()
  */
@@ -717,8 +724,8 @@
  *
  * @param allocator the allocator to use
  * @param str the string data
- * @return the new JSON value or \c NULL if allocation fails
- * @see cxJsonCreateString()
+ * @return the new JSON value or @c NULL if allocation fails
+ * @see cxJsonCreateCxString()
  * @see cxJsonObjPutCxString()
  * @see cxJsonArrAddCxStrings()
  */
@@ -730,7 +737,7 @@
  *
  * @param allocator the allocator to use
  * @param lit the type of literal
- * @return the new JSON value or \c NULL if allocation fails
+ * @return the new JSON value or @c NULL if allocation fails
  * @see cxJsonObjPutLiteral()
  * @see cxJsonArrAddLiterals()
  */
@@ -743,7 +750,8 @@
  * @param arr the JSON array
  * @param num the array of values
  * @param count the number of elements
- * @return zero on success, non-zero on allocation failure
+ * @retval zero success
+ * @retval non-zero allocation failure
  */
 cx_attr_nonnull
 cx_attr_access_r(2, 3)
@@ -755,7 +763,8 @@
  * @param arr the JSON array
  * @param num the array of values
  * @param count the number of elements
- * @return zero on success, non-zero on allocation failure
+ * @retval zero success
+ * @retval non-zero allocation failure
  */
 cx_attr_nonnull
 cx_attr_access_r(2, 3)
@@ -769,7 +778,8 @@
  * @param arr the JSON array
  * @param str the array of strings
  * @param count the number of elements
- * @return zero on success, non-zero on allocation failure
+ * @retval zero success
+ * @retval non-zero allocation failure
  * @see cxJsonArrAddCxStrings()
  */
 cx_attr_nonnull
@@ -784,7 +794,8 @@
  * @param arr the JSON array
  * @param str the array of strings
  * @param count the number of elements
- * @return zero on success, non-zero on allocation failure
+ * @retval zero success
+ * @retval non-zero allocation failure
  * @see cxJsonArrAddStrings()
  */
 cx_attr_nonnull
@@ -797,7 +808,8 @@
  * @param arr the JSON array
  * @param lit the array of literal types
  * @param count the number of elements
- * @return zero on success, non-zero on allocation failure
+ * @retval zero success
+ * @retval non-zero allocation failure
  */
 cx_attr_nonnull
 cx_attr_access_r(2, 3)
@@ -806,13 +818,14 @@
 /**
  * Add arbitrary values to a JSON array.
  *
- * \note In contrast to all other add functions, this function adds the values
+ * @attention In contrast to all other add functions, this function adds the values
  * directly to the array instead of copying them.
  *
  * @param arr the JSON array
  * @param val the values
  * @param count the number of elements
- * @return zero on success, non-zero on allocation failure
+ * @retval zero success
+ * @retval non-zero allocation failure
  */
 cx_attr_nonnull
 cx_attr_access_r(2, 3)
@@ -823,13 +836,14 @@
  *
  * The value will be directly added and not copied.
  *
- * \note If a value with the specified \p name already exists,
+ * @note If a value with the specified @p name already exists,
  * it will be (recursively) freed with its own allocator.
  *
  * @param obj the JSON object
  * @param name the name of the value
  * @param child the value
- * @return zero on success, non-zero on allocation failure
+ * @retval zero success
+ * @retval non-zero allocation failure
  */
 cx_attr_nonnull
 int cxJsonObjPut(CxJsonValue* obj, cxstring name, CxJsonValue* child);
@@ -839,7 +853,7 @@
  *
  * @param obj the target JSON object
  * @param name the name of the new value
- * @return the new value or \c NULL if allocation fails
+ * @return the new value or @c NULL if allocation fails
  * @see cxJsonObjPut()
  * @see cxJsonCreateObj()
  */
@@ -851,7 +865,7 @@
  *
  * @param obj the target JSON object
  * @param name the name of the new value
- * @return the new value or \c NULL if allocation fails
+ * @return the new value or @c NULL if allocation fails
  * @see cxJsonObjPut()
  * @see cxJsonCreateArr()
  */
@@ -864,7 +878,7 @@
  * @param obj the target JSON object
  * @param name the name of the new value
  * @param num the numeric value
- * @return the new value or \c NULL if allocation fails
+ * @return the new value or @c NULL if allocation fails
  * @see cxJsonObjPut()
  * @see cxJsonCreateNumber()
  */
@@ -877,7 +891,7 @@
  * @param obj the target JSON object
  * @param name the name of the new value
  * @param num the numeric value
- * @return the new value or \c NULL if allocation fails
+ * @return the new value or @c NULL if allocation fails
  * @see cxJsonObjPut()
  * @see cxJsonCreateInteger()
  */
@@ -892,7 +906,7 @@
  * @param obj the target JSON object
  * @param name the name of the new value
  * @param str the string data
- * @return the new value or \c NULL if allocation fails
+ * @return the new value or @c NULL if allocation fails
  * @see cxJsonObjPut()
  * @see cxJsonCreateString()
  */
@@ -908,7 +922,7 @@
  * @param obj the target JSON object
  * @param name the name of the new value
  * @param str the string data
- * @return the new value or \c NULL if allocation fails
+ * @return the new value or @c NULL if allocation fails
  * @see cxJsonObjPut()
  * @see cxJsonCreateCxString()
  */
@@ -921,7 +935,7 @@
  * @param obj the target JSON object
  * @param name the name of the new value
  * @param lit the type of literal
- * @return the new value or \c NULL if allocation fails
+ * @return the new value or @c NULL if allocation fails
  * @see cxJsonObjPut()
  * @see cxJsonCreateLiteral()
  */
@@ -931,7 +945,7 @@
 /**
  * Recursively deallocates the memory of a JSON value.
  *
- * \remark The type of each deallocated value will be changed
+ * @remark The type of each deallocated value will be changed
  * to #CX_JSON_NOTHING and values of such type will be skipped
  * by the de-allocation. That means, this function protects
  * you from double-frees when you are accidentally freeing
@@ -944,10 +958,24 @@
 /**
  * Tries to obtain the next JSON value.
  *
+ * Before this function can be called, the input buffer needs
+ * to be filled with cxJsonFill().
+ *
+ * When this function returns #CX_JSON_INCOMPLETE_DATA, you can
+ * add the missing data with another invocation of cxJsonFill()
+ * and then repeat the call to cxJsonNext().
  *
  * @param json the json interface
  * @param value a pointer where the next value shall be stored
- * @return a status code
+ * @retval CX_JSON_NO_ERROR successfully retrieve the @p value
+ * @retval CX_JSON_NO_DATA there is no (more) data in the buffer to read from
+ * @retval CX_JSON_INCOMPLETE_DATA an incomplete value was read
+ * and more data needs to be filled
+ * @retval CX_JSON_NULL_DATA the buffer was never initialized
+ * @retval CX_JSON_BUFFER_ALLOC_FAILED allocating internal buffer space failed
+ * @retval CX_JSON_VALUE_ALLOC_FAILED allocating memory for a CxJsonValue failed
+ * @retval CX_JSON_FORMAT_ERROR_NUMBER the JSON text contains an illegally formatted number
+ * @retval CX_JSON_FORMAT_ERROR_UNEXPECTED_TOKEN JSON syntax error
  */
 cx_attr_nonnull
 cx_attr_access_w(2)
@@ -957,7 +985,8 @@
  * Checks if the specified value is a JSON object.
  *
  * @param value a pointer to the value
- * @return true if the value is a JSON object, false otherwise
+ * @retval true the value is a JSON object
+ * @retval false otherwise
  */
 cx_attr_nonnull
 static inline bool cxJsonIsObject(const CxJsonValue *value) {
@@ -968,7 +997,8 @@
  * Checks if the specified value is a JSON array.
  *
  * @param value a pointer to the value
- * @return true if the value is a JSON array, false otherwise
+ * @retval true the value is a JSON array
+ * @retval false otherwise
  */
 cx_attr_nonnull
 static inline bool cxJsonIsArray(const CxJsonValue *value) {
@@ -979,7 +1009,8 @@
  * Checks if the specified value is a string.
  *
  * @param value a pointer to the value
- * @return true if the value is a string, false otherwise
+ * @retval true the value is a string
+ * @retval false otherwise
  */
 cx_attr_nonnull
 static inline bool cxJsonIsString(const CxJsonValue *value) {
@@ -993,7 +1024,8 @@
  * integer numbers.
  *
  * @param value a pointer to the value
- * @return true if the value is a JSON number, false otherwise
+ * @retval true the value is a JSON number
+ * @retval false otherwise
  * @see cxJsonIsInteger()
  */
 cx_attr_nonnull
@@ -1005,7 +1037,8 @@
  * Checks if the specified value is an integer number.
  *
  * @param value a pointer to the value
- * @return true if the value is an integer number, false otherwise
+ * @retval true the value is an integer number
+ * @retval false otherwise
  * @see cxJsonIsNumber()
  */
 cx_attr_nonnull
@@ -1016,10 +1049,11 @@
 /**
  * Checks if the specified value is a JSON literal.
  *
- * JSON literals are \c true, \c false, and \c null.
+ * JSON literals are @c true, @c false, and @c null.
  *
  * @param value a pointer to the value
- * @return true if the value is a JSON literal, false otherwise
+ * @retval true the value is a JSON literal
+ * @retval false otherwise
  * @see cxJsonIsTrue()
  * @see cxJsonIsFalse()
  * @see cxJsonIsNull()
@@ -1033,7 +1067,8 @@
  * Checks if the specified value is a Boolean literal.
  *
  * @param value a pointer to the value
- * @return true if the value is either \c true or \c false, false otherwise
+ * @retval true the value is either @c true or @c false
+ * @retval false otherwise
  * @see cxJsonIsTrue()
  * @see cxJsonIsFalse()
  */
@@ -1043,13 +1078,14 @@
 }
 
 /**
- * Checks if the specified value is \c true.
+ * Checks if the specified value is @c true.
  *
- * \remark Be advised, that this is not the same as
- * testing \c !cxJsonIsFalse(v).
+ * @remark Be advised, that this is not the same as
+ * testing @c !cxJsonIsFalse(v).
  *
  * @param value a pointer to the value
- * @return true if the value is \c true, false otherwise
+ * @retval true the value is @c true
+ * @retval false otherwise
  * @see cxJsonIsBool()
  * @see cxJsonIsFalse()
  */
@@ -1059,13 +1095,14 @@
 }
 
 /**
- * Checks if the specified value is \c false.
+ * Checks if the specified value is @c false.
  *
- * \remark Be advised, that this is not the same as
- * testing \c !cxJsonIsTrue(v).
+ * @remark Be advised, that this is not the same as
+ * testing @c !cxJsonIsTrue(v).
  *
  * @param value a pointer to the value
- * @return true if the value is \c false, false otherwise
+ * @retval true the value is @c false
+ * @retval false otherwise
  * @see cxJsonIsBool()
  * @see cxJsonIsTrue()
  */
@@ -1075,10 +1112,11 @@
 }
 
 /**
- * Checks if the specified value is \c null.
+ * Checks if the specified value is @c null.
  *
  * @param value a pointer to the value
- * @return true if the value is \c null, false otherwise
+ * @retval true the value is @c null
+ * @retval false otherwise
  * @see cxJsonIsLiteral()
  */
 cx_attr_nonnull
@@ -1089,7 +1127,7 @@
 /**
  * Obtains a C string from the given JSON value.
  *
- * If the \p value is not a string, the behavior is undefined.
+ * If the @p value is not a string, the behavior is undefined.
  *
  * @param value the JSON value
  * @return the value represented as C string
@@ -1104,7 +1142,7 @@
 /**
  * Obtains a UCX string from the given JSON value.
  *
- * If the \p value is not a string, the behavior is undefined.
+ * If the @p value is not a string, the behavior is undefined.
  *
  * @param value the JSON value
  * @return the value represented as UCX string
@@ -1118,7 +1156,7 @@
 /**
  * Obtains a mutable UCX string from the given JSON value.
  *
- * If the \p value is not a string, the behavior is undefined.
+ * If the @p value is not a string, the behavior is undefined.
  *
  * @param value the JSON value
  * @return the value represented as mutable UCX string
@@ -1132,7 +1170,7 @@
 /**
  * Obtains a double-precision floating point value from the given JSON value.
  *
- * If the \p value is not a JSON number, the behavior is undefined.
+ * If the @p value is not a JSON number, the behavior is undefined.
  *
  * @param value the JSON value
  * @return the value represented as double
@@ -1150,7 +1188,7 @@
 /**
  * Obtains a 64-bit signed integer from the given JSON value.
  *
- * If the \p value is not a JSON number, the behavior is undefined.
+ * If the @p value is not a JSON number, the behavior is undefined.
  * If it is a JSON number, but not an integer, the value will be
  * converted to an integer, possibly losing precision.
  *
@@ -1171,8 +1209,8 @@
 /**
  * Obtains a Boolean value from the given JSON value.
  *
- * If the \p value is not a JSON literal, the behavior is undefined.
- * The \c null literal is interpreted as \c false.
+ * If the @p value is not a JSON literal, the behavior is undefined.
+ * The @c null literal is interpreted as @c false.
  *
  * @param value the JSON value
  * @return the value represented as double
@@ -1186,7 +1224,7 @@
 /**
  * Returns the size of a JSON array.
  *
- * If the \p value is not a JSON array, the behavior is undefined.
+ * If the @p value is not a JSON array, the behavior is undefined.
  *
  * @param value the JSON value
  * @return the size of the array
@@ -1200,11 +1238,11 @@
 /**
  * Returns an element from a JSON array.
  *
- * If the \p value is not a JSON array, the behavior is undefined.
+ * If the @p value is not a JSON array, the behavior is undefined.
  *
  * This function guarantees to return a value. If the index is
  * out of bounds, the returned value will be of type
- * #CX_JSON_NOTHING, but never \c NULL.
+ * #CX_JSON_NOTHING, but never @c NULL.
  *
  * @param value the JSON value
  * @param index the index in the array
@@ -1218,9 +1256,9 @@
 /**
  * Returns an iterator over the JSON array elements.
  *
- * The iterator yields values of type \c CxJsonValue* .
+ * The iterator yields values of type @c CxJsonValue* .
  *
- * If the \p value is not a JSON array, the behavior is undefined.
+ * If the @p value is not a JSON array, the behavior is undefined.
  *
  * @param value the JSON value
  * @return an iterator over the array elements
@@ -1233,10 +1271,10 @@
 /**
  * Returns an iterator over the JSON object members.
  *
- * The iterator yields values of type \c CxJsonObjValue* which
+ * The iterator yields values of type @c CxJsonObjValue* which
  * contain the name and value of the member.
  *
- * If the \p value is not a JSON object, the behavior is undefined.
+ * If the @p value is not a JSON object, the behavior is undefined.
  *
  * @param value the JSON value
  * @return an iterator over the object members
@@ -1273,11 +1311,11 @@
 /**
  * Returns a value corresponding to a key in a JSON object.
  *
- * If the \p value is not a JSON object, the behavior is undefined.
+ * If the @p value is not a JSON object, the behavior is undefined.
  *
  * This function guarantees to return a JSON value. If the
- * object does not contain \p name, the returned JSON value
- * will be of type #CX_JSON_NOTHING, but never \c NULL.
+ * object does not contain @p name, the returned JSON value
+ * will be of type #CX_JSON_NOTHING, but never @c NULL.
  *
  * @param value the JSON object
  * @param name the key to look up

mercurial