fixed a gtk-doc comment.

2000-02-21  Michael Natterer  <mitch@gimp.org>

	* libgimp/gimppixmap.c: fixed a gtk-doc comment.

	* libgimp/gimpenv.[ch]: new functions:

	- gimp_path_parse(): Creates a GList of strings from a searchpath
	  string and performs sanity checks.
	- gimp_path_to_str(): Creates a searchpath string from the list
	  returned by gimp_path_parse().
	- gimp_path_free(): Frees the list returned by gimp_path_parse().
	- gimp_path_get_user_writable_dir(): Returns the first dir in a
	  path where the user has write access. With this function the
	  "Save" dialogs of some plugins always show the plugin's
	  subdirectory of the user's gimp_dir instead of the read-only
	  global one.

	* app/datafiles.[ch]
	* app/gimpbrushlist.c: use the new functions and
	s/datafile_loader_t/GimpDataFileLoaderFunc/.

	* plug-ins/FractalExplorer/Dialogs.c
	* plug-ins/FractalExplorer/FractalExplorer.c
	* plug-ins/gfig/gfig.c
	* plug-ins/gflare/gflare.c
	* plug-ins/gimpressionist/gimpressionist.c: use the new functions.
This commit is contained in:
Michael Natterer 2000-02-21 17:15:30 +00:00 committed by Michael Natterer
parent d4b05436ec
commit ed071953b2
19 changed files with 790 additions and 596 deletions

View File

@ -1,3 +1,30 @@
2000-02-21 Michael Natterer <mitch@gimp.org>
* libgimp/gimppixmap.c: fixed a gtk-doc comment.
* libgimp/gimpenv.[ch]: new functions:
- gimp_path_parse(): Creates a GList of strings from a searchpath
string and performs sanity checks.
- gimp_path_to_str(): Creates a searchpath string from the list
returned by gimp_path_parse().
- gimp_path_free(): Frees the list returned by gimp_path_parse().
- gimp_path_get_user_writable_dir(): Returns the first dir in a
path where the user has write access. With this function the
"Save" dialogs of some plugins always show the plugin's
subdirectory of the user's gimp_dir instead of the read-only
global one.
* app/datafiles.[ch]
* app/gimpbrushlist.c: use the new functions and
s/datafile_loader_t/GimpDataFileLoaderFunc/.
* plug-ins/FractalExplorer/Dialogs.c
* plug-ins/FractalExplorer/FractalExplorer.c
* plug-ins/gfig/gfig.c
* plug-ins/gflare/gflare.c
* plug-ins/gimpressionist/gimpressionist.c: use the new functions.
Mon Feb 21 14:05:56 CET 2000 Sven Neumann <sven@gimp.org>
* app/gimpbrushlist.c

View File

