1998-10-30 00:47:54 +00:00
|
|
|
/* Convenience functions for metadata handling in the MIdnight Commander
|
|
|
|
*
|
|
|
|
* Copyright (C) 1998 The Free Software Foundation
|
|
|
|
*
|
|
|
|
* Author: Federico Mena <federico@nuclecu.unam.mx>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <config.h>
|
1998-10-30 17:51:28 +00:00
|
|
|
#include "fs.h"
|
1998-10-30 00:47:54 +00:00
|
|
|
#include <libgnome/libgnome.h>
|
|
|
|
#include "gmetadata.h"
|
1998-10-30 17:51:28 +00:00
|
|
|
#include <sys/stat.h>
|
1998-10-30 17:08:03 +00:00
|
|
|
#include "../vfs/vfs.h"
|
1998-10-30 00:47:54 +00:00
|
|
|
|
|
|
|
|
|
|
|
#define ICON_FILENAME "icon-filename"
|
|
|
|
#define ICON_POSITION "icon-position"
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_get_icon_for_file
|
|
|
|
* @filename: The name of the file to get the icon for.
|
|
|
|
*
|
|
|
|
* Computes the name of the file that holds the icon for the specified file. The
|
|
|
|
* resulting string is guaranteed to be non-NULL. You have to free this string
|
|
|
|
* on your own.
|
|
|
|
*
|
|
|
|
* Returns the icon's file name.
|
|
|
|
*/
|
|
|
|
char *
|
|
|
|
meta_get_icon_for_file (char *filename)
|
|
|
|
{
|
|
|
|
int size;
|
|
|
|
char *buf;
|
|
|
|
struct stat s;
|
|
|
|
int retval;
|
|
|
|
|
1998-10-30 17:08:03 +00:00
|
|
|
g_return_val_if_fail (filename != NULL, NULL);
|
1998-10-30 00:47:54 +00:00
|
|
|
|
|
|
|
if (gnome_metadata_get (filename, ICON_FILENAME, &size, &buf) != 0) {
|
|
|
|
/* Return a default icon */
|
|
|
|
|
|
|
|
retval = mc_stat (filename, &s);
|
|
|
|
|
|
|
|
if (!retval && S_ISDIR (s.st_mode))
|
|
|
|
return gnome_unconditional_pixmap_file ("gnome-folder.png");
|
|
|
|
else
|
|
|
|
return gnome_unconditional_pixmap_file ("gnome-unknown.png");
|
|
|
|
}
|
|
|
|
|
|
|
|
return buf;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
1998-10-30 17:08:03 +00:00
|
|
|
* meta_get_icon_pos
|
1998-10-30 00:47:54 +00:00
|
|
|
* @filename: The file under ~/desktop for which to get the icon position
|
|
|
|
* @x: The x position will be stored here. Must be non-NULL.
|
|
|
|
* @y: The y position will be stored here. Must be non-NULL.
|
|
|
|
*
|
1998-10-30 17:08:03 +00:00
|
|
|
* Checks if the specified file has an icon position associated to it. If so, returns TRUE and
|
|
|
|
* fills in the x and y values. Otherwise it returns FALSE and x and y are not modified.
|
|
|
|
*
|
|
|
|
* Icon position information is expected to be saved using the meta_set_icon_pos() function.
|
1998-10-30 00:47:54 +00:00
|
|
|
*/
|
|
|
|
int
|
1998-10-30 17:08:03 +00:00
|
|
|
meta_get_icon_pos (char *filename, int *x, int *y)
|
1998-10-30 00:47:54 +00:00
|
|
|
{
|
|
|
|
int size;
|
|
|
|
char *buf;
|
|
|
|
int tx, ty;
|
|
|
|
|
|
|
|
g_return_val_if_fail (filename != NULL, FALSE);
|
|
|
|
g_return_val_if_fail (x != NULL, FALSE);
|
|
|
|
g_return_val_if_fail (y != NULL, FALSE);
|
|
|
|
|
|
|
|
if (gnome_metadata_get (filename, ICON_POSITION, &size, &buf) != 0)
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
if (!buf || (sscanf (buf, "%d%d", &tx, &ty) != 2)) {
|
|
|
|
g_warning ("Invalid metadata for \"%s\"'s icon position, using auto-placement", filename);
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
|
|
|
*x = tx;
|
|
|
|
*y = ty;
|
|
|
|
return TRUE;
|
|
|
|
}
|
1998-10-30 17:08:03 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* meta_set_icon_pos
|
|
|
|
* @filename: The file for which to save icon position information
|
|
|
|
* @x: X position of the icon
|
|
|
|
* @y: Y position of the icon
|
|
|
|
*
|
|
|
|
* Saves the icon position information for the specified file. This is expected to be read back
|
|
|
|
* using the meta_get_icon_pos() function.
|
|
|
|
*/
|
|
|
|
void
|
|
|
|
meta_set_icon_pos (char *filename, int x, int y)
|
|
|
|
{
|
|
|
|
char buf[100];
|
|
|
|
|
|
|
|
g_return_if_fail (filename != NULL);
|
|
|
|
|
|
|
|
sprintf (buf, "%d %d", x, y);
|
|
|
|
|
|
|
|
if (gnome_metadata_set (filename, ICON_POSITION, strlen (buf) + 1, buf) != 0)
|
|
|
|
g_warning ("Error setting the icon position metadata for \"%s\"", filename);
|
|
|
|
}
|