#ifdef HAVE_CONFIG_H
#include <config.h>
#endif

#include <string.h>
#include "eom-image-save-info.h"
#include "eom-image-private.h"
#include "eom-pixbuf-util.h"
#include "eom-image.h"

G_DEFINE_TYPE (EomImageSaveInfo, eom_image_save_info, G_TYPE_OBJECT)

static void
eom_image_save_info_dispose (GObject *object)
{
	EomImageSaveInfo *info = EOM_IMAGE_SAVE_INFO (object);

	if (info->file != NULL) {
		g_object_unref (info->file);
		info->file = NULL;
	}

	if (info->format != NULL) {
		g_free (info->format);
		info->format = NULL;
	}

	G_OBJECT_CLASS (eom_image_save_info_parent_class)->dispose (object);
}

static void
eom_image_save_info_init (EomImageSaveInfo *obj)
{

}

static void
eom_image_save_info_class_init (EomImageSaveInfoClass *klass)
{
	GObjectClass *object_class = (GObjectClass*) klass;

	object_class->dispose = eom_image_save_info_dispose;
}

/* is_local_uri:
 *
 * Checks if the URI points to a local file system. This tests simply
 * if the URI scheme is 'file'. This function is used to ensure that
 * we can write to the path-part of the URI with non-VFS aware
 * filesystem calls.
 */
static gboolean
is_local_file (GFile *file)
{
	char *scheme;
	gboolean ret;

	g_return_val_if_fail (file != NULL, FALSE);

	scheme = g_file_get_uri_scheme (file);

	ret = (g_ascii_strcasecmp (scheme, "file") == 0);
	g_free (scheme);
	return ret;
}

static char*
get_save_file_type_by_file (GFile *file)
{
	GdkPixbufFormat *format;
	char *type = NULL;

	format = eom_pixbuf_get_format (file);
	if (format != NULL) {
		type = gdk_pixbuf_format_get_name (format);
	}

	return type;
}

EomImageSaveInfo*
eom_image_save_info_from_image (gpointer data)
{
	EomImageSaveInfo *info = NULL;
	EomImage *image;

	image = EOM_IMAGE (data);

	g_return_val_if_fail (EOM_IS_IMAGE (image), NULL);

	info = g_object_new (EOM_TYPE_IMAGE_SAVE_INFO, NULL);

	info->file         = eom_image_get_file (image);
	info->format       = g_strdup (image->priv->file_type);
	info->exists       = g_file_query_exists (info->file, NULL);
	info->local        = is_local_file (info->file);
        info->has_metadata = eom_image_has_data (image, EOM_IMAGE_DATA_EXIF);
	info->modified     = eom_image_is_modified (image);
	info->overwrite    = FALSE;

	info->jpeg_quality = -1.0;

	return info;
}

EomImageSaveInfo*
eom_image_save_info_from_uri (const char *txt_uri, GdkPixbufFormat *format)
{
	GFile *file;
	EomImageSaveInfo *info;

	g_return_val_if_fail (txt_uri != NULL, NULL);

	file = g_file_new_for_uri (txt_uri);

	info = eom_image_save_info_from_file (file, format);

	g_object_unref (file);

	return info;
}

EomImageSaveInfo*
eom_image_save_info_from_file (GFile *file, GdkPixbufFormat *format)
{
	EomImageSaveInfo *info;

	g_return_val_if_fail (file != NULL, NULL);

	info = g_object_new (EOM_TYPE_IMAGE_SAVE_INFO, NULL);

	info->file = g_object_ref (file);
	if (format == NULL) {
		info->format = get_save_file_type_by_file (info->file);
	}
	else {
		info->format = gdk_pixbuf_format_get_name (format);
	}
	info->exists       = g_file_query_exists (file, NULL);
	info->local        = is_local_file (file);
        info->has_metadata = FALSE;
	info->modified     = FALSE;
	info->overwrite    = FALSE;

	info->jpeg_quality = -1.0;

	g_assert (info->format != NULL);

	return info;
}