
2000-02-15 Tor Lillqvist <tml@iki.fi> * libgimp/gimp.def * libgimp/gimpui.def * libgimp/makefile.{cygwin,msc} * app/makefile.{cygwin,msc} * plug-ins/makefile.{cygwin,msc}: Updates. * app/datafiles.c (is_script): New Win32-only function, which tests if a file's extension matches one of the extensions in the PATHEXT environment variable (which the cmd.exe command interpreter also uses). This is to avoid starting applications associated with any random data file the user might have dropped in the plug-ins folder, while still supporting plug-ins written in scripting languages. * app/gimpparasite.c (gimp_parasiterc_save): (Win32:) Cannot rename to an existing file. * plug-ins/Lighting/lighting_image.c * plug-ins/Lighting/lighting_share.c * plug-ins/MapObject/mapobject_preview.c * plug-ins/MapObject/mapobject_shade.c: Use G_PI. * plug-ins/common/gz.c: #ifdef G_OS_WIN32 was used before its potential definition via glib.h. * plug-ins/common/jpeg.c: Also recognize Exif files, which are typically produced by digital cameras. The usually have a .jpg file name extension, and would thus already match this plug-in, but add the magic string just in case. They are loaded just fine by libjpeg even if they don't have the JFIF signature. * plug-ins/common/tiff.c: Set TIFF warning and error handler, so we get to pass libtiff's messages through the normal channels.
226 lines
4.8 KiB
C
226 lines
4.8 KiB
C
/* The GIMP -- an image manipulation program
|
|
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
|
|
*
|
|
* Datafiles module copyight (C) 1996 Federico Mena Quintero
|
|
* federico@nuclecu.unam.mx
|
|
*
|
|
* 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 <glib.h>
|
|
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
#include <sys/types.h>
|
|
#include <sys/stat.h>
|
|
#ifdef HAVE_UNISTD_H
|
|
#include <unistd.h>
|
|
#endif
|
|
#ifdef HAVE_DIRENT_H
|
|
#include <dirent.h>
|
|
#endif
|
|
|
|
#ifdef G_OS_WIN32
|
|
#ifndef S_ISDIR
|
|
#define S_ISDIR(m) (((m) & _S_IFMT) == _S_IFDIR)
|
|
#define S_ISREG(m) (((m) & _S_IFMT) == _S_IFREG)
|
|
#endif
|
|
#ifndef S_IXUSR
|
|
#define S_IXUSR _S_IEXEC
|
|
#endif
|
|
#endif /* G_OS_WIN32 */
|
|
|
|
#include "datafiles.h"
|
|
#include "errors.h"
|
|
#include "general.h"
|
|
#include "gimprc.h"
|
|
|
|
|
|
/***** Functions *****/
|
|
|
|
/*****/
|
|
|
|
static int filestat_valid = 0;
|
|
static struct stat filestat;
|
|
|
|
#ifdef G_OS_WIN32
|
|
/*
|
|
* On Windows there is no concept like the Unix executable flag. There
|
|
* There is a weak emulation provided by the MS C Runtime using file
|
|
* extensions (com, exe, cmd, bat). This needs to be extended to treat
|
|
* scripts (Python, Perl, ...) as executables, too. We use the PATHEXT
|
|
* variable, which is also used by cmd.exe.
|
|
*/
|
|
gboolean
|
|
is_script (const gchar* filename)
|
|
{
|
|
const gchar *ext = strrchr (filename, '.');
|
|
gchar *pathext;
|
|
static gchar **exts = NULL;
|
|
gint i;
|
|
|
|
if (exts == NULL)
|
|
{
|
|
pathext = g_getenv ("PATHEXT");
|
|
if (pathext != NULL)
|
|
{
|
|
exts = g_strsplit (pathext, G_SEARCHPATH_SEPARATOR_S, 100);
|
|
g_free (pathext);
|
|
}
|
|
else
|
|
{
|
|
exts = g_new (gchar *, 1);
|
|
exts[0] = NULL;
|
|
}
|
|
}
|
|
|
|
i = 0;
|
|
while (exts[i] != NULL)
|
|
{
|
|
if (g_strcasecmp (ext, exts[i]) == 0)
|
|
return TRUE;
|
|
i++;
|
|
}
|
|
|
|
return FALSE;
|
|
}
|
|
#else /* !G_OS_WIN32 */
|
|
#define is_script(filename) FALSE
|
|
#endif
|
|
|
|
void
|
|
datafiles_read_directories (char *path_str,
|
|
datafile_loader_t loader_func,
|
|
int flags)
|
|
{
|
|
char *home;
|
|
char *local_path;
|
|
char *path;
|
|
char *filename;
|
|
char *token;
|
|
char *next_token;
|
|
int err;
|
|
DIR *dir;
|
|
struct dirent *dir_ent;
|
|
|
|
if (path_str == NULL)
|
|
return;
|
|
|
|
/* Set local path to contain temp_path, where (supposedly)
|
|
* there may be working files.
|
|
*/
|
|
home = g_get_home_dir ();
|
|
local_path = g_strdup (path_str);
|
|
#ifdef __EMX__
|
|
/*
|
|
* Change drive so opendir works.
|
|
*/
|
|
if (local_path[1] == ':')
|
|
{
|
|
_chdrive(local_path[0]);
|
|
}
|
|
#endif
|
|
/* Search through all directories in the local path */
|
|
|
|
next_token = local_path;
|
|
|
|
token = xstrsep(&next_token, G_SEARCHPATH_SEPARATOR_S);
|
|
|
|
while (token)
|
|
{
|
|
if (*token == '~')
|
|
{
|
|
path = g_malloc(strlen(home) + strlen(token) + 1);
|
|
sprintf(path, "%s%s", home, token + 1);
|
|
}
|
|
else
|
|
{
|
|
path = g_malloc(strlen(token) + 2);
|
|
strcpy(path, token);
|
|
} /* else */
|
|
|
|
/* Check if directory exists and if it has any items in it */
|
|
err = stat(path, &filestat);
|
|
|
|
if (!err && S_ISDIR(filestat.st_mode))
|
|
{
|
|
if (path[strlen(path) - 1] != G_DIR_SEPARATOR)
|
|
strcat(path, G_DIR_SEPARATOR_S);
|
|
|
|
/* Open directory */
|
|
dir = opendir(path);
|
|
|
|
if (!dir)
|
|
g_message ("error reading datafiles directory \"%s\"", path);
|
|
else
|
|
{
|
|
while ((dir_ent = readdir(dir)))
|
|
{
|
|
filename = g_strdup_printf("%s%s", path, dir_ent->d_name);
|
|
|
|
/* Check the file and see that it is not a sub-directory */
|
|
err = stat(filename, &filestat);
|
|
|
|
if (!err && S_ISREG(filestat.st_mode) &&
|
|
(!(flags & MODE_EXECUTABLE) ||
|
|
(filestat.st_mode & S_IXUSR) ||
|
|
is_script (filename)))
|
|
{
|
|
filestat_valid = 1;
|
|
(*loader_func) (filename);
|
|
filestat_valid = 0;
|
|
}
|
|
|
|
g_free(filename);
|
|
} /* while */
|
|
|
|
closedir(dir);
|
|
} /* else */
|
|
} /* if */
|
|
|
|
g_free(path);
|
|
|
|
token = xstrsep(&next_token, G_SEARCHPATH_SEPARATOR_S);
|
|
} /* while */
|
|
|
|
g_free(local_path);
|
|
} /* datafiles_read_directories */
|
|
|
|
time_t
|
|
datafile_atime ()
|
|
{
|
|
if (filestat_valid)
|
|
return filestat.st_atime;
|
|
return 0;
|
|
}
|
|
|
|
time_t
|
|
datafile_mtime ()
|
|
{
|
|
if (filestat_valid)
|
|
return filestat.st_mtime;
|
|
return 0;
|
|
}
|
|
|
|
time_t
|
|
datafile_ctime ()
|
|
{
|
|
if (filestat_valid)
|
|
return filestat.st_ctime;
|
|
return 0;
|
|
}
|