/* json-glib-validate - Checks JSON data for errors
*
* This file is part of JSON-GLib
*
* Copyright © 2013 Emmanuele Bassi
*
* 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 .
*
* Author:
* Emmanuele Bassi
*/
#include "config.h"
#ifdef HAVE_UNISTD_H
#include
#endif
#include
#include
#include
#include
#include
#include
#include
static char **files = NULL;
static GOptionEntry entries[] = {
{ G_OPTION_REMAINING, 0, 0, G_OPTION_ARG_FILENAME_ARRAY, &files, NULL, NULL },
{ NULL },
};
static gboolean
validate (JsonParser *parser,
GFile *file)
{
GBytes *bytes;
GError *error;
gboolean res = TRUE;
error = NULL;
bytes = g_file_load_bytes (file, NULL, NULL, &error);
if (bytes == NULL)
{
/* Translators: the first %s is the program name, the second one
* is the URI of the file, the third is the error message.
*/
g_printerr (_("%s: %s: error reading file: %s\n"),
g_get_prgname (), g_file_get_uri (file), error->message);
g_error_free (error);
return FALSE;
}
res = json_parser_load_from_data (parser,
g_bytes_get_data (bytes, NULL),
g_bytes_get_size (bytes),
&error);
if (!res)
{
/* Translators: the first %s is the program name, the second one
* is the URI of the file, the third is the error message.
*/
g_printerr (_("%s: %s: error parsing file: %s\n"),
g_get_prgname (), g_file_get_uri (file), error->message);
g_clear_error (&error);
}
g_bytes_unref (bytes);
return res;
}
int
main (int argc,
char *argv[])
{
GOptionContext *context = NULL;
GError *error = NULL;
const char *description;
const char *summary;
gchar *param;
JsonParser *parser;
gboolean res;
int i;
setlocale (LC_ALL, "");
bindtextdomain (GETTEXT_PACKAGE, JSON_LOCALEDIR);
bind_textdomain_codeset (GETTEXT_PACKAGE, "UTF-8");
textdomain (GETTEXT_PACKAGE);
param = g_strdup_printf (("%s..."), _("FILE"));
/* Translators: this message will appear after the usage string */
/* and before the list of options. */
summary = _("Validate JSON files.");
description = _("json-glib-validate validates JSON data at the given URI.");
context = g_option_context_new (param);
g_option_context_set_summary (context, summary);
g_option_context_set_description (context, description);
g_option_context_add_main_entries (context, entries, GETTEXT_PACKAGE);
g_option_context_parse (context, &argc, &argv, &error);
g_option_context_free (context);
g_free (param);
if (error != NULL)
{
/* Translators: the %s is the program name. This error message
* means the user is calling json-glib-validate without any
* argument.
*/
g_printerr (_("Error parsing commandline options: %s\n"), error->message);
g_printerr ("\n");
g_printerr (_("Try “%s --help” for more information."), g_get_prgname ());
g_printerr ("\n");
g_error_free (error);
return 1;
}
if (files == NULL)
{
/* Translators: the %s is the program name. This error message
* means the user is calling json-glib-validate without any
* argument.
*/
g_printerr (_("%s: missing files"), g_get_prgname ());
g_printerr ("\n");
g_printerr (_("Try “%s --help” for more information."), g_get_prgname ());
g_printerr ("\n");
return 1;
}
parser = json_parser_new ();
res = TRUE;
i = 0;
do
{
GFile *file = g_file_new_for_commandline_arg (files[i]);
res = validate (parser, file) && res;
g_object_unref (file);
}
while (files[++i] != NULL);
g_object_unref (parser);
return res ? EXIT_SUCCESS : EXIT_FAILURE;
}