Add a command line option to list supported types
Make it work without a display connection.
This commit is contained in:
parent
47293cfc10
commit
06af1a3cc9
22
fastiv-io.c
22
fastiv-io.c
|
@ -78,6 +78,28 @@ const char *fastiv_io_supported_media_types[] = {
|
||||||
NULL
|
NULL
|
||||||
};
|
};
|
||||||
|
|
||||||
|
char **
|
||||||
|
fastiv_io_all_supported_media_types(void)
|
||||||
|
{
|
||||||
|
GPtrArray *types = g_ptr_array_new();
|
||||||
|
for (const char **p = fastiv_io_supported_media_types; *p; p++)
|
||||||
|
g_ptr_array_add(types, g_strdup(*p));
|
||||||
|
|
||||||
|
#ifdef HAVE_GDKPIXBUF
|
||||||
|
GSList *formats = gdk_pixbuf_get_formats();
|
||||||
|
for (GSList *iter = formats; iter; iter = iter->next) {
|
||||||
|
gchar **subtypes = gdk_pixbuf_format_get_mime_types(iter->data);
|
||||||
|
for (gchar **p = subtypes; *p; p++)
|
||||||
|
g_ptr_array_add(types, *p);
|
||||||
|
g_free(subtypes);
|
||||||
|
}
|
||||||
|
g_slist_free(formats);
|
||||||
|
#endif // HAVE_GDKPIXBUF
|
||||||
|
|
||||||
|
g_ptr_array_add(types, NULL);
|
||||||
|
return (char **) g_ptr_array_free(types, FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
// - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
|
||||||
|
|
||||||
#define FASTIV_IO_ERROR fastiv_io_error_quark()
|
#define FASTIV_IO_ERROR fastiv_io_error_quark()
|
||||||
|
|
|
@ -22,6 +22,8 @@
|
||||||
|
|
||||||
extern const char *fastiv_io_supported_media_types[];
|
extern const char *fastiv_io_supported_media_types[];
|
||||||
|
|
||||||
|
char **fastiv_io_all_supported_media_types(void);
|
||||||
|
|
||||||
cairo_surface_t *fastiv_io_open(const gchar *path, GError **error);
|
cairo_surface_t *fastiv_io_open(const gchar *path, GError **error);
|
||||||
cairo_surface_t *fastiv_io_open_from_data(
|
cairo_surface_t *fastiv_io_open_from_data(
|
||||||
const char *data, size_t len, const gchar *path, GError **error);
|
const char *data, size_t len, const gchar *path, GError **error);
|
||||||
|
|
25
fastiv.c
25
fastiv.c
|
@ -396,24 +396,33 @@ on_button_press_browser(G_GNUC_UNUSED GtkWidget *widget, GdkEventButton *event)
|
||||||
int
|
int
|
||||||
main(int argc, char *argv[])
|
main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
gboolean show_version = FALSE;
|
gboolean show_version = FALSE, show_supported_media_types = FALSE;
|
||||||
gchar **path_args = NULL;
|
gchar **path_args = NULL;
|
||||||
const GOptionEntry options[] = {
|
const GOptionEntry options[] = {
|
||||||
{G_OPTION_REMAINING, 0, 0, G_OPTION_ARG_FILENAME_ARRAY, &path_args,
|
{G_OPTION_REMAINING, 0, 0, G_OPTION_ARG_FILENAME_ARRAY, &path_args,
|
||||||
NULL, "[FILE | DIRECTORY]"},
|
NULL, "[FILE | DIRECTORY]"},
|
||||||
|
{"list-supported-media-types", 0, G_OPTION_FLAG_IN_MAIN,
|
||||||
|
G_OPTION_ARG_NONE, &show_supported_media_types,
|
||||||
|
"Output supported media types and exit", NULL},
|
||||||
{"version", 'V', G_OPTION_FLAG_IN_MAIN, G_OPTION_ARG_NONE,
|
{"version", 'V', G_OPTION_FLAG_IN_MAIN, G_OPTION_ARG_NONE,
|
||||||
&show_version, "output version information and exit", NULL},
|
&show_version, "Output version information and exit", NULL},
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
GError *error = NULL;
|
GError *error = NULL;
|
||||||
if (!gtk_init_with_args(
|
gboolean initialized = gtk_init_with_args(
|
||||||
&argc, &argv, " - fast image viewer", options, NULL, &error))
|
&argc, &argv, " - fast image viewer", options, NULL, &error);
|
||||||
exit_fatal("%s", error->message);
|
|
||||||
if (show_version) {
|
if (show_version) {
|
||||||
printf(PROJECT_NAME " " PROJECT_VERSION "\n");
|
printf(PROJECT_NAME " " PROJECT_VERSION "\n");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
if (show_supported_media_types) {
|
||||||
|
for (char **types = fastiv_io_all_supported_media_types(); *types; )
|
||||||
|
g_print("%s\n", *types++);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
if (!initialized)
|
||||||
|
exit_fatal("%s", error->message);
|
||||||
|
|
||||||
// NOTE: Firefox and Eye of GNOME both interpret multiple arguments
|
// NOTE: Firefox and Eye of GNOME both interpret multiple arguments
|
||||||
// in a special way. This is problematic, because one-element lists
|
// in a special way. This is problematic, because one-element lists
|
||||||
|
@ -506,8 +515,10 @@ main(int argc, char *argv[])
|
||||||
G_CALLBACK(on_key_press), NULL);
|
G_CALLBACK(on_key_press), NULL);
|
||||||
gtk_container_add(GTK_CONTAINER(g.window), g.stack);
|
gtk_container_add(GTK_CONTAINER(g.window), g.stack);
|
||||||
|
|
||||||
// TODO(p): Also milk gdk-pixbuf, if linked in, needs to be done in runtime.
|
char **types = fastiv_io_all_supported_media_types();
|
||||||
g.supported_globs = extract_mime_globs(fastiv_io_supported_media_types);
|
g.supported_globs = extract_mime_globs((const char **) types);
|
||||||
|
g_strfreev(types);
|
||||||
|
|
||||||
g.files = g_ptr_array_new_full(16, g_free);
|
g.files = g_ptr_array_new_full(16, g_free);
|
||||||
gchar *cwd = g_get_current_dir();
|
gchar *cwd = g_get_current_dir();
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue