2003-09-23 01:09:32 -07:00
# ifndef _ECORE_H
# define _ECORE_H
2010-04-05 01:26:48 -07:00
# ifdef _MSC_VER
# include <Evil.h>
# endif
2009-08-04 02:13:49 -07:00
# include <Eina.h>
2004-11-24 21:18:31 -08:00
# ifdef EAPI
2008-05-25 22:16:34 -07:00
# undef EAPI
2004-11-24 21:18:31 -08:00
# endif
2008-05-25 22:16:34 -07:00
# ifdef _WIN32
# ifdef EFL_ECORE_BUILD
# ifdef DLL_EXPORT
# define EAPI __declspec(dllexport)
# else
# define EAPI
# endif /* ! DLL_EXPORT */
2004-11-24 21:18:31 -08:00
# else
# define EAPI __declspec(dllimport)
2008-05-25 22:16:34 -07:00
# endif /* ! EFL_ECORE_BUILD */
2004-11-24 21:18:31 -08:00
# else
2005-12-27 09:17:31 -08:00
# ifdef __GNUC__
# if __GNUC__ >= 4
# define EAPI __attribute__ ((visibility("default")))
# else
# define EAPI
# endif
2004-11-24 21:18:31 -08:00
# else
# define EAPI
# endif
2008-05-25 22:16:34 -07:00
# endif /* ! _WIN32 */
2004-11-24 21:18:31 -08:00
2004-04-29 20:10:17 -07:00
/**
* @ file Ecore . h
* @ brief The file that provides the program utility , main loop and timer
* functions .
*
2004-09-22 01:17:15 -07:00
* This header provides the Ecore event handling loop . For more
* details , see @ ref Ecore_Main_Loop_Group .
*
* For the main loop to be of any use , you need to be able to add events
2004-09-22 21:05:13 -07:00
* and event handlers . Events for file descriptor events are covered in
* @ ref Ecore_FD_Handler_Group .
2004-09-22 01:17:15 -07:00
*
2004-09-22 21:58:16 -07:00
* Time functions are covered in @ ref Ecore_Time_Group .
*
2004-09-22 01:17:15 -07:00
* There is also provision for callbacks for when the loop enters or
* exits an idle state . See @ ref Idle_Group for more information .
*
* Functions are also provided for spawning child processes using fork .
* See @ ref Ecore_Exe_Basic_Group and @ ref Ecore_Exe_Signal_Group for
* more details .
2004-04-29 20:10:17 -07:00
*/
2009-04-16 10:12:40 -07:00
# ifdef _WIN32
# include <winsock2.h>
2009-10-25 07:48:12 -07:00
# elif (defined (__FreeBSD__) && (__FreeBSD_version >= 420001)) || defined (__OpenBSD__)
2009-07-28 02:58:12 -07:00
# include <sys / select.h>
2009-11-07 11:10:08 -08:00
# include <signal.h>
2009-04-16 10:12:40 -07:00
# else
2009-06-12 08:23:32 -07:00
# include <sys / time.h>
2009-04-16 10:12:40 -07:00
# include <signal.h>
2006-01-09 05:36:22 -08:00
# endif
2010-02-06 14:14:32 -08:00
2009-10-25 00:07:48 -07:00
# include <sys/types.h>
2004-03-17 21:29:54 -08:00
2005-04-14 18:22:46 -07:00
# ifdef __cplusplus
extern " C " {
# endif
2010-08-16 01:17:24 -07:00
# define ECORE_VERSION_MAJOR 1
# define ECORE_VERSION_MINOR 0
2010-05-28 23:37:02 -07:00
typedef struct _Ecore_Version
{
int major ;
int minor ;
int micro ;
int revision ;
} Ecore_Version ;
EAPI extern Ecore_Version * ecore_version ;
2010-06-24 09:15:56 -07:00
# define ECORE_CALLBACK_CANCEL EINA_FALSE /**< Return value to remove a callback */
# define ECORE_CALLBACK_RENEW EINA_TRUE /**< Return value to keep a callback */
# define ECORE_CALLBACK_PASS_ON EINA_TRUE /**< Return value to pass event to next handler */
# define ECORE_CALLBACK_DONE EINA_FALSE /**< Return value to stop event handling */
2008-01-25 10:28:16 -08:00
2005-10-24 01:53:50 -07:00
# define ECORE_EVENT_NONE 0
2006-01-13 05:18:36 -08:00
# define ECORE_EVENT_SIGNAL_USER 1 /**< User signal event */
# define ECORE_EVENT_SIGNAL_HUP 2 /**< Hup signal event */
# define ECORE_EVENT_SIGNAL_EXIT 3 /**< Exit signal event */
# define ECORE_EVENT_SIGNAL_POWER 4 /**< Power signal event */
# define ECORE_EVENT_SIGNAL_REALTIME 5 /**< Realtime signal event */
# define ECORE_EVENT_COUNT 6
2008-11-01 18:29:08 -07:00
# define ECORE_EXE_PRIORITY_INHERIT 9999
2006-01-13 05:18:36 -08:00
EAPI extern int ECORE_EXE_EVENT_ADD ; /**< A child process has been added */
2010-09-08 04:23:42 -07:00
EAPI extern int ECORE_EXE_EVENT_DEL ; /**< A child process has been deleted (it exited, naming consistent with the rest of ecore). */
2006-01-13 05:18:36 -08:00
EAPI extern int ECORE_EXE_EVENT_DATA ; /**< Data from a child process. */
EAPI extern int ECORE_EXE_EVENT_ERROR ; /**< Errors from a child process. */
2006-01-12 20:31:41 -08:00
2003-09-23 01:09:32 -07:00
enum _Ecore_Fd_Handler_Flags
{
2010-09-29 23:09:20 -07:00
ECORE_FD_READ = 1 , /**< Fd Read mask */
ECORE_FD_WRITE = 2 , /**< Fd Write mask */
ECORE_FD_ERROR = 4 /**< Fd Error mask */
2003-09-23 01:09:32 -07:00
} ;
typedef enum _Ecore_Fd_Handler_Flags Ecore_Fd_Handler_Flags ;
2007-08-26 04:17:21 -07:00
2005-12-24 04:22:47 -08:00
enum _Ecore_Exe_Flags /* flags for executing a child with its stdin and/or stdout piped back */
2005-10-24 01:53:50 -07:00
{
2010-09-29 23:09:20 -07:00
ECORE_EXE_PIPE_READ = 1 , /**< Exe Pipe Read mask */
ECORE_EXE_PIPE_WRITE = 2 , /**< Exe Pipe Write mask */
ECORE_EXE_PIPE_ERROR = 4 , /**< Exe Pipe error mask */
ECORE_EXE_PIPE_READ_LINE_BUFFERED = 8 , /**< Reads are buffered until a newline and delivered 1 event per line */
ECORE_EXE_PIPE_ERROR_LINE_BUFFERED = 16 , /**< Errors are buffered until a newline and delivered 1 event per line */
ECORE_EXE_PIPE_AUTO = 32 , /**< stdout and stderr are buffered automatically */
ECORE_EXE_RESPAWN = 64 , /**< FIXME: Exe is restarted if it dies */
ECORE_EXE_USE_SH = 128 , /**< Use /bin/sh to run the command. */
ECORE_EXE_NOT_LEADER = 256 /**< Do not use setsid() to have the executed process be its own session leader */
2005-10-24 01:53:50 -07:00
} ;
typedef enum _Ecore_Exe_Flags Ecore_Exe_Flags ;
2007-08-26 04:17:21 -07:00
2010-02-20 01:20:04 -08:00
enum _Ecore_Exe_Win32_Priority
{
ECORE_EXE_WIN32_PRIORITY_IDLE , /**< Idle priority, for monitoring the system */
ECORE_EXE_WIN32_PRIORITY_BELOW_NORMAL , /**< Below default priority */
ECORE_EXE_WIN32_PRIORITY_NORMAL , /**< Default priority */
ECORE_EXE_WIN32_PRIORITY_ABOVE_NORMAL , /**< Above default priority */
ECORE_EXE_WIN32_PRIORITY_HIGH , /**< High priority, use with care as other threads in the system will not get processor time */
ECORE_EXE_WIN32_PRIORITY_REALTIME /**< Realtime priority, should be almost never used as it can interrupt system threads that manage mouse input, keyboard input, and background disk flushing */
} ;
typedef enum _Ecore_Exe_Win32_Priority Ecore_Exe_Win32_Priority ;
2008-01-10 23:33:57 -08:00
enum _Ecore_Poller_Type /* Poller types */
{
2010-09-29 23:09:20 -07:00
ECORE_POLLER_CORE = 0 /**< The core poller interval */
2008-01-10 23:33:57 -08:00
} ;
typedef enum _Ecore_Poller_Type Ecore_Poller_Type ;
2008-05-25 22:31:20 -07:00
2009-12-22 13:15:12 -08:00
typedef struct _Ecore_Exe Ecore_Exe ; /**< A handle for spawned processes */
typedef struct _Ecore_Timer Ecore_Timer ; /**< A handle for timers */
typedef struct _Ecore_Idler Ecore_Idler ; /**< A handle for idlers */
typedef struct _Ecore_Idle_Enterer Ecore_Idle_Enterer ; /**< A handle for idle enterers */
typedef struct _Ecore_Idle_Exiter Ecore_Idle_Exiter ; /**< A handle for idle exiters */
typedef struct _Ecore_Fd_Handler Ecore_Fd_Handler ; /**< A handle for Fd handlers */
typedef struct _Ecore_Win32_Handler Ecore_Win32_Handler ; /**< A handle for HANDLE handlers on Windows */
typedef struct _Ecore_Event_Handler Ecore_Event_Handler ; /**< A handle for an event handler */
typedef struct _Ecore_Event_Filter Ecore_Event_Filter ; /**< A handle for an event filter */
typedef struct _Ecore_Event Ecore_Event ; /**< A handle for an event */
typedef struct _Ecore_Animator Ecore_Animator ; /**< A handle for animators */
typedef struct _Ecore_Pipe Ecore_Pipe ; /**< A handle for pipes */
typedef struct _Ecore_Poller Ecore_Poller ; /**< A handle for pollers */
2005-10-24 01:53:50 -07:00
typedef struct _Ecore_Event_Signal_User Ecore_Event_Signal_User ; /**< User signal event */
typedef struct _Ecore_Event_Signal_Hup Ecore_Event_Signal_Hup ; /**< Hup signal event */
typedef struct _Ecore_Event_Signal_Exit Ecore_Event_Signal_Exit ; /**< Exit signal event */
typedef struct _Ecore_Event_Signal_Power Ecore_Event_Signal_Power ; /**< Power signal event */
2004-04-04 12:53:19 -07:00
typedef struct _Ecore_Event_Signal_Realtime Ecore_Event_Signal_Realtime ; /**< Realtime signal event */
2006-01-15 03:27:19 -08:00
typedef struct _Ecore_Exe_Event_Add Ecore_Exe_Event_Add ; /**< Spawned Exe add event */
typedef struct _Ecore_Exe_Event_Del Ecore_Exe_Event_Del ; /**< Spawned Exe exit event */
typedef struct _Ecore_Exe_Event_Data_Line Ecore_Exe_Event_Data_Line ; /**< Lines from a child process */
typedef struct _Ecore_Exe_Event_Data Ecore_Exe_Event_Data ; /**< Data from a child process */
2009-11-06 14:15:04 -08:00
typedef struct _Ecore_Thread Ecore_Thread ;
2010-08-03 19:55:20 -07:00
/**
* @ typedef Ecore_Data_Cb Ecore_Data_Cb
* A callback which is used to return data to the main function
*/
typedef void * ( * Ecore_Data_Cb ) ( void * data ) ;
/**
* @ typedef Ecore_Filter_Cb
* A callback used for filtering events from the main loop .
*/
typedef Eina_Bool ( * Ecore_Filter_Cb ) ( void * data , void * loop_data , int type , void * event ) ;
/**
* @ typedef Ecore_Eselect_Function Ecore_Eselect_Function
* A function which can be used to replace select ( ) in the main loop
*/
typedef int ( * Ecore_Select_Function ) ( int nfds , fd_set * readfds , fd_set * writefds , fd_set * exceptfds , struct timeval * timeout ) ;
/**
* @ typedef Ecore_End_Cb Ecore_End_Cb
* This is the callback which is called at the end of a function , usually for cleanup purposes .
*/
typedef void ( * Ecore_End_Cb ) ( void * user_data , void * func_data ) ;
/**
* @ typedef Ecore_Pipe_Cb Ecore_Pipe_Cb
* The callback that data written to the pipe is sent to .
*/
typedef void ( * Ecore_Pipe_Cb ) ( void * data , void * buffer , unsigned int nbyte ) ;
/**
* @ typedef Ecore_Exe_Cb Ecore_Exe_Cb
* A callback to run with the associated @ ref Ecore_Exe , usually for cleanup purposes .
*/
typedef void ( * Ecore_Exe_Cb ) ( void * data , const Ecore_Exe * exe ) ;
/**
* @ typedef Ecore_Event_Handler_Cb Ecore_Event_Handler_Cb
* A callback used by the main loop to handle events of a specified type .
*/
typedef Eina_Bool ( * Ecore_Event_Handler_Cb ) ( void * data , int type , void * event ) ;
/**
* @ typedef Ecore_Thread_Heavy_Cb Ecore_Thread_Heavy_Cb
* A callback used to run cpu intensive or blocking I / O operations .
*/
2010-07-26 00:19:27 -07:00
typedef void ( * Ecore_Thread_Heavy_Cb ) ( Ecore_Thread * thread , void * data ) ;
2010-08-03 19:55:20 -07:00
/**
* @ typedef Ecore_Thread_Notify_Cb Ecore_Thread_Notify_Cb
* A callback used by the main loop to receive data sent by an @ ref Ecore_Thread .
*/
2010-07-26 00:19:27 -07:00
typedef void ( * Ecore_Thread_Notify_Cb ) ( Ecore_Thread * thread , void * msg_data , void * data ) ;
2010-08-03 19:55:20 -07:00
/**
* @ typedef Ecore_Task_Cb Ecore_Task_Cb
* A callback run for a task ( timer , idler , poller , animater , etc )
*/
typedef Eina_Bool ( * Ecore_Task_Cb ) ( void * data ) ;
/**
* @ typedef Ecore_Cb Ecore_Cb
* A generic callback called as a hook when a certain point in execution is reached .
*/
typedef void ( * Ecore_Cb ) ( void * data ) ;
/**
* @ typedef Ecore_Fd_Cb Ecore_Fd_Cb
* A callback used by an @ ref Ecore_Fd_Handler .
*/
typedef Eina_Bool ( * Ecore_Fd_Cb ) ( void * data , Ecore_Fd_Handler * fd_handler ) ;
/**
* @ typedef Ecore_Fd_Prep_Cb Ecore_Fd_Prep_Cb
* A callback used by an @ ref Ecore_Fd_Handler .
*/
typedef void ( * Ecore_Fd_Prep_Cb ) ( void * data , Ecore_Fd_Handler * fd_handler ) ;
/**
* @ typedef Ecore_Fd_Win32_Cb Ecore_Fd_Win32_Cb
* A callback used by an @ ref Ecore_Win32_Handler .
*/
typedef Eina_Bool ( * Ecore_Fd_Win32_Cb ) ( void * data , Ecore_Win32_Handler * wh ) ;
2010-07-25 21:20:18 -07:00
2003-09-23 01:09:32 -07:00
2010-01-25 13:59:21 -08:00
typedef struct _Ecore_Job Ecore_Job ; /**< A job handle */
2003-09-23 01:09:32 -07:00
struct _Ecore_Event_Signal_User /** User signal event */
{
2010-09-29 23:09:20 -07:00
int number ; /**< The signal number. Either 1 or 2 */
void * ext_data ; /**< Extension data - not used */
2004-10-20 10:51:29 -07:00
2007-08-26 04:17:21 -07:00
# ifndef _WIN32
2010-09-29 23:09:20 -07:00
siginfo_t data ; /**< Signal info */
2004-10-20 10:51:29 -07:00
# endif
2003-09-23 01:09:32 -07:00
} ;
2007-08-26 04:17:21 -07:00
2003-09-23 01:09:32 -07:00
struct _Ecore_Event_Signal_Hup /** Hup signal event */
{
2010-09-29 23:09:20 -07:00
void * ext_data ; /**< Extension data - not used */
2004-10-20 10:51:29 -07:00
2007-08-26 04:17:21 -07:00
# ifndef _WIN32
2010-09-29 23:09:20 -07:00
siginfo_t data ; /**< Signal info */
2004-10-20 10:51:29 -07:00
# endif
2003-09-23 01:09:32 -07:00
} ;
2007-08-26 04:17:21 -07:00
2003-09-23 01:09:32 -07:00
struct _Ecore_Event_Signal_Exit /** Exit request event */
{
2010-09-29 23:09:20 -07:00
unsigned int interrupt : 1 ; /**< Set if the exit request was an interrupt signal*/
unsigned int quit : 1 ; /**< set if the exit request was a quit signal */
unsigned int terminate : 1 ; /**< Set if the exit request was a terminate singal */
void * ext_data ; /**< Extension data - not used */
2004-10-20 10:51:29 -07:00
2007-08-26 04:17:21 -07:00
# ifndef _WIN32
2010-09-29 23:09:20 -07:00
siginfo_t data ; /**< Signal info */
2004-10-20 10:51:29 -07:00
# endif
2003-09-23 01:09:32 -07:00
} ;
struct _Ecore_Event_Signal_Power /** Power event */
{
2010-09-29 23:09:20 -07:00
void * ext_data ; /**< Extension data - not used */
2004-10-20 10:51:29 -07:00
2007-08-26 04:17:21 -07:00
# ifndef _WIN32
2010-09-29 23:09:20 -07:00
siginfo_t data ; /**< Signal info */
2004-10-20 10:51:29 -07:00
# endif
2004-04-04 12:53:19 -07:00
} ;
struct _Ecore_Event_Signal_Realtime /** Realtime event */
{
2010-09-29 23:09:20 -07:00
int num ; /**< The realtime signal's number */
2004-10-20 10:51:29 -07:00
2007-08-26 04:17:21 -07:00
# ifndef _WIN32
2010-09-29 23:09:20 -07:00
siginfo_t data ; /**< Signal info */
2004-10-20 10:51:29 -07:00
# endif
2003-09-23 01:09:32 -07:00
} ;
2006-01-15 03:27:19 -08:00
struct _Ecore_Exe_Event_Add /** Process add event */
{
2010-09-29 23:09:20 -07:00
Ecore_Exe * exe ; /**< The handle to the added process */
void * ext_data ; /**< Extension data - not used */
2006-01-15 03:27:19 -08:00
} ;
struct _Ecore_Exe_Event_Del /** Process exit event */
{
2010-09-29 23:09:20 -07:00
pid_t pid ; /**< The process ID of the process that exited */
int exit_code ; /**< The exit code of the process */
Ecore_Exe * exe ; /**< The handle to the exited process, or NULL if not found */
int exit_signal ; /** < The signal that caused the process to exit */
unsigned int exited : 1 ; /** < set to 1 if the process exited of its own accord */
unsigned int signalled : 1 ; /** < set to 1 id the process exited due to uncaught signal */
void * ext_data ; /**< Extension data - not used */
2009-11-08 14:19:30 -08:00
# ifndef _WIN32
2010-09-29 23:09:20 -07:00
siginfo_t data ; /**< Signal info */
2009-11-08 14:19:30 -08:00
# endif
2006-01-15 03:27:19 -08:00
} ;
struct _Ecore_Exe_Event_Data_Line /**< Lines from a child process */
2005-12-15 17:11:24 -08:00
{
char * line ;
2010-09-29 23:09:20 -07:00
int size ;
2005-12-15 17:11:24 -08:00
} ;
2006-01-15 03:27:19 -08:00
struct _Ecore_Exe_Event_Data /** Data from a child process event */
2005-10-24 01:53:50 -07:00
{
2010-09-29 23:09:20 -07:00
Ecore_Exe * exe ; /**< The handle to the process */
void * data ; /**< the raw binary data from the child process that was received */
int size ; /**< the size of this data in bytes */
Ecore_Exe_Event_Data_Line * lines ; /**< an array of line data if line buffered, the last one has it's line member set to NULL */
2005-10-24 01:53:50 -07:00
} ;
2007-08-26 04:17:21 -07:00
2004-11-24 21:18:31 -08:00
EAPI int ecore_init ( void ) ;
EAPI int ecore_shutdown ( void ) ;
2007-08-26 04:17:21 -07:00
2004-11-24 21:18:31 -08:00
EAPI void ecore_app_args_set ( int argc , const char * * argv ) ;
EAPI void ecore_app_args_get ( int * argc , char * * * argv ) ;
EAPI void ecore_app_restart ( void ) ;
2010-08-03 19:55:20 -07:00
EAPI Ecore_Event_Handler * ecore_event_handler_add ( int type , Ecore_Event_Handler_Cb func , const void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_event_handler_del ( Ecore_Event_Handler * event_handler ) ;
2010-08-03 19:55:20 -07:00
EAPI Ecore_Event * ecore_event_add ( int type , void * ev , Ecore_End_Cb func_free , void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_event_del ( Ecore_Event * event ) ;
EAPI int ecore_event_type_new ( void ) ;
2010-08-03 19:55:20 -07:00
EAPI Ecore_Event_Filter * ecore_event_filter_add ( Ecore_Data_Cb func_start , Ecore_Filter_Cb func_filter , Ecore_End_Cb func_end , const void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_event_filter_del ( Ecore_Event_Filter * ef ) ;
EAPI int ecore_event_current_type_get ( void ) ;
EAPI void * ecore_event_current_event_get ( void ) ;
2007-08-26 04:17:21 -07:00
2008-11-01 18:29:08 -07:00
EAPI void ecore_exe_run_priority_set ( int pri ) ;
EAPI int ecore_exe_run_priority_get ( void ) ;
2005-09-28 06:09:09 -07:00
EAPI Ecore_Exe * ecore_exe_run ( const char * exe_cmd , const void * data ) ;
2005-10-24 01:53:50 -07:00
EAPI Ecore_Exe * ecore_exe_pipe_run ( const char * exe_cmd , Ecore_Exe_Flags flags , const void * data ) ;
2010-08-03 19:55:20 -07:00
EAPI void ecore_exe_callback_pre_free_set ( Ecore_Exe * exe , Ecore_Exe_Cb func ) ;
2010-01-05 21:16:59 -08:00
EAPI Eina_Bool ecore_exe_send ( Ecore_Exe * exe , const void * data , int size ) ;
2006-01-04 12:53:07 -08:00
EAPI void ecore_exe_close_stdin ( Ecore_Exe * exe ) ;
2006-01-16 05:21:52 -08:00
EAPI void ecore_exe_auto_limits_set ( Ecore_Exe * exe , int start_bytes , int end_bytes , int start_lines , int end_lines ) ;
EAPI Ecore_Exe_Event_Data * ecore_exe_event_data_get ( Ecore_Exe * exe , Ecore_Exe_Flags flags ) ;
EAPI void ecore_exe_event_data_free ( Ecore_Exe_Event_Data * data ) ;
2005-09-28 06:09:09 -07:00
EAPI void * ecore_exe_free ( Ecore_Exe * exe ) ;
2010-01-05 21:16:59 -08:00
EAPI pid_t ecore_exe_pid_get ( const Ecore_Exe * exe ) ;
2005-09-28 06:09:09 -07:00
EAPI void ecore_exe_tag_set ( Ecore_Exe * exe , const char * tag ) ;
2010-01-05 21:16:59 -08:00
EAPI const char * ecore_exe_tag_get ( const Ecore_Exe * exe ) ;
EAPI const char * ecore_exe_cmd_get ( const Ecore_Exe * exe ) ;
EAPI void * ecore_exe_data_get ( const Ecore_Exe * exe ) ;
EAPI Ecore_Exe_Flags ecore_exe_flags_get ( const Ecore_Exe * exe ) ;
2005-09-28 06:09:09 -07:00
EAPI void ecore_exe_pause ( Ecore_Exe * exe ) ;
EAPI void ecore_exe_continue ( Ecore_Exe * exe ) ;
2008-07-29 15:07:19 -07:00
EAPI void ecore_exe_interrupt ( Ecore_Exe * exe ) ;
EAPI void ecore_exe_quit ( Ecore_Exe * exe ) ;
2005-09-28 06:09:09 -07:00
EAPI void ecore_exe_terminate ( Ecore_Exe * exe ) ;
EAPI void ecore_exe_kill ( Ecore_Exe * exe ) ;
EAPI void ecore_exe_signal ( Ecore_Exe * exe , int num ) ;
EAPI void ecore_exe_hup ( Ecore_Exe * exe ) ;
2007-08-26 04:17:21 -07:00
2010-08-03 19:55:20 -07:00
EAPI Ecore_Idler * ecore_idler_add ( Ecore_Task_Cb func , const void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_idler_del ( Ecore_Idler * idler ) ;
2007-08-26 04:17:21 -07:00
2010-08-03 19:55:20 -07:00
EAPI Ecore_Idle_Enterer * ecore_idle_enterer_add ( Ecore_Task_Cb func , const void * data ) ;
EAPI Ecore_Idle_Enterer * ecore_idle_enterer_before_add ( Ecore_Task_Cb func , const void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_idle_enterer_del ( Ecore_Idle_Enterer * idle_enterer ) ;
2010-08-03 19:55:20 -07:00
EAPI Ecore_Idle_Exiter * ecore_idle_exiter_add ( Ecore_Task_Cb func , const void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_idle_exiter_del ( Ecore_Idle_Exiter * idle_exiter ) ;
EAPI void ecore_main_loop_iterate ( void ) ;
2009-04-16 08:44:26 -07:00
2010-08-03 19:55:20 -07:00
EAPI void ecore_main_loop_select_func_set ( Ecore_Select_Function func ) ;
2009-04-16 08:44:26 -07:00
EAPI void * ecore_main_loop_select_func_get ( void ) ;
welcome glib main loop integration support.
that's it, it's here... tested and works fine, please try with your
favorite gmainloop dependent library and report problems. Suggestions:
* GConf to access Gnome and its applications settings.
* GtkSettings to access other properties of Gnome and its applications.
* GUPnP (okay, we have EUPnP, but they have more features so far)
* Rygel, based on GUPnP.
* Libsoup, SOAP and HTTP access, useful for web access and required
by other libraries.
* Mojito, by Moblin, access to various web2.0 services like flickr,
picasa, twitter...
And last but not least, this enables Flash plugin on WebKit-EFL and
may enable us to get Google Gadgets sooner (before someone writes a
proper EFL backend).
Support is auto-detected at compile time but can be disabled with
--disable-glib. Runtime support is not enabled by default (so
compiling with it will just link yet another library), one needs to
call ecore_main_loop_glib_integrate() to do so.
Thanks to INdT folks that provided the initial implementation. I
rewrote it to make it correct, but the idea was good.
SVN revision: 42825
2009-09-30 20:56:38 -07:00
EAPI Eina_Bool ecore_main_loop_glib_integrate ( void ) ;
2010-03-21 20:30:40 -07:00
EAPI void ecore_main_loop_glib_always_integrate_disable ( void ) ;
2004-11-24 21:18:31 -08:00
EAPI void ecore_main_loop_begin ( void ) ;
EAPI void ecore_main_loop_quit ( void ) ;
2010-08-03 19:55:20 -07:00
EAPI Ecore_Fd_Handler * ecore_main_fd_handler_add ( int fd , Ecore_Fd_Handler_Flags flags , Ecore_Fd_Cb func , const void * data ,
Ecore_Fd_Cb buf_func , const void * buf_data ) ;
EAPI void ecore_main_fd_handler_prepare_callback_set ( Ecore_Fd_Handler * fd_handler , Ecore_Fd_Prep_Cb func , const void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_main_fd_handler_del ( Ecore_Fd_Handler * fd_handler ) ;
EAPI int ecore_main_fd_handler_fd_get ( Ecore_Fd_Handler * fd_handler ) ;
2010-09-20 19:06:41 -07:00
EAPI Eina_Bool ecore_main_fd_handler_active_get ( Ecore_Fd_Handler * fd_handler , Ecore_Fd_Handler_Flags flags ) ;
2004-11-24 21:18:31 -08:00
EAPI void ecore_main_fd_handler_active_set ( Ecore_Fd_Handler * fd_handler , Ecore_Fd_Handler_Flags flags ) ;
2009-10-25 03:11:59 -07:00
2010-08-03 19:55:20 -07:00
EAPI Ecore_Win32_Handler * ecore_main_win32_handler_add ( void * h , Ecore_Fd_Win32_Cb func , const void * data ) ;
2009-11-23 15:09:48 -08:00
EAPI void * ecore_main_win32_handler_del ( Ecore_Win32_Handler * win32_handler ) ;
2007-08-26 04:17:21 -07:00
2010-08-03 19:55:20 -07:00
EAPI Ecore_Pipe * ecore_pipe_add ( Ecore_Pipe_Cb handler , const void * data ) ;
2008-11-02 21:42:27 -08:00
EAPI void * ecore_pipe_del ( Ecore_Pipe * p ) ;
2010-06-10 04:57:12 -07:00
EAPI Eina_Bool ecore_pipe_write ( Ecore_Pipe * p , const void * buffer , unsigned int nbytes ) ;
2009-04-23 00:08:50 -07:00
EAPI void ecore_pipe_write_close ( Ecore_Pipe * p ) ;
EAPI void ecore_pipe_read_close ( Ecore_Pipe * p ) ;
2008-11-02 21:42:27 -08:00
2010-07-30 01:52:18 -07:00
2010-10-13 10:45:07 -07:00
EAPI Ecore_Thread * ecore_thread_run ( Ecore_Thread_Heavy_Cb func_blocking ,
Ecore_Cb func_end ,
Ecore_Cb func_cancel ,
2010-07-30 01:52:18 -07:00
const void * data ) ;
2010-10-13 10:45:07 -07:00
EAPI Ecore_Thread * ecore_thread_feedback_run ( Ecore_Thread_Heavy_Cb func_heavy ,
Ecore_Thread_Notify_Cb func_notify ,
Ecore_Cb func_end ,
Ecore_Cb func_cancel ,
2010-09-29 23:09:20 -07:00
const void * data ,
Eina_Bool try_no_queue ) ;
2009-12-01 23:22:35 -08:00
EAPI Eina_Bool ecore_thread_cancel ( Ecore_Thread * thread ) ;
2010-06-30 06:25:28 -07:00
EAPI Eina_Bool ecore_thread_check ( Ecore_Thread * thread ) ;
2010-09-22 02:47:55 -07:00
EAPI Eina_Bool ecore_thread_feedback ( Ecore_Thread * thread , const void * msg_data ) ;
2010-07-20 02:40:18 -07:00
EAPI int ecore_thread_active_get ( void ) ;
EAPI int ecore_thread_pending_get ( void ) ;
2010-09-22 02:47:55 -07:00
EAPI int ecore_thread_pending_feedback_get ( void ) ;
2010-07-20 21:03:40 -07:00
EAPI int ecore_thread_pending_total_get ( void ) ;
2010-07-20 18:04:28 -07:00
EAPI int ecore_thread_max_get ( void ) ;
EAPI void ecore_thread_max_set ( int num ) ;
2010-07-20 19:12:10 -07:00
EAPI void ecore_thread_max_reset ( void ) ;
2010-07-21 00:09:51 -07:00
EAPI int ecore_thread_available_get ( void ) ;
2010-07-20 02:40:18 -07:00
2010-08-18 01:56:44 -07:00
EAPI Eina_Bool ecore_thread_local_data_add ( Ecore_Thread * thread , const char * key , void * value , Eina_Free_Cb cb , Eina_Bool direct ) ;
EAPI void * ecore_thread_local_data_set ( Ecore_Thread * thread , const char * key , void * value , Eina_Free_Cb cb ) ;
EAPI void * ecore_thread_local_data_find ( Ecore_Thread * thread , const char * key ) ;
EAPI Eina_Bool ecore_thread_local_data_del ( Ecore_Thread * thread , const char * key ) ;
2010-07-23 08:33:22 -07:00
2010-07-30 01:52:18 -07:00
EAPI Eina_Bool ecore_thread_global_data_add ( const char * key , void * value , Eina_Free_Cb cb , Eina_Bool direct ) ;
2010-07-30 08:56:18 -07:00
EAPI void * ecore_thread_global_data_set ( const char * key , void * value , Eina_Free_Cb cb ) ;
2010-07-30 13:33:32 -07:00
EAPI void * ecore_thread_global_data_find ( const char * key ) ;
2010-07-23 08:33:22 -07:00
EAPI Eina_Bool ecore_thread_global_data_del ( const char * key ) ;
2010-07-30 13:33:32 -07:00
EAPI void * ecore_thread_global_data_wait ( const char * key , double seconds ) ;
2010-07-30 01:52:18 -07:00
2010-07-23 08:33:22 -07:00
2009-07-31 10:06:11 -07:00
2004-11-24 21:18:31 -08:00
EAPI double ecore_time_get ( void ) ;
2010-09-27 15:35:35 -07:00
EAPI double ecore_time_unix_get ( void ) ;
2008-11-01 18:29:08 -07:00
EAPI double ecore_loop_time_get ( void ) ;
2009-04-22 18:38:55 -07:00
2010-08-03 19:55:20 -07:00
EAPI Ecore_Timer * ecore_timer_add ( double in , Ecore_Task_Cb func , const void * data ) ;
EAPI Ecore_Timer * ecore_timer_loop_add ( double in , Ecore_Task_Cb func , const void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_timer_del ( Ecore_Timer * timer ) ;
2005-02-22 04:39:50 -08:00
EAPI void ecore_timer_interval_set ( Ecore_Timer * timer , double in ) ;
2009-04-26 10:16:33 -07:00
EAPI double ecore_timer_interval_get ( Ecore_Timer * timer ) ;
2008-03-09 08:56:17 -07:00
EAPI void ecore_timer_freeze ( Ecore_Timer * timer ) ;
EAPI void ecore_timer_thaw ( Ecore_Timer * timer ) ;
2008-05-20 05:37:51 -07:00
EAPI void ecore_timer_delay ( Ecore_Timer * timer , double add ) ;
EAPI double ecore_timer_pending_get ( Ecore_Timer * timer ) ;
2007-08-26 04:17:21 -07:00
2008-11-13 12:42:01 -08:00
EAPI double ecore_timer_precision_get ( void ) ;
EAPI void ecore_timer_precision_set ( double precision ) ;
2010-08-03 19:55:20 -07:00
EAPI Ecore_Animator * ecore_animator_add ( Ecore_Task_Cb func , const void * data ) ;
2004-11-24 21:18:31 -08:00
EAPI void * ecore_animator_del ( Ecore_Animator * animator ) ;
2010-09-29 23:09:20 -07:00
EAPI void ecore_animator_freeze ( Ecore_Animator * animator ) ;
EAPI void ecore_animator_thaw ( Ecore_Animator * animator ) ;
2004-11-24 21:18:31 -08:00
EAPI void ecore_animator_frametime_set ( double frametime ) ;
EAPI double ecore_animator_frametime_get ( void ) ;
2007-08-26 04:17:21 -07:00
2008-01-10 23:33:57 -08:00
EAPI void ecore_poller_poll_interval_set ( Ecore_Poller_Type type , double poll_time ) ;
EAPI double ecore_poller_poll_interval_get ( Ecore_Poller_Type type ) ;
2010-05-19 02:16:37 -07:00
EAPI Eina_Bool ecore_poller_poller_interval_set ( Ecore_Poller * poller , int interval ) ;
EAPI int ecore_poller_poller_interval_get ( Ecore_Poller * poller ) ;
2010-08-03 19:55:20 -07:00
EAPI Ecore_Poller * ecore_poller_add ( Ecore_Poller_Type type , int interval , Ecore_Task_Cb func , const void * data ) ;
2008-01-10 23:33:57 -08:00
EAPI void * ecore_poller_del ( Ecore_Poller * poller ) ;
2010-08-03 19:55:20 -07:00
EAPI Ecore_Job * ecore_job_add ( Ecore_Cb func , const void * data ) ;
2010-01-25 13:59:21 -08:00
EAPI void * ecore_job_del ( Ecore_Job * job ) ;
2008-05-25 22:16:34 -07:00
2003-09-23 01:09:32 -07:00
# ifdef __cplusplus
}
# endif
# endif