* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
+#include "config.h"
+
+#include <config.h>
#include <unistd.h>
#include <string.h>
#include <glib/gi18n.h>
-#include <libgnomevfs/gnome-vfs-mime-utils.h>
+#include <gio/gio.h>
#include "comics-document.h"
#include "ev-document-misc.h"
#include "ev-document-thumbnails.h"
+#include "ev-file-helpers.h"
struct _ComicsDocumentClass
{
gint page);
-G_DEFINE_TYPE_WITH_CODE (
- ComicsDocument, comics_document, G_TYPE_OBJECT,
+EV_BACKEND_REGISTER_WITH_CODE (ComicsDocument, comics_document,
{
- G_IMPLEMENT_INTERFACE (EV_TYPE_DOCUMENT,
- comics_document_document_iface_init);
- G_IMPLEMENT_INTERFACE (EV_TYPE_DOCUMENT_THUMBNAILS,
- comics_document_document_thumbnails_iface_init);
+ EV_BACKEND_IMPLEMENT_INTERFACE (EV_TYPE_DOCUMENT_THUMBNAILS,
+ comics_document_document_thumbnails_iface_init);
} );
static char *
{
char *ret, *d;
- d = ret = g_malloc (strlen (s) * 2 + 3);
+ d = ret = g_malloc (strlen (s) * 4 + 3);
*d++ = '\'';
case ']':
case '*':
case '\\':
+ *d++ = '\\';
+ break;
case '\'':
+ *d++ = '\'';
*d++ = '\\';
+ *d++ = '\'';
break;
}
*d = *s;
{
ComicsDocument *comics_document = COMICS_DOCUMENT (document);
GSList *supported_extensions;
- gchar *list_files_command = NULL, *stdout, *quoted_file, *mime_type;
+ GFile *file;
+ GFileInfo *file_info;
+ gchar *list_files_command = NULL, *std_out, *quoted_file;
+ const gchar *mime_type = NULL;
gchar **cbr_files;
gboolean success;
int i, retval;
g_return_val_if_fail (comics_document->archive != NULL, FALSE);
quoted_file = g_shell_quote (comics_document->archive);
- mime_type = gnome_vfs_get_mime_type (uri);
+ file = g_file_new_for_uri (uri);
+ file_info = g_file_query_info (file,
+ G_FILE_ATTRIBUTE_STANDARD_CONTENT_TYPE,
+ 0, NULL, NULL);
+ if (file_info != NULL) {
+ mime_type = g_file_info_get_content_type (file_info);
+ }
+ g_object_unref (file);
/* FIXME, use proper cbr/cbz mime types once they're
* included in shared-mime-info */
list_files_command =
g_strdup_printf ("zipinfo -1 -- %s", quoted_file);
comics_document->regex_arg = TRUE;
+ } else if (!strcmp (mime_type, "application/x-cb7")) {
+ comics_document->extract_command =
+ g_strdup ("7zr x -so");
+ list_files_command =
+ g_strdup_printf ("7zr l -- %s", quoted_file);
+ comics_document->regex_arg = TRUE;
}
+ g_object_unref (file_info);
g_free (quoted_file);
/* Get list of files in archive */
success = g_spawn_command_line_sync (list_files_command,
- &stdout, NULL, &retval, error);
+ &std_out, NULL, &retval, error);
g_free (list_files_command);
if (!success) {
- g_free (mime_type);
return FALSE;
} else if (retval != 0) {
g_set_error (error,
EV_DOCUMENT_ERROR,
EV_DOCUMENT_ERROR_INVALID,
_("File corrupted."));
- g_free (mime_type);
return FALSE;
}
- cbr_files = g_strsplit (stdout, "\n", 0);
+ cbr_files = g_strsplit (std_out, "\n", 0);
supported_extensions = get_supported_image_extensions ();
for (i = 0; cbr_files[i] != NULL; i++) {
gchar *suffix = g_strrstr (cbr_files[i], ".");
g_free (suffix);
}
- g_free (stdout);
- g_free (mime_type);
+ g_free (std_out);
g_strfreev (cbr_files);
g_slist_foreach (supported_extensions, (GFunc) g_free, NULL);
g_slist_free (supported_extensions);
static void
comics_document_get_page_size (EvDocument *document,
- int page,
+ EvPage *page,
double *width,
double *height)
{
gint outpipe = -1;
GPid child_pid = -1;
- argv = extract_argv (document, page);
+ argv = extract_argv (document, page->index);
success = g_spawn_async_with_pipes (NULL, argv, NULL,
G_SPAWN_SEARCH_PATH | G_SPAWN_STDERR_TO_DEV_NULL,
NULL, NULL,
}
static GdkPixbuf *
-comics_document_render_pixbuf (EvDocument *document,
+comics_document_render_pixbuf (EvDocument *document,
EvRenderContext *rc)
{
GdkPixbufLoader *loader;
gint outpipe = -1;
GPid child_pid = -1;
- argv = extract_argv (document, rc->page);
+ argv = extract_argv (document, rc->page->index);
success = g_spawn_async_with_pipes (NULL, argv, NULL,
G_SPAWN_SEARCH_PATH
| G_SPAWN_STDERR_TO_DEV_NULL,
360 - rc->rotation);
g_spawn_close_pid (child_pid);
g_object_unref (loader);
+
return rotated_pixbuf;
}
+static cairo_surface_t *
+comics_document_render (EvDocument *document,
+ EvRenderContext *rc)
+{
+ GdkPixbuf *pixbuf;
+ cairo_surface_t *surface;
+
+ pixbuf = comics_document_render_pixbuf (document, rc);
+ surface = ev_document_misc_surface_from_pixbuf (pixbuf);
+ g_object_unref (pixbuf);
+
+ return surface;
+}
+
static void
render_pixbuf_size_prepared_cb (GdkPixbufLoader *loader,
gint width,
gpointer data)
{
double *scale = data;
- int w = width * (*scale);
- int h = height * (*scale);
+ int w = (width * (*scale) + 0.5);
+ int h = (height * (*scale) + 0.5);
gdk_pixbuf_loader_set_size (loader, w, h);
}
gobject_class->finalize = comics_document_finalize;
}
-static gboolean
-comics_document_can_get_text (EvDocument *document)
-{
- return FALSE;
-}
-
static EvDocumentInfo *
comics_document_get_info (EvDocument *document)
{
{
iface->load = comics_document_load;
iface->save = comics_document_save;
- iface->can_get_text = comics_document_can_get_text;
- iface->get_n_pages = comics_document_get_n_pages;
+ iface->get_n_pages = comics_document_get_n_pages;
iface->get_page_size = comics_document_get_page_size;
- iface->render_pixbuf = comics_document_render_pixbuf;
- iface->get_info = comics_document_get_info;
+ iface->render = comics_document_render;
+ iface->get_info = comics_document_get_info;
}
static void
ComicsDocument *comics_document = COMICS_DOCUMENT (document);
char **argv;
char *command_line, *quoted_archive, *quoted_filename;
+ GError *err = NULL;
quoted_archive = g_shell_quote (comics_document->archive);
if (comics_document->regex_arg) {
comics_document->extract_command,
quoted_archive,
quoted_filename);
- g_shell_parse_argv (command_line, NULL, &argv, NULL);
+ g_shell_parse_argv (command_line, NULL, &argv, &err);
+
+ if (err) {
+ g_warning ("Error %s", err->message);
+ return NULL;
+ }
+
g_free (command_line);
g_free (quoted_archive);
g_free (quoted_filename);