@ -45,16 +45,13 @@
#endif /* G_OS_WIN32 */
#include "datafiles.h"
#include "errors.h"
#include "general.h"
#include "gimprc.h"
#include "libgimp/gimpenv.h"
/***** Functions *****/
/*****/
static int filestat_valid = 0;
static gint filestat_valid = 0;
static struct stat filestat;
#ifdef G_OS_WIN32
@ -66,7 +63,7 @@ static struct stat filestat;
* variable, which is also used by cmd.exe.
*/
gboolean
is_script (const gchar* filename)
is_script (const gchar *filename)
{
const gchar *ext = strrchr (filename, '.');
gchar *pathext;
@ -103,79 +100,57 @@ is_script (const gchar* filename)
#endif
void
datafiles_read_directories (char *path_str,
datafile_loader_t loader_func,
int flags)
datafiles_read_directories (gchar *path_str,
GimpDataFileLoaderFunc loader_func,
gint flags)
{
char *home;
char *local_path;
char *path;
char *filename;
char *token;
char *next_token;
int err;
gchar *local_path;
GList *path;
GList *list;
gchar *filename;
gint 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]);
_chdrive (local_path[0]);
}
#endif
/* Search through all directories in the local path */
next_token = local_path;
path = gimp_path_parse (local_path, 16, TRUE, NULL);
token = xstrsep(&next_token, G_SEARCHPATH_SEPARATOR_S);
while (token)
for (list = path; list; list = g_list_next (list))
{
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);
dir = opendir ((gchar *) list->data);
if (!dir)
g_message ("error reading datafiles directory \"%s\"", path);
{
g_message ("error reading datafiles directory \"%s\"",
(gchar *) list->data);
}
else
{
while ((dir_ent = readdir(dir)))
{
filename = g_strdup_printf("%s%s", path, dir_ent->d_name);
filename = g_strdup_printf ("%s%s",
(gchar *) list->data,
dir_ent->d_name);
/* Check the file and see that it is not a sub-directory */
err = stat(filename, &filestat);
err = stat (filename, &filestat);
if (!err && S_ISREG(filestat.st_mode) &&
if (!err && S_ISREG (filestat.st_mode) &&
(!(flags & MODE_EXECUTABLE) ||
(filestat.st_mode & S_IXUSR) ||
is_script (filename)))
@ -185,23 +160,18 @@ datafiles_read_directories (char *path_str,
filestat_valid = 0;
}
g_free(filename);
} /* while */
g_free (filename);
}
closedir(dir);
} /* else */
} /* if */
closedir (dir);
}
}
g_free(path);
token = xstrsep(&next_token, G_SEARCHPATH_SEPARATOR_S);
} /* while */
g_free(local_path);
} /* datafiles_read_directories */
gimp_path_free (path);
}
time_t
datafile_atime ()
datafile_atime (void)
{
if (filestat_valid)
return filestat.st_atime;
@ -209,7 +179,7 @@ datafile_atime ()
}
time_t
datafile_mtime ()
datafile_mtime (void)
{
if (filestat_valid)
return filestat.st_mtime;
@ -217,7 +187,7 @@ datafile_mtime ()
}
time_t
datafile_ctime ()
datafile_ctime (void)
{
if (filestat_valid)
return filestat.st_ctime;

View File

@ -19,11 +19,11 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef _DATAFILES_H_
#define _DATAFILES_H_
#ifndef __DATAFILES_H__
#define __DATAFILES_H__
#include <time.h>
#include <glib.h>
#define INCLUDE_TEMP_DIR 0x1
#define MODE_EXECUTABLE 0x2
@ -31,23 +31,22 @@
/***** Types *****/
typedef void (*datafile_loader_t) (char *filename);
typedef void (* GimpDataFileLoaderFunc) (gchar *filename);
/***** Functions *****/
void datafiles_read_directories(char *path_str,
datafile_loader_t loader_func,
int flags);
void datafiles_read_directories (gchar *path_str,
GimpDataFileLoaderFunc loader_func,
gint flags);
/* Return the current datafiles access, modification
* or change time. The current datafile is the one for
* which the "datafile_loader_t" function has been called
* which the "DataFileLoaderFunc" function has been called
* on.
*/
time_t datafile_atime (void);
time_t datafile_mtime (void);
time_t datafile_ctime (void);
#endif
#endif /* __DATAFILES_H__ */

View File

@ -45,16 +45,13 @@
#endif /* G_OS_WIN32 */
#include "datafiles.h"
#include "errors.h"
#include "general.h"
#include "gimprc.h"
#include "libgimp/gimpenv.h"
/***** Functions *****/
/*****/
static int filestat_valid = 0;
static gint filestat_valid = 0;
static struct stat filestat;
#ifdef G_OS_WIN32
@ -66,7 +63,7 @@ static struct stat filestat;
* variable, which is also used by cmd.exe.
*/
gboolean
is_script (const gchar* filename)
is_script (const gchar *filename)
{
const gchar *ext = strrchr (filename, '.');
gchar *pathext;
@ -103,79 +100,57 @@ is_script (const gchar* filename)
#endif
void
datafiles_read_directories (char *path_str,
datafile_loader_t loader_func,
int flags)
datafiles_read_directories (gchar *path_str,
GimpDataFileLoaderFunc loader_func,
gint flags)
{
char *home;
char *local_path;
char *path;
char *filename;
char *token;
char *next_token;
int err;
gchar *local_path;
GList *path;
GList *list;
gchar *filename;
gint 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]);
_chdrive (local_path[0]);
}
#endif
/* Search through all directories in the local path */
next_token = local_path;
path = gimp_path_parse (local_path, 16, TRUE, NULL);
token = xstrsep(&next_token, G_SEARCHPATH_SEPARATOR_S);
while (token)
for (list = path; list; list = g_list_next (list))
{
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);
dir = opendir ((gchar *) list->data);
if (!dir)
g_message ("error reading datafiles directory \"%s\"", path);
{
g_message ("error reading datafiles directory \"%s\"",
(gchar *) list->data);
}
else
{
while ((dir_ent = readdir(dir)))
{
filename = g_strdup_printf("%s%s", path, dir_ent->d_name);
filename = g_strdup_printf ("%s%s",
(gchar *) list->data,
dir_ent->d_name);
/* Check the file and see that it is not a sub-directory */
err = stat(filename, &filestat);
err = stat (filename, &filestat);
if (!err && S_ISREG(filestat.st_mode) &&
if (!err && S_ISREG (filestat.st_mode) &&
(!(flags & MODE_EXECUTABLE) ||
(filestat.st_mode & S_IXUSR) ||
is_script (filename)))
@ -185,23 +160,18 @@ datafiles_read_directories (char *path_str,
filestat_valid = 0;
}
g_free(filename);
} /* while */
g_free (filename);
}
closedir(dir);
} /* else */
} /* if */
closedir (dir);
}
}
g_free(path);
token = xstrsep(&next_token, G_SEARCHPATH_SEPARATOR_S);
} /* while */
g_free(local_path);
} /* datafiles_read_directories */
gimp_path_free (path);
}
time_t
datafile_atime ()
datafile_atime (void)
{
if (filestat_valid)
return filestat.st_atime;
@ -209,7 +179,7 @@ datafile_atime ()
}
time_t
datafile_mtime ()
datafile_mtime (void)
{
if (filestat_valid)
return filestat.st_mtime;
@ -217,7 +187,7 @@ datafile_mtime ()
}
time_t
datafile_ctime ()
datafile_ctime (void)
{
if (filestat_valid)
return filestat.st_ctime;

View File

@ -19,11 +19,11 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef _DATAFILES_H_
#define _DATAFILES_H_
#ifndef __DATAFILES_H__
#define __DATAFILES_H__
#include <time.h>
#include <glib.h>
#define INCLUDE_TEMP_DIR 0x1
#define MODE_EXECUTABLE 0x2
@ -31,23 +31,22 @@
/***** Types *****/
typedef void (*datafile_loader_t) (char *filename);
typedef void (* GimpDataFileLoaderFunc) (gchar *filename);
/***** Functions *****/
void datafiles_read_directories(char *path_str,
datafile_loader_t loader_func,
int flags);
void datafiles_read_directories (gchar *path_str,
GimpDataFileLoaderFunc loader_func,
gint flags);
/* Return the current datafiles access, modification
* or change time. The current datafile is the one for
* which the "datafile_loader_t" function has been called
* which the "DataFileLoaderFunc" function has been called
* on.
*/
time_t datafile_atime (void);
time_t datafile_mtime (void);
time_t datafile_ctime (void);
#endif
#endif /* __DATAFILES_H__ */

View File

@ -134,7 +134,7 @@ gimp_brush_list_new (void)
/* function declarations */
void
brushes_init (int no_data)
brushes_init (gint no_data)
{
if (brush_list)
brushes_free ();
@ -146,9 +146,11 @@ brushes_init (int no_data)
brush_select_freeze_all ();
datafiles_read_directories (brush_path,
(datafile_loader_t) brushes_brush_load, 0);
(GimpDataFileLoaderFunc) brushes_brush_load,
0);
datafiles_read_directories (brush_vbr_path,
(datafile_loader_t) brushes_brush_load, 0);
(GimpDataFileLoaderFunc) brushes_brush_load,
0);
brush_select_thaw_all ();
}

