/usr/include/elementary-1/elm_widget_prefs.h is in libelementary-dev 1.8.5-2.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 | #ifndef ELM_WIDGET_PREFS_H
#define ELM_WIDGET_PREFS_H
#include "Elementary.h"
/**
* @addtogroup Widget
* @{
*
* @section elm-prefs-class The Elementary Prefs Class
*
* Elementary, besides having the @ref Prefs widget, exposes its
* foundation -- the Elementary Prefs Class -- in order to create
* other widgets which are a prefs with some more logic on top.
*/
typedef struct _Elm_Prefs_Page_Node
{
unsigned int version;
/* not to be serialized */
Evas_Object *prefs;
Evas_Object *parent;
Evas_Object *w_obj;
const Elm_Prefs_Page_Iface *w_impl;
const char *name;
const char *title;
const char *sub_title;
const char *widget;
const char *style;
const char *icon;
Eina_List *items;
Eina_Bool autosave;
} Elm_Prefs_Page_Node;
typedef struct _Elm_Prefs_Item_Node
{
Elm_Prefs_Item_Type type;
/* not to be serialized */
Evas_Object *prefs;
Elm_Prefs_Page_Node *page;
Elm_Prefs_Page_Node *subpage; /* page item type only */
Evas_Object *w_obj;
const Elm_Prefs_Item_Iface *w_impl;
Eina_Bool available;
const char *name;
const char *label;
const char *icon;
const char *style;
const char *widget;
Elm_Prefs_Item_Spec spec;
Eina_Bool persistent;
Eina_Bool editable;
Eina_Bool visible;
} Elm_Prefs_Item_Node;
/**
* Base widget smart data extended with prefs instance data.
*/
typedef struct _Elm_Prefs_Smart_Data Elm_Prefs_Smart_Data;
struct _Elm_Prefs_Smart_Data
{
Elm_Prefs_Page_Node *root;
Elm_Prefs_Data *prefs_data;
const char *file;
const char *page;
Ecore_Poller *saving_poller;
Eina_Bool changing_from_ui : 1;
Eina_Bool values_fetching : 1;
Eina_Bool delete_me : 1;
Eina_Bool autosave : 1;
Eina_Bool dirty : 1;
};
/**
* @}
*/
extern const Eina_Hash *elm_prefs_item_widgets_map;
extern const Eina_Hash *elm_prefs_item_type_widgets_map;
extern const Elm_Prefs_Item_Iface *elm_prefs_item_default_widget;
#define ELM_PREFS_DATA_GET(o, sd) \
Elm_Prefs_Smart_Data * sd = eo_data_scope_get(o, ELM_OBJ_PREFS_CLASS)
#define ELM_PREFS_ENTRY(o, sd) \
if (!sd->data_file || !sd->page) \
{ \
CRITICAL("You must issue elm_prefs_file_set() on this widget before" \
" you make this call"); \
} \
return
#define ELM_PREFS_DATA_GET_OR_RETURN(o, ptr) \
ELM_PREFS_DATA_GET(o, ptr); \
if (!ptr) \
{ \
CRITICAL("No widget data for object %p (%s)", \
o, evas_object_type_get(o)); \
return; \
}
#define ELM_PREFS_DATA_GET_OR_RETURN_VAL(o, ptr, val) \
ELM_PREFS_DATA_GET(o, ptr); \
if (!ptr) \
{ \
CRITICAL("No widget data for object %p (%s)", \
o, evas_object_type_get(o)); \
return val; \
}
#define ELM_PREFS_CHECK(obj) \
if (!eo_isa((obj), ELM_OBJ_PREFS_CLASS)) \
return
#endif
|