Files
gimp/app/file/file-open.c
Michael Natterer b96f184b0b speak in terms of "uri", not "filename". Return the created imagefile.
2002-04-19  Michael Natterer  <mitch@gimp.org>

	* app/core/gimpdocuments.[ch] (gimp_documents_add): speak in terms
	of "uri", not "filename". Return the created imagefile.

	* app/core/gimpimagefile.[ch]: factored out private function
	gimp_imagefile_save_png_thumb() and call it from
	gimp_imagefile_create_thumbnail().
	Added public function gimp_imagefile_save_thumbnail() which takes
	an imagefile and an image.

	* app/file/file-open.c: create thumbnails for all images opened
	interactively using gimp_imagefile_save_thumbnail().

	* app/xcf/xcf-load.c (xcf_load_image): set the filename with
	gimp_image_set_filename() so it gets converted to an URI as for
	external plug-ins.
2002-04-19 12:05:47 +00:00

214 lines
5.4 KiB
C

/* The GIMP -- an image manipulation program
* Copyright (C) 1995, 1996, 1997 Spencer Kimball and Peter Mattis
* Copyright (C) 1997 Josh MacDonald
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program 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 General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#include "config.h"
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#ifdef HAVE_SYS_PARAM_H
#include <sys/param.h>
#endif
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif
#include <glib-object.h>
#ifdef G_OS_WIN32
#include <io.h>
#define R_OK 4
#define access(f,p) _access(f,p)
#endif
#include "core/core-types.h"
#include "libgimptool/gimptooltypes.h"
#include "core/gimp.h"
#include "core/gimpcoreconfig.h"
#include "core/gimpimage.h"
#include "core/gimpimagefile.h"
#include "core/gimpdocuments.h"
#include "pdb/procedural_db.h"
#include "plug-in/plug-in.h"
#include "plug-in/plug-in-proc.h"
#include "file-open.h"
#include "file-utils.h"
#include "undo.h"
#include "libgimp/gimpintl.h"
/* public functions */
GimpImage *
file_open_image (Gimp *gimp,
const gchar *uri,
const gchar *raw_filename,
const gchar *open_mode,
PlugInProcDef *file_proc,
GimpRunMode run_mode,
GimpPDBStatusType *status)
{
ProcRecord *proc;
Argument *args;
Argument *return_vals;
gint gimage_id;
gint i;
gchar *filename;
g_return_val_if_fail (GIMP_IS_GIMP (gimp), NULL);
g_return_val_if_fail (status != NULL, NULL);
*status = GIMP_PDB_CANCEL; /* inhibits error messages by caller */
if (! file_proc)
file_proc = file_utils_find_proc (gimp->load_procs, uri);
if (! file_proc)
{
/* no errors when making thumbnails */
if (run_mode == GIMP_RUN_INTERACTIVE)
g_message (_("%s failed.\n"
"%s: Unknown file type."),
open_mode, uri);
return NULL;
}
filename = g_filename_from_uri (uri, NULL, NULL);
if (filename)
{
/* check if we are opening a file */
if (g_file_test (filename, G_FILE_TEST_EXISTS))
{
if (! g_file_test (filename, G_FILE_TEST_IS_REGULAR))
{
/* no errors when making thumbnails */
if (run_mode == GIMP_RUN_INTERACTIVE)
g_message (_("%s failed.\n"
"%s is not a regular file."),
open_mode, uri);
g_free (filename);
return NULL;
}
if (access (filename, R_OK) != 0)
{
/* no errors when making thumbnails */
if (run_mode == GIMP_RUN_INTERACTIVE)
g_message (_("%s failed.\n"
"%s: %s."),
open_mode, uri, g_strerror (errno));
g_free (filename);
return NULL;
}
}
}
proc = plug_in_proc_def_get_proc (file_proc);
args = g_new0 (Argument, proc->num_args);
for (i = 0; i < proc->num_args; i++)
args[i].arg_type = proc->args[i].arg_type;
args[0].value.pdb_int = run_mode;
args[1].value.pdb_pointer = filename ? filename : (gchar *) uri;
args[2].value.pdb_pointer = (gchar *) raw_filename;
return_vals = procedural_db_execute (gimp, proc->name, args);
if (filename)
g_free (filename);
*status = return_vals[0].value.pdb_int;
gimage_id = return_vals[1].value.pdb_int;
procedural_db_destroy_args (return_vals, proc->num_values);
g_free (args);
if (*status == GIMP_PDB_SUCCESS && gimage_id != -1)
{
return gimp_image_get_by_ID (gimp, gimage_id);
}
return NULL;
}
GimpPDBStatusType
file_open_with_display (Gimp *gimp,
const gchar *uri)
{
g_return_val_if_fail (GIMP_IS_GIMP (gimp), GIMP_PDB_CALLING_ERROR);
return file_open_with_proc_and_display (gimp, uri, uri, NULL);
}
GimpPDBStatusType
file_open_with_proc_and_display (Gimp *gimp,
const gchar *uri,
const gchar *raw_filename,
PlugInProcDef *file_proc)
{
GimpImage *gimage;
GimpPDBStatusType status;
g_return_val_if_fail (GIMP_IS_GIMP (gimp), GIMP_PDB_CALLING_ERROR);
if ((gimage = file_open_image (gimp,
uri,
raw_filename,
_("Open"),
file_proc,
GIMP_RUN_INTERACTIVE,
&status)) != NULL)
{
GimpImagefile *imagefile;
/* enable & clear all undo steps */
gimp_image_undo_enable (gimage);
/* set the image to clean */
gimp_image_clean_all (gimage);
gimp_create_display (gimage->gimp, gimage, 0x0101);
g_object_unref (G_OBJECT (gimage));
imagefile = gimp_documents_add (gimp, uri);
if (gimp->config->write_thumbnails)
{
/* save a thumbnail of every opened image */
gimp_imagefile_save_thumbnail (imagefile, gimage);
}
}
return status;
}