View File

@ -22,6 +22,12 @@
#include <glib.h>
#include <string.h>
#include <sys/stat.h>
#include <sys/types.h>
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif
#include "gimpenv.h"
#ifdef G_OS_WIN32
@ -240,6 +246,196 @@ gimp_gtkrc (void)
return gimp_gtkrc_filename;
}
/**
* gimp_path_parse:
* @path: A list of directories separated by #G_SEARCHPATH_SEPARATOR.
* @max_path: The maximum number of directories to return.
* @check: #TRUE if you want the directories to be checked.
* @not_found: #
*
* Return: A list of all directories in @path.
*
*/
GList *
gimp_path_parse (gchar *path,
gint max_paths,
gboolean check,
GList **check_failed)
{
gchar *home;
gchar **patharray;
GList *list = NULL;
GList *fail_list = NULL;
gint i;
struct stat filestat;
gint err = FALSE;
if (!path || !*path || max_paths < 1 || max_paths > 256)
return NULL;
home = g_get_home_dir ();
patharray = g_strsplit (path, G_SEARCHPATH_SEPARATOR_S, max_paths);
for (i = 0; i < max_paths; i++)
{
GString *dir;
if (!patharray[i])
break;
if (*patharray[i] == '~')
{
dir = g_string_new (home);
g_string_append (dir, patharray[i] + 1);
}
else
{
dir = g_string_new (patharray[i]);
}
#ifdef __EMX__
_fnslashify (dir);
#endif
if (check)
{
/* check if directory exists */
err = stat (dir->str, &filestat);
if (!err && S_ISDIR (filestat.st_mode))
{
if (dir->str[dir->len - 1] != G_DIR_SEPARATOR)
g_string_append_c (dir, G_DIR_SEPARATOR);
}
}
if (!err)
list = g_list_prepend (list, dir->str);
else if (check_failed)
fail_list = g_list_prepend (fail_list, dir->str);
g_string_free (dir, FALSE);
}
g_strfreev (patharray);
list = g_list_reverse (list);
if (check && check_failed)
{
fail_list = g_list_reverse (fail_list);
*check_failed = fail_list;
}
return list;
}
/**
* gimp_path_to_str:
* @path: A list of directories as returned by gimp_path_parse().
*
* Returns: A searchpath string separated by #G_SEARCHPATH_SEPARATOR.
*
*/
gchar *
gimp_path_to_str (GList *path)
{
GString *str = NULL;
GList *list;
gchar *retval = NULL;
for (list = path; list; list = g_list_next (list))
{
if (str)
{
g_string_append_c (str, G_SEARCHPATH_SEPARATOR);
g_string_append (str, (gchar *) list->data);
}
else
{
str = g_string_new ((gchar *) list->data);
}
}
if (str)
{
retval = str->str;
g_string_free (str, FALSE);
}
return retval;
}
/**
* gimp_path_free:
* @path: A list of directories as returned by gimp_path_parse().
*
* This function frees the memory allocated for the list and it's strings.
*
*/
void
gimp_path_free (GList *path)
{
GList *list;
if (path)
{
for (list = path; list; list = g_list_next (list))
{
g_free (list->data);
}
g_list_free (path);
}
}
/**
* gimp_path_get_user_writable_dir:
* @path: A list of directories as returned by gimp_path_parse().
*
* Returns: The first directory in @path where the user has write permission.
*
*/
gchar *
gimp_path_get_user_writable_dir (GList *path)
{
GList *list;
uid_t euid;
gid_t egid;
struct stat filestat;
gint err;
euid = geteuid ();
egid = getegid ();
for (list = path; list; list = g_list_next (list))
{
/* check if directory exists */
err = stat ((gchar *) list->data, &filestat);
/* this is tricky:
* if a file is e.g. owned by the current user but not user-writable,
* the user has no permission to write to the file regardless
* of his group's or other's write permissions
*/
if (!err && S_ISDIR (filestat.st_mode) &&
((filestat.st_mode & S_IWUSR) ||
((filestat.st_mode & S_IWGRP) &&
(euid != filestat.st_uid)) ||
((filestat.st_mode & S_IWOTH) &&
(euid != filestat.st_uid) &&
(egid != filestat.st_gid))))
{
return (gchar *) list->data;
}
}
return NULL;
}

View File

@ -27,10 +27,19 @@ extern "C" {
/* For information look into the C source or the html documentation */
gchar* gimp_directory (void);
gchar* gimp_personal_rc_file (gchar *basename);
gchar* gimp_data_directory (void);
gchar* gimp_gtkrc (void);
gchar * gimp_directory (void);
gchar * gimp_personal_rc_file (gchar *basename);
gchar * gimp_data_directory (void);
gchar * gimp_gtkrc (void);
GList * gimp_path_parse (gchar *path,
gint max_paths,
gboolean check,
GList **check_failed);
gchar * gimp_path_to_str (GList *path);
void gimp_path_free (GList *path);
gchar * gimp_path_get_user_writable_dir (GList *path);
#ifdef __cplusplus
}

View File

