efl/src/lib/eo/eo_base.eo

228 lines
8.5 KiB
Plaintext
Raw Normal View History

abstract Eo.Base ()
2014-03-09 00:31:28 -08:00
{
eo_prefix: eo;
legacy_prefix: null;
2014-03-09 00:31:28 -08:00
properties {
parent {
set {
/*@ Set the parent of an object
Parents keep references to their children so in order to delete objects that have parents you need to set parent to NULL or use eo_del() that does that for you (and also unrefs the object). */
}
get {
/*@ Get the parent of an object */
}
values {
Eo* parent; /*@ the new parent */
}
}
event_global_freeze_count @class {
2014-03-09 00:31:28 -08:00
get {
/*@ return freeze events of object.
Return event freeze count. */
}
values {
int fcount; /*@ The event freeze count of the object */
}
}
event_freeze_count {
2014-03-09 00:31:28 -08:00
get {
/*@ return freeze events of object.
Return event freeze count. */
}
values {
int fcount; /*@ The event freeze count of the object */
}
}
finalized {
/*@ True if the object is already finalized, false otherwise. */
get {
}
values {
bool finalized;
}
}
2014-03-09 00:31:28 -08:00
}
methods {
constructor {
/*@ Call the object's constructor.
Should not be used with #eo_do. Only use it with #eo_do_super. */
}
2014-03-09 00:31:28 -08:00
event_callback_forwarder_del {
/*@ Remove an event callback forwarder for an event and an object. */
params {
@in const(Eo_Event_Description)* desc; /*@ The description of the event to listen to */
2014-03-09 00:31:28 -08:00
@in Eo* new_obj; /*@ The object to emit events from */
}
}
event_thaw {
/*@ thaw events of object.
Lets event callbacks be called for the object. */
}
event_freeze {
/*@ freeze events of object.
Prevents event callbacks from being called for the object. */
}
event_global_freeze @class {
2014-03-09 00:31:28 -08:00
/*@ freeze events of object.
Prevents event callbacks from being called for the object. */
}
event_callback_array_del {
/*@ Del a callback array with a specific data associated to it for an event. */
params {
@in const(Eo_Callback_Array_Item)* array; /*@ an #Eo_Callback_Array_Item of events to listen to */
@in const(void)* user_data; /*@ The data to compare */
2014-03-09 00:31:28 -08:00
}
}
wref_del {
/*@ Delete the weak reference passed. */
params {
@in Eo** wref;
2014-03-09 00:31:28 -08:00
}
}
destructor {
/*@ Call the object's destructor.
Should not be used with #eo_do. Only use it with #eo_do_super. */
}
finalize {
/*@ Called at the end of #eo_add. Should not be called, just overridden. */
return: Eo *; /*@ The new object created, can be NULL if the finalize func decided to abort (though it should free the created object on it's own). */
}
key_data_set {
2014-03-09 00:31:28 -08:00
/*@ Set generic data to object. */
params {
@in const(char)* key; /*@ the key associated with the data */
@in const(void)* data; /*@ the data to set */
2014-04-02 03:42:00 -07:00
@in eo_key_data_free_func free_func; /*@ the func to free data with (NULL means */
2014-03-09 00:31:28 -08:00
}
}
key_data_get {
2014-03-09 00:31:28 -08:00
/*@ Get generic data from object. */
params {
@in const(char)* key; /*@ the key associated with the data */
2014-03-09 00:31:28 -08:00
}
return: void *; /* the data for the key */
2014-03-09 00:31:28 -08:00
}
event_callback_del {
/*@ Del a callback with a specific data associated to it for an event. */
params {
@in const(Eo_Event_Description)* desc; /*@ The description of the event to listen to */
2014-03-09 00:31:28 -08:00
@in Eo_Event_Cb func; /*@ the callback to delete */
@in const(void)* user_data; /*@ The data to compare */
2014-03-09 00:31:28 -08:00
}
}
event_global_thaw @class {
2014-03-09 00:31:28 -08:00
/*@ thaw events of object.
Lets event callbacks be called for the object. */
}
key_data_del {
2014-03-09 00:31:28 -08:00
/*@ Del generic data from object. */
params {
@in const(char)* key; /*@ the key associated with the data */
2014-03-09 00:31:28 -08:00
}
}
event_callback_array_priority_add {
/*@ Add a callback array for an event with a specific priority.
callbacks of the same priority are called in reverse order of creation. */
params {
@in const(Eo_Callback_Array_Item)* array; /*@ an #Eo_Callback_Array_Item of events to listen to */
2014-03-09 00:31:28 -08:00
@in Eo_Callback_Priority priority; /*@ The priority of the callback */
@in const(void)* data; /*@ additional data to pass to the callback */
2014-03-09 00:31:28 -08:00
}
}
wref_add {
/*@ Add a new weak reference to obj.
This function registers the object handle pointed by wref to obj so when obj is deleted it'll be updated to NULL. This functions should be used when you want to keep track of an object in a safe way, but you don't want to prevent it from being freed. */
params {
@out Eo* wref;
2014-03-09 00:31:28 -08:00
}
}
dbg_info_get {
/*@ Get dbg information from the object. */
params {
@in Eo_Dbg_Info* root_node; /*@ node of the tree */
}
}
event_callback_forwarder_add {
/*@ Add an event callback forwarder for an event and an object. */
params {
@in const(Eo_Event_Description)* desc; /*@ The description of the event to listen to */
2014-03-09 00:31:28 -08:00
@in Eo* new_obj; /*@ The object to emit events from */
}
}
event_callback_call {
/*@ Call the callbacks for an event of an object. */
params {
@in const(Eo_Event_Description)* desc; /*@ The description of the event to call */
@in void *event_info; /*@ Extra event info to pass to the callbacks */
2014-03-09 00:31:28 -08:00
}
return: bool; /* @c EINA_TRUE if one of the callbacks aborted the call, @c EINA_FALSE otherwise */
2014-03-09 00:31:28 -08:00
}
event_callback_priority_add {
/*@ Add a callback for an event with a specific priority.
callbacks of the same priority are called in reverse order of creation. */
params {
@in const(Eo_Event_Description)* desc; /*@ The description of the event to listen to */
2014-03-09 00:31:28 -08:00
@in Eo_Callback_Priority priority; /*@ The priority of the callback */
@in Eo_Event_Cb cb; /*@ the callback to call */
@in const(void)* data; /*@ additional data to pass to the callback */
2014-03-09 00:31:28 -08:00
}
}
children_iterator_new {
/*@ Get an iterator on all childrens */
return: free(own(iterator<Eo *> *), eina_iterator_free) @warn_unused;
2014-03-09 00:31:28 -08:00
}
composite_attach @protected { /* XXX: Still BETA! */
/**
* @brief Make an object a composite object of another.
*
* The class of comp_obj must be part of the extensions of the class of the parent.
* It is not possible to attach more then 1 composite of the same class.
* This functions also sets the parent of comp_obj to parent.
*
* @see eo_composite_detach()
* @see eo_composite_part_is()
* @ingroup Eo_Composite_Objects
*/
params {
@in Eo *comp_obj; /*@ the object that will be used to composite the parent. */
}
return: bool; /*@ EINA_TRUE if successfull. EINA_FALSE otherwise. */
}
composite_detach @protected { /* XXX: Still BETA! */
/**
* @brief Detach a composite object from another object.
*
* This functions also sets the parent of comp_obj to @c NULL.
*
* @see eo_composite_attach()
* @see eo_composite_part_is()
* @ingroup Eo_Composite_Objects
*/
params {
@in Eo *comp_obj; /*@ the object that will be removed from the parent. */
}
return: bool; /*@ EINA_TRUE if successfull. EINA_FALSE otherwise. */
}
composite_part_is @protected { /* XXX: Still BETA! */
/**
* @brief Check if an object is part of a composite object.
*
* @see eo_composite_attach()
* @see eo_composite_part_is()
* @ingroup Eo_Composite_Objects
*/
return: bool; /*@ EINA_TRUE if it is. EINA_FALSE otherwise. */
}
2014-03-09 00:31:28 -08:00
}
implements {
class.constructor;
class.destructor;
}
2014-03-09 00:31:28 -08:00
events {
callback,add; /*@ A callback was added. */
callback,del; /*@ A callback was deleted. */
del; /*@ Obj is being deleted. */
}
}