gnome-mime-info

Name

gnome-mime-info — Routines to get information bound to a MIME-type.

Synopsis


#include <gnome.h>


const char* gnome_mime_get_value            (const char *mime_type,
                                             char *key);
GList*      gnome_mime_get_keys             (const char *mime_type);
const char* gnome_mime_program              (const char *mime_type);
const char* gnome_mime_description          (const char *mime_type);
const char* gnome_mime_nametemplate         (const char *mime_type);
const char* gnome_mime_test                 (const char *mime_type);
const char* gnome_mime_composetyped         (const char *mime_type);
gboolean    gnome_mime_copiousoutput        (const char *mime_type,
                                             char *key);
gboolean    gnome_mime_needsterminal        (const char *mime_type,
                                             char *key);

Description

The routines in the gnome-mime-info allow retrieval of information that has been bound to a given mime-type. There are a number of standard keys used in GNOME to provide default actions and behaviour.

To add keys to a mime-type, it is necessary to install a file with the extension .keys in the $gnome/share/mime-info directory or in the ~/.gnome/mime-info directory directory. The former is for system-provided mime-information and the later is to enable the user to extend the actions as provided by the system.

The .keys files have the following format:

Example 1-1. Format of a .keys file

mime-type-match:
	[\[LANG\]]key=value
  

Above, the key is the key that is being defined and value is the value we bind to it. The optional [LANG] represents a language in which this definition is valid. If this part is specified, then the definition will only be valid if LANG matches the setting of the environment variable LANG. The LANG setting is used to provide keys which can be displayed to the user in a localized way.

This is an example to bind the key open to all of the mime-types matching image/* and the icon-filename key is bound to the /opt/gimp/share/xcf.png value:

Example 1-2. Sample gimp.keys file

image/*:
	open=gimp f

image/x-xcf:
        icon-filename=/opt/gimp/share/xcf.png
  

This will make the GIMP the handler for the open action. Files of type xcf would use the filename pointed in the icon-filename key.

f gets interpolated with the file name or the list of file names that matched this mime-type.

As you can see from the example above, a .keys file does not need to provide all of the values, it can just provide or override some of the actions.

User defined bindings in .keys file will take precedence over system installed files.

The following keys are currently used in the GNOME desktop:

Those keys are also queried on the metadata (except in the cases where the lookup would be too expensive).

Details


gnome_mime_get_value()

const char* gnome_mime_get_value            (const char *mime_type,
                                             char *key);

mime_type : key : Returns


gnome_mime_get_keys()

GList*      gnome_mime_get_keys             (const char *mime_type);

mime_type : the mime type to lookup.Returns :a GList that contains private strings with all of the keys associated with the mime_type.


gnome_mime_program()

const char* gnome_mime_program              (const char *mime_type);

mime_type : the mime_type Returns :the program intended to be loaded for this given mime-type


gnome_mime_description()

const char* gnome_mime_description          (const char *mime_type);

mime_type : the mime typeReturns :the description for this mime-type


gnome_mime_nametemplate()

const char* gnome_mime_nametemplate         (const char *mime_type);

mime_type : Returns


gnome_mime_test()

const char* gnome_mime_test                 (const char *mime_type);

mime_type : the mime typeReturns :the command to be executed on the file before considering the file to match this mime_type.


gnome_mime_composetyped()

const char* gnome_mime_composetyped         (const char *mime_type);

mime_type : the mime typeReturns :the command to be executed to compose a message of the given mime_type


gnome_mime_copiousoutput()

gboolean    gnome_mime_copiousoutput        (const char *mime_type,
                                             char *key);

mime_type : the mime typekey : the key used to open the command.Returns :a boolean value, whether the mime_type open command will produce lots of output


gnome_mime_needsterminal()

gboolean    gnome_mime_needsterminal        (const char *mime_type,
                                             char *key);

mime_type : the mime typekey : the key used to open the command.Returns :a boolean value, whether the mime_type open command will required a terminal.