@ -118,7 +118,7 @@ gimp_pixmap_new (gchar **xpm_data)
}
/**
* gimp_pixmap_new:
* gimp_pixmap_set:
* @pixmap: The pixmap widget you want to set the new xpm_data for.
* @xpm_data: A pointer to a XPM data structure as found in XPM files.
*

View File

@ -45,16 +45,13 @@
#endif /* G_OS_WIN32 */
#include "datafiles.h"
#include "errors.h"
#include "general.h"
#include "gimprc.h"
#include "libgimp/gimpenv.h"
/***** Functions *****/
/*****/
static int filestat_valid = 0;
static gint filestat_valid = 0;
static struct stat filestat;
#ifdef G_OS_WIN32
@ -66,7 +63,7 @@ static struct stat filestat;
* variable, which is also used by cmd.exe.
*/
gboolean
is_script (const gchar* filename)
is_script (const gchar *filename)
{
const gchar *ext = strrchr (filename, '.');
gchar *pathext;
@ -103,79 +100,57 @@ is_script (const gchar* filename)
#endif
void
datafiles_read_directories (char *path_str,
datafile_loader_t loader_func,
int flags)
datafiles_read_directories (gchar *path_str,
GimpDataFileLoaderFunc loader_func,
gint flags)
{
char *home;
char *local_path;
char *path;
char *filename;
char *token;
char *next_token;
int err;
gchar *local_path;
GList *path;
GList *list;
gchar *filename;
gint 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]);
_chdrive (local_path[0]);
}
#endif
/* Search through all directories in the local path */
next_token = local_path;
path = gimp_path_parse (local_path, 16, TRUE, NULL);
token = xstrsep(&next_token, G_SEARCHPATH_SEPARATOR_S);
while (token)
for (list = path; list; list = g_list_next (list))
{
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);
dir = opendir ((gchar *) list->data);
if (!dir)
g_message ("error reading datafiles directory \"%s\"", path);
{
g_message ("error reading datafiles directory \"%s\"",
(gchar *) list->data);
}
else
{
while ((dir_ent = readdir(dir)))
{
filename = g_strdup_printf("%s%s", path, dir_ent->d_name);
filename = g_strdup_printf ("%s%s",
(gchar *) list->data,
dir_ent->d_name);
/* Check the file and see that it is not a sub-directory */
err = stat(filename, &filestat);
err = stat (filename, &filestat);
if (!err && S_ISREG(filestat.st_mode) &&
if (!err && S_ISREG (filestat.st_mode) &&
(!(flags & MODE_EXECUTABLE) ||
(filestat.st_mode & S_IXUSR) ||
is_script (filename)))
@ -185,23 +160,18 @@ datafiles_read_directories (char *path_str,
filestat_valid = 0;
}
g_free(filename);
} /* while */
g_free (filename);
}
closedir(dir);
} /* else */
} /* if */
closedir (dir);
}
}
g_free(path);
token = xstrsep(&next_token, G_SEARCHPATH_SEPARATOR_S);
} /* while */
g_free(local_path);
} /* datafiles_read_directories */
gimp_path_free (path);
}
time_t
datafile_atime ()
datafile_atime (void)
{
if (filestat_valid)
return filestat.st_atime;
@ -209,7 +179,7 @@ datafile_atime ()
}
time_t
datafile_mtime ()
datafile_mtime (void)
{
if (filestat_valid)
return filestat.st_mtime;
@ -217,7 +187,7 @@ datafile_mtime ()
}
time_t
datafile_ctime ()
datafile_ctime (void)
{
if (filestat_valid)
return filestat.st_ctime;

View File

@ -19,11 +19,11 @@
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
*/
#ifndef _DATAFILES_H_
#define _DATAFILES_H_
#ifndef __DATAFILES_H__
#define __DATAFILES_H__
#include <time.h>
#include <glib.h>
#define INCLUDE_TEMP_DIR 0x1
#define MODE_EXECUTABLE 0x2
@ -31,23 +31,22 @@
/***** Types *****/
typedef void (*datafile_loader_t) (char *filename);
typedef void (* GimpDataFileLoaderFunc) (gchar *filename);
/***** Functions *****/
void datafiles_read_directories(char *path_str,
datafile_loader_t loader_func,
int flags);
void datafiles_read_directories (gchar *path_str,
GimpDataFileLoaderFunc loader_func,
gint flags);
/* Return the current datafiles access, modification
* or change time. The current datafile is the one for
* which the "datafile_loader_t" function has been called
* which the "DataFileLoaderFunc" function has been called
* on.
*/
time_t datafile_atime (void);
time_t datafile_mtime (void);
time_t datafile_ctime (void);
#endif
#endif /* __DATAFILES_H__ */

View File

@ -22,6 +22,12 @@
#include <glib.h>
#include <string.h>
#include <sys/stat.h>
#include <sys/types.h>
#ifdef HAVE_UNISTD_H
#include <unistd.h>
#endif
#include "gimpenv.h"
#ifdef G_OS_WIN32
@ -240,6 +246,196 @@ gimp_gtkrc (void)
return gimp_gtkrc_filename;
}
/**
* gimp_path_parse:
* @path: A list of directories separated by #G_SEARCHPATH_SEPARATOR.
* @max_path: The maximum number of directories to return.
* @check: #TRUE if you want the directories to be checked.
* @not_found: #
*
* Return: A list of all directories in @path.
*
*/
GList *
gimp_path_parse (gchar *path,
gint max_paths,
gboolean check,
GList **check_failed)
{
gchar *home;
gchar **patharray;
GList *list = NULL;
GList *fail_list = NULL;
gint i;
struct stat filestat;
gint err = FALSE;
if (!path || !*path || max_paths < 1 || max_paths > 256)
return NULL;
home = g_get_home_dir ();
patharray = g_strsplit (path, G_SEARCHPATH_SEPARATOR_S, max_paths);
for (i = 0; i < max_paths; i++)
{
GString *dir;
if (!patharray[i])
break;
if (*patharray[i] == '~')
{
dir = g_string_new (home);
g_string_append (dir, patharray[i] + 1);
}
else
{
dir = g_string_new (patharray[i]);
}
#ifdef __EMX__
_fnslashify (dir);
#endif
if (check)
{
/* check if directory exists */
err = stat (dir->str, &filestat);
if (!err && S_ISDIR (filestat.st_mode))
{
if (dir->str[dir->len - 1] != G_DIR_SEPARATOR)
g_string_append_c (dir, G_DIR_SEPARATOR);
}
}
if (!err)
list = g_list_prepend (list, dir->str);
else if (check_failed)
fail_list = g_list_prepend (fail_list, dir->str);
g_string_free (dir, FALSE);
}
g_strfreev (patharray);
list = g_list_reverse (list);
if (check && check_failed)
{
fail_list = g_list_reverse (fail_list);
*check_failed = fail_list;
}
return list;
}
/**
* gimp_path_to_str:
* @path: A list of directories as returned by gimp_path_parse().
*
* Returns: A searchpath string separated by #G_SEARCHPATH_SEPARATOR.
*
*/
gchar *
gimp_path_to_str (GList *path)
{
GString *str = NULL;
GList *list;
gchar *retval = NULL;
for (list = path; list; list = g_list_next (list))
{
if (str)
{
g_string_append_c (str, G_SEARCHPATH_SEPARATOR);
g_string_append (str, (gchar *) list->data);
}
else
{
str = g_string_new ((gchar *) list->data);
}
}
if (str)
{
retval = str->str;
g_string_free (str, FALSE);
}
return retval;
}
/**
* gimp_path_free:
* @path: A list of directories as returned by gimp_path_parse().
*
* This function frees the memory allocated for the list and it's strings.
*
*/
void
gimp_path_free (GList *path)
{
GList *list;
if (path)
{
for (list = path; list; list = g_list_next (list))
{
g_free (list->data);
}
g_list_free (path);
}
}
/**
* gimp_path_get_user_writable_dir:
* @path: A list of directories as returned by gimp_path_parse().
*
* Returns: The first directory in @path where the user has write permission.
*
*/
gchar *
gimp_path_get_user_writable_dir (GList *path)
{
GList *list;
uid_t euid;
gid_t egid;
struct stat filestat;
gint err;
euid = geteuid ();
egid = getegid ();
for (list = path; list; list = g_list_next (list))
{
/* check if directory exists */
err = stat ((gchar *) list->data, &filestat);
/* this is tricky:
* if a file is e.g. owned by the current user but not user-writable,
* the user has no permission to write to the file regardless
* of his group's or other's write permissions
*/
if (!err && S_ISDIR (filestat.st_mode) &&
((filestat.st_mode & S_IWUSR) ||
((filestat.st_mode & S_IWGRP) &&
(euid != filestat.st_uid)) ||
((filestat.st_mode & S_IWOTH) &&
(euid != filestat.st_uid) &&
(egid != filestat.st_gid))))
{
return (gchar *) list->data;
}
}
return NULL;
}

