be53750aa3
Signed-off-by: Oosman Saeed <oossaeed@amd.com>
[ROCm/amdsmi commit: 90f4b8c43d]
165 línte
4.4 KiB
C
165 línte
4.4 KiB
C
/*
|
|
* Copyright (c) Advanced Micro Devices, Inc. All rights reserved.
|
|
*
|
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
* of this software and associated documentation files (the "Software"), to deal
|
|
* in the Software without restriction, including without limitation the rights
|
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
* copies of the Software, and to permit persons to whom the Software is
|
|
* furnished to do so, subject to the following conditions:
|
|
*
|
|
* The above copyright notice and this permission notice shall be included in
|
|
* all copies or substantial portions of the Software.
|
|
*
|
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
* THE SOFTWARE.
|
|
*/
|
|
|
|
#ifndef JSON_UTIL_H
|
|
#define JSON_UTIL_H
|
|
|
|
#include <stdbool.h>
|
|
#include <stddef.h>
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/**
|
|
* @brief JSON value types enumeration
|
|
*/
|
|
typedef enum { JSON_NULL, JSON_BOOL, JSON_NUMBER, JSON_STRING, JSON_OBJECT, JSON_ARRAY } JsonType;
|
|
|
|
typedef struct JsonValue JsonValue;
|
|
typedef struct JsonPair JsonPair;
|
|
|
|
/**
|
|
* @brief JSON key-value pair structure for objects
|
|
*/
|
|
struct JsonPair {
|
|
char *key;
|
|
JsonValue *value;
|
|
JsonPair *next;
|
|
};
|
|
|
|
/**
|
|
* @brief JSON value structure
|
|
*/
|
|
struct JsonValue {
|
|
JsonType type;
|
|
union {
|
|
bool boolean;
|
|
double number;
|
|
char *string;
|
|
JsonPair *object; // Linked list of key-value pairs
|
|
struct {
|
|
JsonValue **items;
|
|
size_t count;
|
|
size_t capacity;
|
|
} array;
|
|
} data;
|
|
};
|
|
|
|
/**
|
|
* @brief Create a null JSON value
|
|
* @return Pointer to new JsonValue or NULL on failure
|
|
*/
|
|
JsonValue *json_create_null(void);
|
|
|
|
/**
|
|
* @brief Create a boolean JSON value
|
|
* @param b Boolean value
|
|
* @return Pointer to new JsonValue or NULL on failure
|
|
*/
|
|
JsonValue *json_create_bool(bool b);
|
|
|
|
/**
|
|
* @brief Create a number JSON value
|
|
* @param num Numeric value
|
|
* @return Pointer to new JsonValue or NULL on failure
|
|
*/
|
|
JsonValue *json_create_number(double num);
|
|
|
|
/**
|
|
* @brief Create a string JSON value
|
|
* @param str String value (will be copied)
|
|
* @return Pointer to new JsonValue or NULL on failure
|
|
*/
|
|
JsonValue *json_create_string(const char *str);
|
|
|
|
/**
|
|
* @brief Create an empty JSON object
|
|
* @return Pointer to new JsonValue or NULL on failure
|
|
*/
|
|
JsonValue *json_create_object(void);
|
|
|
|
/**
|
|
* @brief Create an empty JSON array
|
|
* @return Pointer to new JsonValue or NULL on failure
|
|
*/
|
|
JsonValue *json_create_array(void);
|
|
|
|
/**
|
|
* @brief Add a key-value pair to a JSON object
|
|
* @param obj JSON object to modify
|
|
* @param key Key string (will be copied)
|
|
* @param value Value to add
|
|
*/
|
|
void json_object_set(JsonValue *obj, const char *key, JsonValue *value);
|
|
|
|
/**
|
|
* @brief Get a value by key from a JSON object
|
|
* @param obj JSON object to search
|
|
* @param key Key to search for
|
|
* @return Pointer to JsonValue or NULL if not found
|
|
*/
|
|
JsonValue *json_object_get(JsonValue *obj, const char *key);
|
|
|
|
/**
|
|
* @brief Check if a key exists in a JSON object
|
|
* @param obj JSON object to check
|
|
* @param key Key to check for
|
|
* @return true if key exists, false otherwise
|
|
*/
|
|
bool json_object_has_key(JsonValue *obj, const char *key);
|
|
|
|
/**
|
|
* @brief Add a value to a JSON array
|
|
* @param arr JSON array to modify
|
|
* @param value Value to add
|
|
* @return true on success, false on failure
|
|
*/
|
|
bool json_array_push(JsonValue *arr, JsonValue *value);
|
|
|
|
/**
|
|
* @brief Get a value by index from a JSON array
|
|
* @param arr JSON array to access
|
|
* @param index Array index
|
|
* @return Pointer to JsonValue or NULL if index out of bounds
|
|
*/
|
|
JsonValue *json_array_get(JsonValue *arr, size_t index);
|
|
|
|
/**
|
|
* @brief Get the size of a JSON array
|
|
* @param arr JSON array
|
|
* @return Number of elements in array, or 0 if not an array
|
|
*/
|
|
size_t json_array_size(JsonValue *arr);
|
|
|
|
/**
|
|
* @brief Free a JSON value and all its contents
|
|
* @param val JSON value to free
|
|
*/
|
|
void json_free(JsonValue *val);
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* JSON_UTIL_H */
|