2015-01-28 14:47:39 +00:00
|
|
|
/**************************************************************************
|
|
|
|
* Copyright (C) 2015 (mrovi9000@gmail.com)
|
|
|
|
*
|
|
|
|
**************************************************************************/
|
|
|
|
|
|
|
|
#ifndef ICON_THEME_COMMON_H
|
|
|
|
#define ICON_THEME_COMMON_H
|
|
|
|
|
|
|
|
#include <glib.h>
|
|
|
|
|
|
|
|
typedef struct IconThemeWrapper {
|
2016-02-29 22:44:00 +00:00
|
|
|
// The icon theme name for which this wrapper was created
|
|
|
|
char *icon_theme_name;
|
2015-01-28 14:47:39 +00:00
|
|
|
// List of IconTheme*
|
|
|
|
GSList *themes;
|
2016-02-29 22:44:00 +00:00
|
|
|
// Themes are loaded lazily when needed.
|
|
|
|
gboolean _themes_loaded;
|
2015-01-28 14:47:39 +00:00
|
|
|
// List of IconTheme*
|
|
|
|
GSList *themes_fallback;
|
2016-02-29 22:44:00 +00:00
|
|
|
// Fallback themes are loaded lazily when needed.
|
2016-02-28 14:41:50 +00:00
|
|
|
gboolean _fallback_loaded;
|
2016-02-29 22:44:00 +00:00
|
|
|
GHashTable *_cache;
|
|
|
|
gboolean _cache_dirty;
|
|
|
|
// List of icon theme names that have been queued for loading.
|
|
|
|
// Used to avoid loading the same theme twice, and to avoid cycles.
|
|
|
|
GSList *_queued;
|
2015-01-28 14:47:39 +00:00
|
|
|
} IconThemeWrapper;
|
|
|
|
|
|
|
|
typedef struct IconTheme {
|
|
|
|
char *name;
|
2016-02-28 12:06:50 +00:00
|
|
|
char *description;
|
2015-11-20 22:28:37 +00:00
|
|
|
GSList *list_inherits; // each item is a char* (theme name)
|
2015-01-28 14:47:39 +00:00
|
|
|
GSList *list_directories; // each item is an IconThemeDir*
|
|
|
|
} IconTheme;
|
|
|
|
|
|
|
|
// Parses a line of the form "key = value". Modifies the line.
|
|
|
|
// Returns 1 if successful, and parts are not empty.
|
|
|
|
// Key and value point to the parts.
|
|
|
|
int parse_theme_line(char *line, char **key, char **value);
|
|
|
|
|
|
|
|
// Returns an IconThemeWrapper* containing the icon theme identified by the name icon_theme_name, all the
|
|
|
|
// inherited themes, the hicolor theme and possibly fallback themes.
|
|
|
|
IconThemeWrapper *load_themes(const char *icon_theme_name);
|
|
|
|
|
2016-02-29 22:44:00 +00:00
|
|
|
void save_icon_cache(IconThemeWrapper *wrapper);
|
|
|
|
|
|
|
|
void free_themes(IconThemeWrapper *wrapper);
|
2016-02-28 12:06:50 +00:00
|
|
|
void free_icon_theme(IconTheme *theme);
|
2015-01-28 14:47:39 +00:00
|
|
|
|
|
|
|
#define DEFAULT_ICON "application-x-executable"
|
|
|
|
|
|
|
|
// Returns the full path to an icon file (or NULL) given the list of icon themes to search and the icon name
|
|
|
|
// Note: needs to be released with free().
|
2016-02-29 22:44:00 +00:00
|
|
|
char *get_icon_path(IconThemeWrapper *wrapper, const char *icon_name, int size);
|
2015-01-28 14:47:39 +00:00
|
|
|
|
|
|
|
// Returns a list of the directories used to store icons.
|
|
|
|
// Do not free the result, it is cached.
|
|
|
|
const GSList *get_icon_locations();
|
|
|
|
|
|
|
|
#endif
|