View File

@ -27,10 +27,19 @@ extern "C" {
/* For information look into the C source or the html documentation */
gchar* gimp_directory (void);
gchar* gimp_personal_rc_file (gchar *basename);
gchar* gimp_data_directory (void);
gchar* gimp_gtkrc (void);
gchar * gimp_directory (void);
gchar * gimp_personal_rc_file (gchar *basename);
gchar * gimp_data_directory (void);
gchar * gimp_gtkrc (void);
GList * gimp_path_parse (gchar *path,
gint max_paths,
gboolean check,
GList **check_failed);
gchar * gimp_path_to_str (GList *path);
void gimp_path_free (GList *path);
gchar * gimp_path_get_user_writable_dir (GList *path);
#ifdef __cplusplus
}

View File

@ -118,7 +118,7 @@ gimp_pixmap_new (gchar **xpm_data)
}
/**
* gimp_pixmap_new:
* gimp_pixmap_set:
* @pixmap: The pixmap widget you want to set the new xpm_data for.
* @xpm_data: A pointer to a XPM data structure as found in XPM files.
*

View File

@ -1718,24 +1718,30 @@ create_file_selection (void)
"clicked",
GTK_SIGNAL_FUNC (file_selection_ok),
(gpointer) window);
gimp_help_set_help_data (GTK_FILE_SELECTION(window)->ok_button, _("Click here to save your file"), NULL);
gimp_help_set_help_data (GTK_FILE_SELECTION(window)->ok_button,
_("Click here to save your file"), NULL);
gtk_signal_connect_object (GTK_OBJECT (GTK_FILE_SELECTION(window)->cancel_button),
"clicked",
GTK_SIGNAL_FUNC (gtk_widget_destroy),
GTK_OBJECT (window));
gimp_help_set_help_data (GTK_FILE_SELECTION(window)->cancel_button, _("Click here to cancel save procedure"), NULL);
gimp_help_set_help_data (GTK_FILE_SELECTION (window)->cancel_button,
_("Click here to cancel save procedure"), NULL);
}
if (tpath)
{
gtk_file_selection_set_filename (GTK_FILE_SELECTION (window), tpath);
}
else if(fractalexplorer_path_list)
else if (fractalexplorer_path_list)
{
/* Last path is where usually saved to */
gtk_file_selection_set_filename (GTK_FILE_SELECTION (window),
g_list_nth (fractalexplorer_path_list,
g_list_length (fractalexplorer_path_list)-1)->data);
gchar *dir;
dir = gimp_path_get_user_writable_dir (fractalexplorer_path_list);
if (!dir)
dir = gimp_directory ();
gtk_file_selection_set_filename (GTK_FILE_SELECTION (window), dir);
}
else
gtk_file_selection_set_filename (GTK_FILE_SELECTION (window),"/tmp");

View File

