mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-01-27 06:26:15 +01:00
Conditionally warn if pre-processing tools are not found
There's no need to unconditionally print an error message if xmllint or json-glib-format are not found when running glib-compile-resources is called; we only need to warn if they are not available when we need them. To avoid spamming the build logs, we can also warn once. https://bugzilla.gnome.org/show_bug.cgi?id=794285
This commit is contained in:
parent
c5c3fa83c9
commit
b4117b8d88
@ -297,64 +297,116 @@ end_element (GMarkupParseContext *context,
|
|||||||
}
|
}
|
||||||
g_strfreev (options);
|
g_strfreev (options);
|
||||||
|
|
||||||
if (xml_stripblanks && xmllint != NULL)
|
if (xml_stripblanks)
|
||||||
{
|
{
|
||||||
GSubprocess *proc;
|
/* This is not fatal: pretty-printed XML is still valid XML */
|
||||||
int fd;
|
if (xmllint == NULL)
|
||||||
|
|
||||||
fd = g_file_open_tmp ("resource-XXXXXXXX", &tmp_file, error);
|
|
||||||
if (fd < 0)
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
close (fd);
|
|
||||||
|
|
||||||
proc = g_subprocess_new (G_SUBPROCESS_FLAGS_STDOUT_SILENCE, error,
|
|
||||||
xmllint, "--nonet", "--noblanks", "--output", tmp_file, real_file, NULL);
|
|
||||||
g_free (real_file);
|
|
||||||
real_file = NULL;
|
|
||||||
|
|
||||||
if (!proc)
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
if (!g_subprocess_wait_check (proc, NULL, error))
|
|
||||||
{
|
{
|
||||||
g_object_unref (proc);
|
static gboolean xmllint_warned = FALSE;
|
||||||
goto cleanup;
|
|
||||||
|
if (!xmllint_warned)
|
||||||
|
{
|
||||||
|
/* Translators: the first %s is a gresource XML attribute,
|
||||||
|
* the second %s is an environment variable, and the third
|
||||||
|
* %s is a command line tool
|
||||||
|
*/
|
||||||
|
char *warn = g_strdup_printf (_("%s preprocessing requested, but %s is not set, and %s is not in PATH"),
|
||||||
|
"xml-stripblanks",
|
||||||
|
"XMLLINT",
|
||||||
|
"xmllint");
|
||||||
|
g_printerr ("%s\n", warn);
|
||||||
|
g_free (warn);
|
||||||
|
|
||||||
|
/* Only warn once */
|
||||||
|
xmllint_warned = TRUE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GSubprocess *proc;
|
||||||
|
int fd;
|
||||||
|
|
||||||
g_object_unref (proc);
|
fd = g_file_open_tmp ("resource-XXXXXXXX", &tmp_file, error);
|
||||||
|
if (fd < 0)
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
real_file = g_strdup (tmp_file);
|
close (fd);
|
||||||
|
|
||||||
|
proc = g_subprocess_new (G_SUBPROCESS_FLAGS_STDOUT_SILENCE, error,
|
||||||
|
xmllint, "--nonet", "--noblanks", "--output", tmp_file, real_file, NULL);
|
||||||
|
g_free (real_file);
|
||||||
|
real_file = NULL;
|
||||||
|
|
||||||
|
if (!proc)
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
if (!g_subprocess_wait_check (proc, NULL, error))
|
||||||
|
{
|
||||||
|
g_object_unref (proc);
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_object_unref (proc);
|
||||||
|
|
||||||
|
real_file = g_strdup (tmp_file);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (json_stripblanks && jsonformat != NULL)
|
if (json_stripblanks)
|
||||||
{
|
{
|
||||||
GSubprocess *proc;
|
/* As above, this is not fatal: pretty-printed JSON is still
|
||||||
int fd;
|
* valid JSON
|
||||||
|
*/
|
||||||
fd = g_file_open_tmp ("resource-XXXXXXXX", &tmp_file, error);
|
if (jsonformat == NULL)
|
||||||
if (fd < 0)
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
close (fd);
|
|
||||||
|
|
||||||
proc = g_subprocess_new (G_SUBPROCESS_FLAGS_STDOUT_SILENCE, error,
|
|
||||||
jsonformat, "--output", tmp_file, real_file, NULL);
|
|
||||||
g_free (real_file);
|
|
||||||
real_file = NULL;
|
|
||||||
|
|
||||||
if (!proc)
|
|
||||||
goto cleanup;
|
|
||||||
|
|
||||||
if (!g_subprocess_wait_check (proc, NULL, error))
|
|
||||||
{
|
{
|
||||||
g_object_unref (proc);
|
static gboolean jsonformat_warned = FALSE;
|
||||||
goto cleanup;
|
|
||||||
|
if (!jsonformat_warned)
|
||||||
|
{
|
||||||
|
/* Translators: the first %s is a gresource XML attribute,
|
||||||
|
* the second %s is an environment variable, and the third
|
||||||
|
* %s is a command line tool
|
||||||
|
*/
|
||||||
|
char *warn = g_strdup_printf (_("%s preprocessing requested, but %s is not set, and %s is not in PATH"),
|
||||||
|
"json-stripblanks",
|
||||||
|
"JSON_GLIB_FORMAT",
|
||||||
|
"json-glib-format");
|
||||||
|
g_printerr ("%s\n", warn);
|
||||||
|
g_free (warn);
|
||||||
|
|
||||||
|
/* Only warn once */
|
||||||
|
jsonformat_warned = TRUE;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
GSubprocess *proc;
|
||||||
|
int fd;
|
||||||
|
|
||||||
g_object_unref (proc);
|
fd = g_file_open_tmp ("resource-XXXXXXXX", &tmp_file, error);
|
||||||
|
if (fd < 0)
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
real_file = g_strdup (tmp_file);
|
close (fd);
|
||||||
|
|
||||||
|
proc = g_subprocess_new (G_SUBPROCESS_FLAGS_STDOUT_SILENCE, error,
|
||||||
|
jsonformat, "--output", tmp_file, real_file, NULL);
|
||||||
|
g_free (real_file);
|
||||||
|
real_file = NULL;
|
||||||
|
|
||||||
|
if (!proc)
|
||||||
|
goto cleanup;
|
||||||
|
|
||||||
|
if (!g_subprocess_wait_check (proc, NULL, error))
|
||||||
|
{
|
||||||
|
g_object_unref (proc);
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
|
g_object_unref (proc);
|
||||||
|
|
||||||
|
real_file = g_strdup (tmp_file);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (to_pixdata)
|
if (to_pixdata)
|
||||||
@ -362,11 +414,20 @@ end_element (GMarkupParseContext *context,
|
|||||||
GSubprocess *proc;
|
GSubprocess *proc;
|
||||||
int fd;
|
int fd;
|
||||||
|
|
||||||
|
/* This is a fatal error: if to-pixdata is used it means that
|
||||||
|
* the code loading the GResource expects a specific data format
|
||||||
|
*/
|
||||||
if (gdk_pixbuf_pixdata == NULL)
|
if (gdk_pixbuf_pixdata == NULL)
|
||||||
{
|
{
|
||||||
g_set_error_literal (error, G_IO_ERROR, G_IO_ERROR_FAILED,
|
/* Translators: the first %s is a gresource XML attribute,
|
||||||
"to-pixbuf preprocessing requested but GDK_PIXBUF_PIXDATA "
|
* the second %s is an environment variable, and the third
|
||||||
"not set and gdk-pixbuf-pixdata not found in path");
|
* %s is a command line tool
|
||||||
|
*/
|
||||||
|
g_set_error (error, G_IO_ERROR, G_IO_ERROR_FAILED,
|
||||||
|
_("%s preprocessing requested, but %s is not set, and %s is not in PATH"),
|
||||||
|
"to-pixdata",
|
||||||
|
"GDK_PIXBUF_PIXDATA",
|
||||||
|
"gdk-pixbuf-pixdata");
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -744,14 +805,10 @@ main (int argc, char **argv)
|
|||||||
xmllint = g_strdup (g_getenv ("XMLLINT"));
|
xmllint = g_strdup (g_getenv ("XMLLINT"));
|
||||||
if (xmllint == NULL)
|
if (xmllint == NULL)
|
||||||
xmllint = g_find_program_in_path ("xmllint");
|
xmllint = g_find_program_in_path ("xmllint");
|
||||||
if (xmllint == NULL)
|
|
||||||
g_printerr ("XMLLINT not set and xmllint not found in path; skipping xml preprocessing.\n");
|
|
||||||
|
|
||||||
jsonformat = g_strdup (g_getenv ("JSON_GLIB_FORMAT"));
|
jsonformat = g_strdup (g_getenv ("JSON_GLIB_FORMAT"));
|
||||||
if (jsonformat == NULL)
|
if (jsonformat == NULL)
|
||||||
jsonformat = g_find_program_in_path ("json-glib-format");
|
jsonformat = g_find_program_in_path ("json-glib-format");
|
||||||
if (jsonformat == NULL)
|
|
||||||
g_printerr ("JSON_GLIB_FORMAT not set and json-glib-format not found in path; skipping json pre-processing.\n");
|
|
||||||
|
|
||||||
gdk_pixbuf_pixdata = g_strdup (g_getenv ("GDK_PIXBUF_PIXDATA"));
|
gdk_pixbuf_pixdata = g_strdup (g_getenv ("GDK_PIXBUF_PIXDATA"));
|
||||||
if (gdk_pixbuf_pixdata == NULL)
|
if (gdk_pixbuf_pixdata == NULL)
|
||||||
|
Loading…
Reference in New Issue
Block a user