Same semantics as select_member(), useful for values where only a known set of values is accepted, like enumerations encoded as strings.
100 lines
5.1 KiB
C
100 lines
5.1 KiB
C
/*
|
|
* Copyright © 2021 Benjamin Otte
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
* License as published by the Free Software Foundation; either
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
*
|
|
* This library is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
|
*
|
|
* Authors: Benjamin Otte <otte@gnome.org>
|
|
*/
|
|
|
|
|
|
#ifndef __GTK_JSON_PARSER_H__
|
|
#define __GTK_JSON_PARSER_H__
|
|
|
|
#include <glib.h>
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
typedef enum {
|
|
GTK_JSON_NONE,
|
|
GTK_JSON_NULL,
|
|
GTK_JSON_BOOLEAN,
|
|
GTK_JSON_NUMBER,
|
|
GTK_JSON_STRING,
|
|
GTK_JSON_OBJECT,
|
|
GTK_JSON_ARRAY
|
|
} GtkJsonNode;
|
|
|
|
typedef enum {
|
|
GTK_JSON_ERROR_FAILED,
|
|
GTK_JSON_ERROR_SYNTAX,
|
|
GTK_JSON_ERROR_TYPE,
|
|
GTK_JSON_ERROR_VALUE,
|
|
GTK_JSON_ERROR_SCHEMA,
|
|
} GtkJsonError;
|
|
|
|
typedef struct _GtkJsonParser GtkJsonParser;
|
|
|
|
#define GTK_JSON_ERROR (gtk_json_error_quark ())
|
|
GQuark gtk_json_error_quark (void);
|
|
|
|
GtkJsonParser * gtk_json_parser_new_for_bytes (GBytes *bytes);
|
|
GtkJsonParser * gtk_json_parser_new_for_string (const char *string,
|
|
gssize size);
|
|
|
|
void gtk_json_parser_free (GtkJsonParser *self);
|
|
|
|
gboolean gtk_json_parser_next (GtkJsonParser *self);
|
|
void gtk_json_parser_rewind (GtkJsonParser *self);
|
|
gsize gtk_json_parser_get_depth (GtkJsonParser *self);
|
|
GtkJsonNode gtk_json_parser_get_node (GtkJsonParser *self);
|
|
char * gtk_json_parser_get_member_name (GtkJsonParser *self);
|
|
gboolean gtk_json_parser_has_member (GtkJsonParser *self,
|
|
const char *name);
|
|
gboolean gtk_json_parser_find_member (GtkJsonParser *self,
|
|
const char *name);
|
|
gssize gtk_json_parser_select_member (GtkJsonParser *self,
|
|
const char * const *options);
|
|
|
|
gboolean gtk_json_parser_get_boolean (GtkJsonParser *self);
|
|
double gtk_json_parser_get_number (GtkJsonParser *self);
|
|
int gtk_json_parser_get_int (GtkJsonParser *self);
|
|
guint gtk_json_parser_get_uint (GtkJsonParser *self);
|
|
char * gtk_json_parser_get_string (GtkJsonParser *self);
|
|
gssize gtk_json_parser_select_string (GtkJsonParser *self,
|
|
const char * const *options);
|
|
|
|
gboolean gtk_json_parser_start_object (GtkJsonParser *self);
|
|
gboolean gtk_json_parser_start_array (GtkJsonParser *self);
|
|
gboolean gtk_json_parser_end (GtkJsonParser *self);
|
|
|
|
const GError * gtk_json_parser_get_error (GtkJsonParser *self) G_GNUC_PURE;
|
|
void gtk_json_parser_get_error_offset (GtkJsonParser *self,
|
|
gsize *start,
|
|
gsize *end);
|
|
void gtk_json_parser_get_error_location (GtkJsonParser *self,
|
|
gsize *start_line,
|
|
gsize *start_line_bytes,
|
|
gsize *end_line,
|
|
gsize *end_line_bytes);
|
|
void gtk_json_parser_value_error (GtkJsonParser *self,
|
|
const char *format,
|
|
...) G_GNUC_PRINTF(2, 3);
|
|
void gtk_json_parser_schema_error (GtkJsonParser *self,
|
|
const char *format,
|
|
...) G_GNUC_PRINTF(2, 3);
|
|
|
|
G_END_DECLS
|
|
|
|
#endif /* __GTK_JSON_PARSER_H__ */
|