@ -1135,17 +1135,11 @@ plug_in_parse_fractalexplorer_path (void)
{
GParam *return_vals;
gint nreturn_vals;
gchar *path_string;
gchar *home;
gchar *path;
gchar *token;
gchar *next_token;
struct stat filestat;
gint err;
if(fractalexplorer_path_list)
g_list_free(fractalexplorer_path_list);
GList *fail_list = NULL;
GList *list;
gimp_path_free (fractalexplorer_path_list);
fractalexplorer_path_list = NULL;
return_vals = gimp_run_procedure ("gimp_gimprc_query",
@ -1164,52 +1158,28 @@ plug_in_parse_fractalexplorer_path (void)
return;
}
path_string = g_strdup (return_vals[1].data.d_string);
fractalexplorer_path_list = gimp_path_parse (return_vals[1].data.d_string,
16, TRUE, &fail_list);
gimp_destroy_params (return_vals, nreturn_vals);
/* Set local path to contain temp_path, where (supposedly)
* there may be working files.
*/
home = g_get_home_dir ();
/* Search through all directories in the path */
next_token = path_string;
token = strtok (next_token, G_SEARCHPATH_SEPARATOR_S);
while (token)
if (fail_list)
{
if (*token == '\0')
GString *err =
g_string_new (_("fractalexplorer-path misconfigured - "
"the following directories were not found"));
for (list = fail_list; list; list = g_list_next (list))
{
token = strtok (NULL, G_SEARCHPATH_SEPARATOR_S);
continue;
g_string_append_c (err, '\n');
g_string_append (err, (gchar *) list->data);
}
if (*token == '~')
{
path = g_strdup_printf ("%s%s", home, token + 1);
}
else
{
path = g_strdup (token);
} /* else */
g_message (err->str);
/* Check if directory exists */
err = stat (path, &filestat);
if (!err && S_ISDIR (filestat.st_mode))
{
fractalexplorer_path_list = g_list_append (fractalexplorer_path_list, path);
g_string_free (err, TRUE);
gimp_path_free (fail_list);
}
else
{
g_message (_("fractalexplorer-path misconfigured\nPath "
"\"%s\" not found."), path);
g_free (path);
}
token = strtok (NULL, G_SEARCHPATH_SEPARATOR_S);
}
g_free (path_string);
}
static void
@ -1448,17 +1418,11 @@ fractalexplorer_rescan_ok_callback (GtkWidget *widget,
gpointer data)
{
GtkWidget *patheditor;
GList *list;
gchar *raw_path;
gchar **path;
gint i;
gtk_widget_set_sensitive (GTK_WIDGET (data), FALSE);
for (list = fractalexplorer_path_list; list; list = g_list_next (list))
g_free (list->data);
g_list_free (fractalexplorer_path_list);
gimp_path_free (fractalexplorer_path_list);
fractalexplorer_path_list = NULL;
patheditor = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (data),
@ -1466,18 +1430,9 @@ fractalexplorer_rescan_ok_callback (GtkWidget *widget,
raw_path = gimp_path_editor_get_path (GIMP_PATH_EDITOR (patheditor));
path = g_strsplit (raw_path, ":", 16);
fractalexplorer_path_list = gimp_path_parse (raw_path, 16, FALSE, NULL);
for (i = 0; i < 16; i++)
{
if (!path[i])
break;
fractalexplorer_path_list = g_list_append (fractalexplorer_path_list,
g_strdup (path[i]));
}
g_strfreev (path);
g_free (raw_path);
if (fractalexplorer_path_list)
{
@ -1496,8 +1451,7 @@ fractalexplorer_rescan_list (void)
static GtkWidget *dlg = NULL;
GtkWidget *patheditor;
GString *path = NULL;
GList *list;
gchar *path;
if (dlg)
{
@ -1522,26 +1476,15 @@ fractalexplorer_rescan_list (void)
GTK_SIGNAL_FUNC (gtk_widget_destroyed),
&dlg);
for (list = fractalexplorer_path_list; list; list = g_list_next (list))
{
if (path == NULL)
{
path = g_string_new (list->data);
}
else
{
g_string_append_c (path, G_SEARCHPATH_SEPARATOR);
g_string_append (path, list->data);
}
}
path = gimp_path_to_str (fractalexplorer_path_list);
patheditor = gimp_path_editor_new (_("Add FractalExplorer Path"), path->str);
patheditor = gimp_path_editor_new (_("Add FractalExplorer Path"), path);
gtk_container_set_border_width (GTK_CONTAINER (patheditor), 6);
gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dlg)->vbox), patheditor,
TRUE, TRUE, 0);
gtk_widget_show (patheditor);
g_string_free (path, TRUE);
g_free (path);
gtk_object_set_data (GTK_OBJECT (dlg), "patheditor", patheditor);

View File

@ -134,7 +134,6 @@ static GtkWidget *gfig_preview;
static GtkWidget *pic_preview;
static GtkWidget *gfig_gtk_list;
static gint gfig_preview_exp_id;
static GdkPixmap *gfig_pixmap;
static gint32 gfig_image;
static gint32 gfig_drawable;
static GtkWidget *brush_page_pw;
@ -819,8 +818,6 @@ gfig_clear_selection (gint32 image_ID)
/*
* Query gimprc for gfig-path, and parse it.
* This code is based on script_fu_find_scripts ()
* and the Gflare plugin.
*/
static void
@ -828,16 +825,12 @@ plug_in_parse_gfig_path (void)
{
GParam *return_vals;
gint nreturn_vals;
gchar *path_string;
gchar *home;
gchar *path;
gchar *token;
gchar *next_token;
struct stat filestat;
gint err;
GList *fail_list = NULL;
GList *list;
if (gfig_path_list)
g_list_free (gfig_path_list);
gimp_path_free (gfig_path_list);
gfig_path_list = NULL;
@ -849,7 +842,7 @@ plug_in_parse_gfig_path (void)
if (return_vals[0].data.d_status != STATUS_SUCCESS ||
return_vals[1].data.d_string == NULL)
{
g_message ("No gfig-path in gimprc: gfig_path_list is NULL\n\n"
g_message ("No gfig-path in gimprc:\n\n"
"You need to add an entry like\n"
"(gfig-path \"${gimp_dir}/gfig:${gimp_data_dir}/gfig\n"
"to your ~/.gimp/gimprc file\n");
@ -857,63 +850,28 @@ plug_in_parse_gfig_path (void)
return;
}
path_string = g_strdup (return_vals[1].data.d_string);
gfig_path_list = gimp_path_parse (return_vals[1].data.d_string,
16, TRUE, &fail_list);
gimp_destroy_params (return_vals, nreturn_vals);
/* Set local path to contain temp_path, where (supposedly)
* there may be working files.
*/
home = g_get_home_dir ();
/* Search through all directories in the path */
next_token = path_string;
token = strtok (next_token, G_SEARCHPATH_SEPARATOR_S);
while (token)
if (fail_list)
{
if (*token == '\0')
GString *err =
g_string_new (_("gfig-path misconfigured - "
"the following directories were not found"));
for (list = fail_list; list; list = g_list_next (list))
{
token = strtok (NULL, G_SEARCHPATH_SEPARATOR_S);
continue;
g_string_append_c (err, '\n');
g_string_append (err, (gchar *) list->data);
}
if (*token == '~')
{
path = g_malloc (strlen (home) + strlen (token) + 2);
sprintf (path, "%s%s", home, token + 1);
}
else
{
path = g_malloc (strlen (token) + 2);
strcpy (path, token);
} /* else */
#ifdef __EMX__
_fnslashify (path);
#endif
g_message (err->str);
/* Check if directory exists */
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);
#ifdef DEBUG
printf ("Added `%s' to gfig_path_list\n", path);
#endif /* DEBUG */
gfig_path_list = g_list_append (gfig_path_list, path);
g_string_free (err, TRUE);
gimp_path_free (fail_list);
}
else
{
g_message ("gfig-path misconfigured - \nPath `%.100s' not found\n",
path);
}
token = strtok (NULL, G_SEARCHPATH_SEPARATOR_S);
}
g_free (path_string);
}
@ -1640,14 +1598,16 @@ create_file_selection (GFigObj *obj,
{
gtk_file_selection_set_filename (GTK_FILE_SELECTION (window), tpath);
}
else
/* Last path is where usually saved to */
if (gfig_path_list)
else if (gfig_path_list)
{
gtk_file_selection_set_filename
(GTK_FILE_SELECTION (window),
g_list_nth (gfig_path_list,
g_list_length (gfig_path_list) - 1)->data);
gchar *dir;
dir = gimp_path_get_user_writable_dir (gfig_path_list);
if (!dir)
dir = gimp_directory ();
gtk_file_selection_set_filename (GTK_FILE_SELECTION (window), dir);
}
else
gtk_file_selection_set_filename (GTK_FILE_SELECTION (window), "/tmp");
@ -4523,17 +4483,11 @@ gfig_rescan_ok_callback (GtkWidget *widget,
gpointer data)
{
GtkWidget *patheditor;
GList *list;
gchar *raw_path;
gchar **path;
gint i;
gtk_widget_set_sensitive (GTK_WIDGET (data), FALSE);
for (list = gfig_path_list; list; list = g_list_next (list))
g_free (list->data);
g_list_free (gfig_path_list);
gimp_path_free (gfig_path_list);
gfig_path_list = NULL;
patheditor = GTK_WIDGET (gtk_object_get_data (GTK_OBJECT (data),
@ -4541,17 +4495,9 @@ gfig_rescan_ok_callback (GtkWidget *widget,
raw_path = gimp_path_editor_get_path (GIMP_PATH_EDITOR (patheditor));
path = g_strsplit (raw_path, ":", 16);
gfig_path_list = gimp_path_parse (raw_path, 16, FALSE, NULL);
for (i = 0; i < 16; i++)
{
if (!path[i])
break;
gfig_path_list = g_list_append (gfig_path_list, g_strdup (path[i]));
}
g_strfreev (path);
g_free (raw_path);
if (gfig_path_list)
{
@ -4570,8 +4516,7 @@ gfig_rescan_list (void)
static GtkWidget *dlg = NULL;
GtkWidget *patheditor;
GString *path = NULL;
GList *list;
gchar *path;
if (dlg)
{
@ -4596,26 +4541,15 @@ gfig_rescan_list (void)
GTK_SIGNAL_FUNC (gtk_widget_destroyed),
&dlg);
for (list = gfig_path_list; list; list = g_list_next (list))
{
if (path == NULL)
{
path = g_string_new (list->data);
}
else
{
g_string_append_c (path, G_SEARCHPATH_SEPARATOR);
g_string_append (path, list->data);
}
}
path = gimp_path_to_str (gfig_path_list);
patheditor = gimp_path_editor_new (_("Add Gfig Path"), path->str);
patheditor = gimp_path_editor_new (_("Add Gfig Path"), path);
gtk_container_set_border_width (GTK_CONTAINER (patheditor), 6);
gtk_box_pack_start (GTK_BOX (GTK_DIALOG (dlg)->vbox), patheditor,
TRUE, TRUE, 0);
gtk_widget_show (patheditor);
g_string_free (path, TRUE);
g_free (path);
gtk_object_set_data (GTK_OBJECT (dlg), "patheditor", patheditor);

View File

@ -599,7 +599,7 @@ static GFlareDialog *dlg = NULL;
static GFlareEditor *ed = NULL;
static GList *gflares_list = NULL;
static gint num_gflares = 0;
GList *gflare_path_list;
static GList *gflare_path_list = NULL;
static CalcParams calc;
static GList *gradient_menus;
static gchar **gradient_names = NULL;
@ -967,14 +967,11 @@ plug_in_parse_gflare_path (void)
{
GParam *return_vals;
gint nreturn_vals;
gchar *path_string;
gchar *home;
gchar *path;
gchar *token;
gchar *next_token;
struct stat filestat;
gint err;
GList *fail_list = NULL;
GList *list;
gimp_path_free (gflare_path_list);
gflare_path_list = NULL;
return_vals = gimp_run_procedure ("gimp_gimprc_query",
@ -982,62 +979,40 @@ plug_in_parse_gflare_path (void)
PARAM_STRING, "gflare-path",
PARAM_END);
if (return_vals[0].data.d_status != STATUS_SUCCESS || return_vals[1].data.d_string == NULL)
if (return_vals[0].data.d_status != STATUS_SUCCESS ||
return_vals[1].data.d_string == NULL)
{
DEBUG_PRINT ("No gflare-path in gimprc: gflare_path_list is NULL\n");
g_message ("No gflare-path in gimprc:\n\n"
"You need to add an entry like\n"
"(gfig-path \"${gimp_dir}/gfig:${gimp_data_dir}/gfig\n"
"to your ~/.gimp/gimprc file\n");
gimp_destroy_params (return_vals, nreturn_vals);
return;
}
path_string = g_strdup (return_vals[1].data.d_string);
gflare_path_list = gimp_path_parse (return_vals[1].data.d_string,
16, TRUE, &fail_list);
gimp_destroy_params (return_vals, nreturn_vals);
home = g_get_home_dir ();
/* Search through all directories in the path */
next_token = path_string;
token = strtok (next_token, G_SEARCHPATH_SEPARATOR_S);
while (token)
if (fail_list)
{
if (*token == '\0')
GString *err =
g_string_new (_("gflare-path misconfigured - "
"the following directories were not found"));
for (list = fail_list; list; list = g_list_next (list))
{
token = strtok (NULL, G_SEARCHPATH_SEPARATOR_S);
continue;
g_string_append_c (err, '\n');
g_string_append (err, (gchar *) list->data);
}
if (*token == '~')
{
path = g_malloc (strlen (home) + strlen (token) + 2);
sprintf (path, "%s%s", home, token + 1);
}
else
{
path = g_malloc (strlen (token) + 2);
strcpy (path, token);
} /* else */
g_message (err->str);
/* Check if directory exists */
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);
DEBUG_PRINT(("Added `%s' to gflare_path_list\n", path));
gflare_path_list = g_list_append (gflare_path_list, path);
g_string_free (err, TRUE);
gimp_path_free (fail_list);
}
else
{
DEBUG_PRINT(("Not found `%s'\n", path));
g_free (path);
}
token = strtok (NULL, G_SEARCHPATH_SEPARATOR_S);
}
g_free (path_string);
}
@ -1548,14 +1523,12 @@ gflare_save (GFlare *gflare)
if (gflare_path_list == NULL)
{
if (!message_ok)
g_message (message,
gflare->name);
g_message (message, gflare->name);
message_ok = TRUE;
return;
}
/* get first entry of path */
path = gflare_path_list->data;
path = gimp_path_get_user_writable_dir (gflare_path_list);
gflare->filename = g_strdup_printf ("%s%s", path, gflare->name);
}

View File

@ -21,7 +21,6 @@
#include "ppmtool.h"
#include <libgimp/gimp.h>
#include <libgimp/stdplugins-intl.h>
/* #include <libgimp/gimpenv.h> */
#ifndef GIMP_CHECK_VERSION
#define GIMP_CHECK_VERSION(a,b,c) 0
@ -40,15 +39,16 @@ GtkTooltips *tooltips = NULL;
struct ppm infile = {0,0,NULL};
struct ppm inalpha = {0,0,NULL};
GList *parsepath(void)
GList * parsepath (void)
{
GParam *return_vals;
gint nreturn_vals;
static GList *lastpath = NULL;
char *gimpdatasubdir, *defaultpath, *tmps, *lastchr;
gchar *gimpdatasubdir, *defaultpath, *tmps;
struct stat st;
if(lastpath) return lastpath;
if (lastpath)
return lastpath;
#if GIMP_CHECK_VERSION(1, 1, 0)
gimpdatasubdir = g_strconcat (gimp_data_directory (),
@ -68,17 +68,22 @@ GList *parsepath(void)
gimpdatasubdir = strchr (defaultpath, ':') + 1;
#endif
if(standalone)
tmps = g_strdup(defaultpath);
else {
if (standalone)
tmps = g_strdup (defaultpath);
else
{
return_vals = gimp_run_procedure ("gimp_gimprc_query", &nreturn_vals,
PARAM_STRING, "gimpressionist-path",
PARAM_END);
if(return_vals[0].data.d_status != STATUS_SUCCESS ||
return_vals[1].data.d_string == NULL) {
if (return_vals[0].data.d_status != STATUS_SUCCESS ||
return_vals[1].data.d_string == NULL)
{
if (stat (gimpdatasubdir, &st) != 0
|| !S_ISDIR(st.st_mode)) {
/* No gimpressionist-path parameter, and the default doesn't exist */
|| !S_ISDIR(st.st_mode))
{
/* No gimpressionist-path parameter,
* and the default doesn't exist */
#if GIMP_CHECK_VERSION(1, 1, 0)
g_message( "*** Warning ***\n"
"It is highly recommended to add\n"
@ -90,32 +95,19 @@ GList *parsepath(void)
g_message( _("*** Warning ***\nIt is highly recommended to add\n (gimpressionist-path \"%s\")\n(or similar) to your gimprc file.\n"), defaultpath);
#endif
}
tmps = g_strdup(defaultpath);
} else {
tmps = g_strdup(return_vals[1].data.d_string);
tmps = g_strdup (defaultpath);
}
else
{
tmps = g_strdup (return_vals[1].data.d_string);
}
gimp_destroy_params (return_vals, nreturn_vals);
}
for(;;) {
lastchr = strchr(tmps, G_SEARCHPATH_SEPARATOR);
if(lastchr) *lastchr = '\0';
if(*tmps == '~') {
char *tmps2, *home;
home = g_get_home_dir ();
if(!home) {
g_message( _("*** Warning ***\nNo home directory!\n"));
home = "";
}
tmps2 = g_strconcat(home, tmps + 1, NULL);
tmps = tmps2;
}
lastpath = g_list_append(lastpath, tmps);
if(lastchr)
tmps = lastchr + 1;
else
break;
}
lastpath = gimp_path_parse (tmps, 16, FALSE, NULL);
g_free (tmps);
return lastpath;
}