forked from enlightenment/efl
efl/ecore_imf: change namespace to all functions
SVN revision: 82497
This commit is contained in:
parent
c72d6b68cd
commit
bd0ce8260a
|
@ -53,22 +53,21 @@ struct _KeyEvent
|
||||||
int state;
|
int state;
|
||||||
};
|
};
|
||||||
|
|
||||||
static Eina_Bool _use_sync_mode = EINA_FALSE;
|
static Eina_Bool _sync_mode_use = EINA_FALSE;
|
||||||
|
|
||||||
static Ecore_IMF_Context *_focus_im_context = NULL;
|
static Ecore_IMF_Context *_focus_im_context = NULL;
|
||||||
static IBusBus *_bus = NULL;
|
static IBusBus *_bus = NULL;
|
||||||
|
|
||||||
/* functions prototype */
|
/* functions prototype */
|
||||||
/* static methods*/
|
/* static methods*/
|
||||||
static void _create_input_context (IBusIMContext *context);
|
static void _ecore_imf_context_ibus_create (IBusIMContext *context);
|
||||||
static void _set_cursor_location_internal
|
static void _ecore_imf_context_ibus_cursor_location_internal_set(Ecore_IMF_Context *ctx);
|
||||||
(Ecore_IMF_Context *ctx);
|
static void _ecore_imf_context_ibus_bus_connected_cb (IBusBus *bus,
|
||||||
static void _bus_connected_cb (IBusBus *bus,
|
|
||||||
IBusIMContext *context);
|
IBusIMContext *context);
|
||||||
static XKeyEvent createXKeyEvent (Window win, Eina_Bool press, int keysym, int modifiers);
|
static XKeyEvent _ecore_imf_ibus_x_key_event_generate (Window win, Eina_Bool press, int keysym, int modifiers);
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_window_to_screen_geometry_get(Ecore_X_Window client_win, int *x, int *y)
|
_ecore_imf_ibus_window_to_screen_geometry_get(Ecore_X_Window client_win, int *x, int *y)
|
||||||
{
|
{
|
||||||
Ecore_X_Window root_window, win;
|
Ecore_X_Window root_window, win;
|
||||||
int win_x, win_y;
|
int win_x, win_y;
|
||||||
|
@ -120,7 +119,7 @@ _ecore_imf_modifier_to_ibus_modifier(unsigned int modifier)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
key_event_put(int keysym, int state)
|
_ecore_imf_ibus_key_event_put(int keysym, int state)
|
||||||
{
|
{
|
||||||
// Find the window which has the current keyboard focus.
|
// Find the window which has the current keyboard focus.
|
||||||
Window winFocus = 0;
|
Window winFocus = 0;
|
||||||
|
@ -131,18 +130,18 @@ key_event_put(int keysym, int state)
|
||||||
XKeyEvent event;
|
XKeyEvent event;
|
||||||
if (state & IBUS_RELEASE_MASK)
|
if (state & IBUS_RELEASE_MASK)
|
||||||
{
|
{
|
||||||
event = createXKeyEvent(winFocus, EINA_FALSE, keysym, state);
|
event = _ecore_imf_ibus_x_key_event_generate(winFocus, EINA_FALSE, keysym, state);
|
||||||
XSendEvent(event.display, event.window, True, KeyReleaseMask, (XEvent *)&event);
|
XSendEvent(event.display, event.window, True, KeyReleaseMask, (XEvent *)&event);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
event = createXKeyEvent(winFocus, EINA_TRUE, keysym, state);
|
event = _ecore_imf_ibus_x_key_event_generate(winFocus, EINA_TRUE, keysym, state);
|
||||||
XSendEvent(event.display, event.window, True, KeyPressMask, (XEvent *)&event);
|
XSendEvent(event.display, event.window, True, KeyPressMask, (XEvent *)&event);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static KeyEvent *
|
static KeyEvent *
|
||||||
key_event_copy(int keysym, int state)
|
_ecore_imf_ibus_key_event_copy(int keysym, int state)
|
||||||
{
|
{
|
||||||
KeyEvent *kev = calloc(1, sizeof(KeyEvent));
|
KeyEvent *kev = calloc(1, sizeof(KeyEvent));
|
||||||
kev->keysym = keysym;
|
kev->keysym = keysym;
|
||||||
|
@ -152,7 +151,7 @@ key_event_copy(int keysym, int state)
|
||||||
}
|
}
|
||||||
|
|
||||||
IBusIMContext *
|
IBusIMContext *
|
||||||
ibus_im_context_new(void)
|
ecore_imf_context_ibus_new(void)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("%s", __FUNCTION__);
|
EINA_LOG_DBG("%s", __FUNCTION__);
|
||||||
|
|
||||||
|
@ -175,7 +174,7 @@ ibus_im_context_new(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_process_key_event_done(GObject *object,
|
_ecore_imf_ibus_process_key_event_done(GObject *object,
|
||||||
GAsyncResult *res,
|
GAsyncResult *res,
|
||||||
gpointer user_data)
|
gpointer user_data)
|
||||||
{
|
{
|
||||||
|
@ -195,13 +194,13 @@ _process_key_event_done(GObject *object,
|
||||||
|
|
||||||
if (retval == EINA_FALSE)
|
if (retval == EINA_FALSE)
|
||||||
{
|
{
|
||||||
key_event_put(event->keysym, event->state);
|
_ecore_imf_ibus_key_event_put(event->keysym, event->state);
|
||||||
}
|
}
|
||||||
free(event);
|
free(event);
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_add(Ecore_IMF_Context *ctx)
|
ecore_imf_context_ibus_add(Ecore_IMF_Context *ctx)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("%s", __FUNCTION__);
|
EINA_LOG_DBG("%s", __FUNCTION__);
|
||||||
|
|
||||||
|
@ -233,23 +232,23 @@ ibus_im_context_add(Ecore_IMF_Context *ctx)
|
||||||
|
|
||||||
s = getenv("IBUS_ENABLE_SYNC_MODE");
|
s = getenv("IBUS_ENABLE_SYNC_MODE");
|
||||||
if (s)
|
if (s)
|
||||||
_use_sync_mode = !!atoi(s);
|
_sync_mode_use = !!atoi(s);
|
||||||
|
|
||||||
if (ibus_bus_is_connected(_bus))
|
if (ibus_bus_is_connected(_bus))
|
||||||
_create_input_context (ibusimcontext);
|
_ecore_imf_context_ibus_create (ibusimcontext);
|
||||||
|
|
||||||
g_signal_connect(_bus, "connected", G_CALLBACK (_bus_connected_cb), ctx);
|
g_signal_connect(_bus, "connected", G_CALLBACK (_ecore_imf_context_ibus_bus_connected_cb), ctx);
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_del(Ecore_IMF_Context *ctx)
|
ecore_imf_context_ibus_del(Ecore_IMF_Context *ctx)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("%s", __FUNCTION__);
|
EINA_LOG_DBG("%s", __FUNCTION__);
|
||||||
|
|
||||||
IBusIMContext *ibusimcontext = (IBusIMContext*)ecore_imf_context_data_get(ctx);
|
IBusIMContext *ibusimcontext = (IBusIMContext*)ecore_imf_context_data_get(ctx);
|
||||||
EINA_SAFETY_ON_NULL_RETURN(ibusimcontext);
|
EINA_SAFETY_ON_NULL_RETURN(ibusimcontext);
|
||||||
|
|
||||||
g_signal_handlers_disconnect_by_func(_bus, G_CALLBACK(_bus_connected_cb), ctx);
|
g_signal_handlers_disconnect_by_func(_bus, G_CALLBACK(_ecore_imf_context_ibus_bus_connected_cb), ctx);
|
||||||
|
|
||||||
if (ibusimcontext->ibuscontext)
|
if (ibusimcontext->ibuscontext)
|
||||||
ibus_proxy_destroy((IBusProxy *)ibusimcontext->ibuscontext);
|
ibus_proxy_destroy((IBusProxy *)ibusimcontext->ibuscontext);
|
||||||
|
@ -262,7 +261,7 @@ ibus_im_context_del(Ecore_IMF_Context *ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI Eina_Bool
|
EAPI Eina_Bool
|
||||||
ibus_im_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type, Ecore_IMF_Event *event)
|
ecore_imf_context_ibus_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type, Ecore_IMF_Event *event)
|
||||||
{
|
{
|
||||||
IBusIMContext *ibusimcontext = (IBusIMContext*)ecore_imf_context_data_get(ctx);
|
IBusIMContext *ibusimcontext = (IBusIMContext*)ecore_imf_context_data_get(ctx);
|
||||||
EINA_SAFETY_ON_NULL_RETURN_VAL(ibusimcontext, EINA_FALSE);
|
EINA_SAFETY_ON_NULL_RETURN_VAL(ibusimcontext, EINA_FALSE);
|
||||||
|
@ -292,7 +291,7 @@ ibus_im_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type,
|
||||||
keysym = XStringToKeysym(ev->key);
|
keysym = XStringToKeysym(ev->key);
|
||||||
state = _ecore_imf_modifier_to_ibus_modifier(ev->modifiers) | IBUS_RELEASE_MASK;
|
state = _ecore_imf_modifier_to_ibus_modifier(ev->modifiers) | IBUS_RELEASE_MASK;
|
||||||
|
|
||||||
if (_use_sync_mode)
|
if (_sync_mode_use)
|
||||||
{
|
{
|
||||||
retval = ibus_input_context_process_key_event(ibusimcontext->ibuscontext,
|
retval = ibus_input_context_process_key_event(ibusimcontext->ibuscontext,
|
||||||
keysym,
|
keysym,
|
||||||
|
@ -307,8 +306,8 @@ ibus_im_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type,
|
||||||
state,
|
state,
|
||||||
-1,
|
-1,
|
||||||
NULL,
|
NULL,
|
||||||
_process_key_event_done,
|
_ecore_imf_ibus_process_key_event_done,
|
||||||
key_event_copy(keysym, state));
|
_ecore_imf_ibus_key_event_copy(keysym, state));
|
||||||
retval = EINA_TRUE;
|
retval = EINA_TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -321,7 +320,7 @@ ibus_im_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type,
|
||||||
keycode = ecore_x_keysym_keycode_get(ev->key);
|
keycode = ecore_x_keysym_keycode_get(ev->key);
|
||||||
keysym = XStringToKeysym(ev->key);
|
keysym = XStringToKeysym(ev->key);
|
||||||
state = _ecore_imf_modifier_to_ibus_modifier(ev->modifiers);
|
state = _ecore_imf_modifier_to_ibus_modifier(ev->modifiers);
|
||||||
if (_use_sync_mode)
|
if (_sync_mode_use)
|
||||||
{
|
{
|
||||||
retval = ibus_input_context_process_key_event(ibusimcontext->ibuscontext,
|
retval = ibus_input_context_process_key_event(ibusimcontext->ibuscontext,
|
||||||
keysym,
|
keysym,
|
||||||
|
@ -336,8 +335,8 @@ ibus_im_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type,
|
||||||
state,
|
state,
|
||||||
-1,
|
-1,
|
||||||
NULL,
|
NULL,
|
||||||
_process_key_event_done,
|
_ecore_imf_ibus_process_key_event_done,
|
||||||
key_event_copy(keysym, state));
|
_ecore_imf_ibus_key_event_copy(keysym, state));
|
||||||
retval = EINA_TRUE;
|
retval = EINA_TRUE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -354,7 +353,7 @@ ibus_im_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type,
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_focus_in(Ecore_IMF_Context *ctx)
|
ecore_imf_context_ibus_focus_in(Ecore_IMF_Context *ctx)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("ctx : %p", ctx);
|
EINA_LOG_DBG("ctx : %p", ctx);
|
||||||
|
|
||||||
|
@ -376,7 +375,7 @@ ibus_im_context_focus_in(Ecore_IMF_Context *ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_focus_out(Ecore_IMF_Context *ctx)
|
ecore_imf_context_ibus_focus_out(Ecore_IMF_Context *ctx)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("ctx : %p", ctx);
|
EINA_LOG_DBG("ctx : %p", ctx);
|
||||||
|
|
||||||
|
@ -395,7 +394,7 @@ ibus_im_context_focus_out(Ecore_IMF_Context *ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_reset(Ecore_IMF_Context *ctx)
|
ecore_imf_context_ibus_reset(Ecore_IMF_Context *ctx)
|
||||||
{
|
{
|
||||||
IBusIMContext *ibusimcontext = (IBusIMContext*)ecore_imf_context_data_get(ctx);
|
IBusIMContext *ibusimcontext = (IBusIMContext*)ecore_imf_context_data_get(ctx);
|
||||||
EINA_SAFETY_ON_NULL_RETURN(ibusimcontext);
|
EINA_SAFETY_ON_NULL_RETURN(ibusimcontext);
|
||||||
|
@ -405,7 +404,7 @@ ibus_im_context_reset(Ecore_IMF_Context *ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_preedit_string_get(Ecore_IMF_Context *ctx,
|
ecore_imf_context_ibus_preedit_string_get(Ecore_IMF_Context *ctx,
|
||||||
char **str,
|
char **str,
|
||||||
int *cursor_pos)
|
int *cursor_pos)
|
||||||
{
|
{
|
||||||
|
@ -432,7 +431,7 @@ ibus_im_context_preedit_string_get(Ecore_IMF_Context *ctx,
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_preedit_string_with_attributes_get(Ecore_IMF_Context *ctx,
|
ecore_imf_context_ibus_preedit_string_with_attributes_get(Ecore_IMF_Context *ctx,
|
||||||
char **str,
|
char **str,
|
||||||
Eina_List **attr EINA_UNUSED,
|
Eina_List **attr EINA_UNUSED,
|
||||||
int *cursor_pos)
|
int *cursor_pos)
|
||||||
|
@ -460,7 +459,7 @@ ibus_im_context_preedit_string_with_attributes_get(Ecore_IMF_Context *ctx,
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_client_window_set(Ecore_IMF_Context *ctx, void *window)
|
ecore_imf_context_ibus_client_window_set(Ecore_IMF_Context *ctx, void *window)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("canvas : %p", window);
|
EINA_LOG_DBG("canvas : %p", window);
|
||||||
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
||||||
|
@ -471,7 +470,7 @@ ibus_im_context_client_window_set(Ecore_IMF_Context *ctx, void *window)
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_client_canvas_set(Ecore_IMF_Context *ctx, void *canvas)
|
ecore_imf_context_ibus_client_canvas_set(Ecore_IMF_Context *ctx, void *canvas)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("canvas : %p", canvas);
|
EINA_LOG_DBG("canvas : %p", canvas);
|
||||||
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
||||||
|
@ -482,7 +481,7 @@ ibus_im_context_client_canvas_set(Ecore_IMF_Context *ctx, void *canvas)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_set_cursor_location_internal(Ecore_IMF_Context *ctx)
|
_ecore_imf_context_ibus_cursor_location_set(Ecore_IMF_Context *ctx)
|
||||||
{
|
{
|
||||||
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
||||||
Ecore_Evas *ee;
|
Ecore_Evas *ee;
|
||||||
|
@ -503,7 +502,7 @@ _set_cursor_location_internal(Ecore_IMF_Context *ctx)
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if (ibusimcontext->client_window)
|
if (ibusimcontext->client_window)
|
||||||
_window_to_screen_geometry_get(ibusimcontext->client_window, &canvas_x, &canvas_y);
|
_ecore_imf_ibus_window_to_screen_geometry_get(ibusimcontext->client_window, &canvas_x, &canvas_y);
|
||||||
else
|
else
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -516,7 +515,7 @@ _set_cursor_location_internal(Ecore_IMF_Context *ctx)
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_cursor_location_set(Ecore_IMF_Context *ctx, int x, int y, int w, int h)
|
ecore_imf_context_ibus_cursor_location_set(Ecore_IMF_Context *ctx, int x, int y, int w, int h)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("x : %d, y : %d, w, %d, h :%d", x, y, w, h);
|
EINA_LOG_DBG("x : %d, y : %d, w, %d, h :%d", x, y, w, h);
|
||||||
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
||||||
|
@ -532,12 +531,12 @@ ibus_im_context_cursor_location_set(Ecore_IMF_Context *ctx, int x, int y, int w,
|
||||||
ibusimcontext->cursor_w = w;
|
ibusimcontext->cursor_w = w;
|
||||||
ibusimcontext->cursor_h = h;
|
ibusimcontext->cursor_h = h;
|
||||||
|
|
||||||
_set_cursor_location_internal(ctx);
|
_ecore_imf_context_ibus_cursor_location_set(ctx);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EAPI void
|
EAPI void
|
||||||
ibus_im_context_use_preedit_set(Ecore_IMF_Context *ctx, Eina_Bool use_preedit)
|
ecore_imf_context_ibus_use_preedit_set(Ecore_IMF_Context *ctx, Eina_Bool use_preedit)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("preedit : %d", use_preedit);
|
EINA_LOG_DBG("preedit : %d", use_preedit);
|
||||||
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
IBusIMContext *ibusimcontext = (IBusIMContext *)ecore_imf_context_data_get(ctx);
|
||||||
|
@ -555,17 +554,17 @@ ibus_im_context_use_preedit_set(Ecore_IMF_Context *ctx, Eina_Bool use_preedit)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_bus_connected_cb(IBusBus *bus EINA_UNUSED,
|
_ecore_imf_context_ibus_bus_connected_cb(IBusBus *bus EINA_UNUSED,
|
||||||
IBusIMContext *ibusimcontext)
|
IBusIMContext *ibusimcontext)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("ibus is connected");
|
EINA_LOG_DBG("ibus is connected");
|
||||||
|
|
||||||
if (ibusimcontext)
|
if (ibusimcontext)
|
||||||
_create_input_context(ibusimcontext);
|
_ecore_imf_context_ibus_create(ibusimcontext);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_ibus_context_commit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
_ecore_imf_context_ibus_commit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
IBusText *text,
|
IBusText *text,
|
||||||
IBusIMContext *ibusimcontext)
|
IBusIMContext *ibusimcontext)
|
||||||
{
|
{
|
||||||
|
@ -581,7 +580,7 @@ _ibus_context_commit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static XKeyEvent createXKeyEvent(Window win, Eina_Bool press, int keysym, int modifiers)
|
static XKeyEvent _ecore_imf_ibus_x_key_event_generate(Window win, Eina_Bool press, int keysym, int modifiers)
|
||||||
{
|
{
|
||||||
XKeyEvent event;
|
XKeyEvent event;
|
||||||
Display *display = ecore_x_display_get();
|
Display *display = ecore_x_display_get();
|
||||||
|
@ -609,18 +608,18 @@ static XKeyEvent createXKeyEvent(Window win, Eina_Bool press, int keysym, int mo
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_ibus_context_forward_key_event_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
_ecore_imf_context_ibus_forward_key_event_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
guint keyval,
|
guint keyval,
|
||||||
guint state,
|
guint state,
|
||||||
IBusIMContext *ibusimcontext EINA_UNUSED)
|
IBusIMContext *ibusimcontext EINA_UNUSED)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("keyval : %d, state : %d", keyval, state);
|
EINA_LOG_DBG("keyval : %d, state : %d", keyval, state);
|
||||||
|
|
||||||
key_event_put(keyval, state);
|
_ecore_imf_ibus_key_event_put(keyval, state);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_ibus_context_update_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
_ecore_imf_context_ibus_update_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
IBusText *text,
|
IBusText *text,
|
||||||
gint cursor_pos,
|
gint cursor_pos,
|
||||||
gboolean visible,
|
gboolean visible,
|
||||||
|
@ -673,7 +672,7 @@ _ibus_context_update_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_ibus_context_show_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
_ecore_imf_context_ibus_show_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
IBusIMContext *ibusimcontext)
|
IBusIMContext *ibusimcontext)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("preedit visible : %d", ibusimcontext->preedit_visible);
|
EINA_LOG_DBG("preedit visible : %d", ibusimcontext->preedit_visible);
|
||||||
|
@ -694,7 +693,7 @@ _ibus_context_show_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_ibus_context_hide_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
_ecore_imf_context_ibus_hide_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
IBusIMContext *ibusimcontext)
|
IBusIMContext *ibusimcontext)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("%s", __FUNCTION__);
|
EINA_LOG_DBG("%s", __FUNCTION__);
|
||||||
|
@ -715,7 +714,7 @@ _ibus_context_hide_preedit_text_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_ibus_context_enabled_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
_ecore_imf_context_ibus_enabled_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
IBusIMContext *ibusimcontext)
|
IBusIMContext *ibusimcontext)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("%s", __FUNCTION__);
|
EINA_LOG_DBG("%s", __FUNCTION__);
|
||||||
|
@ -725,7 +724,7 @@ _ibus_context_enabled_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_ibus_context_disabled_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
_ecore_imf_context_ibus_disabled_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
IBusIMContext *ibusimcontext)
|
IBusIMContext *ibusimcontext)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("%s", __FUNCTION__);
|
EINA_LOG_DBG("%s", __FUNCTION__);
|
||||||
|
@ -749,7 +748,7 @@ _ibus_context_disabled_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_ibus_context_destroy_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
_ecore_imf_context_ibus_destroy_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
IBusIMContext *ibusimcontext)
|
IBusIMContext *ibusimcontext)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("%s", __FUNCTION__);
|
EINA_LOG_DBG("%s", __FUNCTION__);
|
||||||
|
@ -774,7 +773,7 @@ _ibus_context_destroy_cb(IBusInputContext *ibuscontext EINA_UNUSED,
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
_create_input_context(IBusIMContext *ibusimcontext)
|
_ecore_imf_context_ibus_create(IBusIMContext *ibusimcontext)
|
||||||
{
|
{
|
||||||
EINA_LOG_DBG("%s", __FUNCTION__);
|
EINA_LOG_DBG("%s", __FUNCTION__);
|
||||||
EINA_SAFETY_ON_NULL_RETURN(ibusimcontext);
|
EINA_SAFETY_ON_NULL_RETURN(ibusimcontext);
|
||||||
|
@ -785,34 +784,34 @@ _create_input_context(IBusIMContext *ibusimcontext)
|
||||||
|
|
||||||
g_signal_connect(ibusimcontext->ibuscontext,
|
g_signal_connect(ibusimcontext->ibuscontext,
|
||||||
"commit-text",
|
"commit-text",
|
||||||
G_CALLBACK (_ibus_context_commit_text_cb),
|
G_CALLBACK (_ecore_imf_context_ibus_commit_text_cb),
|
||||||
ibusimcontext);
|
ibusimcontext);
|
||||||
g_signal_connect(ibusimcontext->ibuscontext,
|
g_signal_connect(ibusimcontext->ibuscontext,
|
||||||
"forward-key-event",
|
"forward-key-event",
|
||||||
G_CALLBACK (_ibus_context_forward_key_event_cb),
|
G_CALLBACK (_ecore_imf_context_ibus_forward_key_event_cb),
|
||||||
ibusimcontext);
|
ibusimcontext);
|
||||||
g_signal_connect(ibusimcontext->ibuscontext,
|
g_signal_connect(ibusimcontext->ibuscontext,
|
||||||
"update-preedit-text",
|
"update-preedit-text",
|
||||||
G_CALLBACK (_ibus_context_update_preedit_text_cb),
|
G_CALLBACK (_ecore_imf_context_ibus_update_preedit_text_cb),
|
||||||
ibusimcontext);
|
ibusimcontext);
|
||||||
g_signal_connect(ibusimcontext->ibuscontext,
|
g_signal_connect(ibusimcontext->ibuscontext,
|
||||||
"show-preedit-text",
|
"show-preedit-text",
|
||||||
G_CALLBACK (_ibus_context_show_preedit_text_cb),
|
G_CALLBACK (_ecore_imf_context_ibus_show_preedit_text_cb),
|
||||||
ibusimcontext);
|
ibusimcontext);
|
||||||
g_signal_connect(ibusimcontext->ibuscontext,
|
g_signal_connect(ibusimcontext->ibuscontext,
|
||||||
"hide-preedit-text",
|
"hide-preedit-text",
|
||||||
G_CALLBACK (_ibus_context_hide_preedit_text_cb),
|
G_CALLBACK (_ecore_imf_context_ibus_hide_preedit_text_cb),
|
||||||
ibusimcontext);
|
ibusimcontext);
|
||||||
g_signal_connect(ibusimcontext->ibuscontext,
|
g_signal_connect(ibusimcontext->ibuscontext,
|
||||||
"enabled",
|
"enabled",
|
||||||
G_CALLBACK (_ibus_context_enabled_cb),
|
G_CALLBACK (_ecore_imf_context_ibus_enabled_cb),
|
||||||
ibusimcontext);
|
ibusimcontext);
|
||||||
g_signal_connect(ibusimcontext->ibuscontext,
|
g_signal_connect(ibusimcontext->ibuscontext,
|
||||||
"disabled",
|
"disabled",
|
||||||
G_CALLBACK (_ibus_context_disabled_cb),
|
G_CALLBACK (_ecore_imf_context_ibus_disabled_cb),
|
||||||
ibusimcontext);
|
ibusimcontext);
|
||||||
g_signal_connect(ibusimcontext->ibuscontext, "destroy",
|
g_signal_connect(ibusimcontext->ibuscontext, "destroy",
|
||||||
G_CALLBACK (_ibus_context_destroy_cb),
|
G_CALLBACK (_ecore_imf_context_ibus_destroy_cb),
|
||||||
ibusimcontext);
|
ibusimcontext);
|
||||||
|
|
||||||
ibus_input_context_set_capabilities(ibusimcontext->ibuscontext, ibusimcontext->caps);
|
ibus_input_context_set_capabilities(ibusimcontext->ibuscontext, ibusimcontext->caps);
|
||||||
|
|
|
@ -5,32 +5,36 @@
|
||||||
|
|
||||||
typedef struct _IBusIMContext IBusIMContext;
|
typedef struct _IBusIMContext IBusIMContext;
|
||||||
|
|
||||||
EAPI void ibus_im_context_add (Ecore_IMF_Context *ctx);
|
EAPI void ecore_imf_context_ibus_add(Ecore_IMF_Context *ctx);
|
||||||
EAPI void ibus_im_context_del (Ecore_IMF_Context *ctx);
|
|
||||||
EAPI void ibus_im_context_reset (Ecore_IMF_Context *context);
|
|
||||||
EAPI void ibus_im_context_focus_in(Ecore_IMF_Context *context);
|
|
||||||
EAPI void ibus_im_context_focus_out(Ecore_IMF_Context *context);
|
|
||||||
EAPI void ibus_im_context_preedit_string_get
|
|
||||||
(Ecore_IMF_Context *context,
|
|
||||||
char **str,
|
|
||||||
int *cursor_pos);
|
|
||||||
EAPI void ibus_im_context_preedit_string_with_attributes_get
|
|
||||||
(Ecore_IMF_Context *context,
|
|
||||||
char **str,
|
|
||||||
Eina_List **attr,
|
|
||||||
int *cursor_pos);
|
|
||||||
|
|
||||||
EAPI void ibus_im_context_cursor_location_set(Ecore_IMF_Context *context,
|
EAPI void ecore_imf_context_ibus_del(Ecore_IMF_Context *ctx);
|
||||||
int x, int y, int w, int h);
|
|
||||||
EAPI void ibus_im_context_use_preedit_set(Ecore_IMF_Context *context,
|
|
||||||
Eina_Bool use_preedit);
|
|
||||||
EAPI void
|
|
||||||
ibus_im_context_client_window_set(Ecore_IMF_Context *context, void *window);
|
|
||||||
EAPI void
|
|
||||||
ibus_im_context_client_canvas_set(Ecore_IMF_Context *context, void *canvas);
|
|
||||||
EAPI Eina_Bool
|
|
||||||
ibus_im_context_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type, Ecore_IMF_Event *event);
|
|
||||||
|
|
||||||
IBusIMContext
|
EAPI void ecore_imf_context_ibus_reset(Ecore_IMF_Context *context);
|
||||||
*ibus_im_context_new (void);
|
|
||||||
|
EAPI void ecore_imf_context_ibus_focus_in(Ecore_IMF_Context *context);
|
||||||
|
|
||||||
|
EAPI void ecore_imf_context_ibus_focus_out(Ecore_IMF_Context *context);
|
||||||
|
|
||||||
|
EAPI void ecore_imf_context_ibus_preedit_string_get(Ecore_IMF_Context *context,
|
||||||
|
char **str,
|
||||||
|
int *cursor_pos);
|
||||||
|
|
||||||
|
EAPI void ecore_imf_context_ibus_preedit_string_with_attributes_get(Ecore_IMF_Context *context,
|
||||||
|
char **str,
|
||||||
|
Eina_List **attr,
|
||||||
|
int *cursor_pos);
|
||||||
|
|
||||||
|
EAPI void ecore_imf_context_ibus_cursor_location_set(Ecore_IMF_Context *context,
|
||||||
|
int x, int y, int w, int h);
|
||||||
|
|
||||||
|
EAPI void ecore_imf_context_ibus_use_preedit_set(Ecore_IMF_Context *context,
|
||||||
|
Eina_Bool use_preedit);
|
||||||
|
|
||||||
|
EAPI void ecore_imf_context_ibus_client_window_set(Ecore_IMF_Context *context, void *window);
|
||||||
|
|
||||||
|
EAPI void ecore_imf_context_ibus_client_canvas_set(Ecore_IMF_Context *context, void *canvas);
|
||||||
|
|
||||||
|
EAPI Eina_Bool ecore_imf_context_ibus_filter_event(Ecore_IMF_Context *ctx, Ecore_IMF_Event_Type type, Ecore_IMF_Event *event);
|
||||||
|
|
||||||
|
IBusIMContext *ecore_imf_context_ibus_new(void);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -20,35 +20,35 @@ static const Ecore_IMF_Context_Info ibus_im_info = {
|
||||||
};
|
};
|
||||||
|
|
||||||
static Ecore_IMF_Context_Class ibus_imf_class = {
|
static Ecore_IMF_Context_Class ibus_imf_class = {
|
||||||
ibus_im_context_add, /* add */
|
ecore_imf_context_ibus_add, /* add */
|
||||||
ibus_im_context_del, /* del */
|
ecore_imf_context_ibus_del, /* del */
|
||||||
ibus_im_context_client_window_set, /* client_window_set */
|
ecore_imf_context_ibus_client_window_set, /* client_window_set */
|
||||||
ibus_im_context_client_canvas_set, /* client_canvas_set */
|
ecore_imf_context_ibus_client_canvas_set, /* client_canvas_set */
|
||||||
NULL, /* input_panel_show */
|
NULL, /* input_panel_show */
|
||||||
NULL, /* input_panel_hide */
|
NULL, /* input_panel_hide */
|
||||||
ibus_im_context_preedit_string_get, /* get_preedit_string */
|
ecore_imf_context_ibus_preedit_string_get, /* get_preedit_string */
|
||||||
ibus_im_context_focus_in, /* focus_in */
|
ecore_imf_context_ibus_focus_in, /* focus_in */
|
||||||
ibus_im_context_focus_out, /* focus_out */
|
ecore_imf_context_ibus_focus_out, /* focus_out */
|
||||||
ibus_im_context_reset, /* reset */
|
ecore_imf_context_ibus_reset, /* reset */
|
||||||
NULL, /* cursor_position_set */
|
NULL, /* cursor_position_set */
|
||||||
ibus_im_context_use_preedit_set, /* use_preedit_set */
|
ecore_imf_context_ibus_use_preedit_set, /* use_preedit_set */
|
||||||
NULL, /* input_mode_set */
|
NULL, /* input_mode_set */
|
||||||
ibus_im_context_filter_event, /* filter_event */
|
ecore_imf_context_ibus_filter_event, /* filter_event */
|
||||||
ibus_im_context_preedit_string_with_attributes_get, /* preedit_string_with_attribute_get */
|
ecore_imf_context_ibus_preedit_string_with_attributes_get, /* preedit_string_with_attribute_get */
|
||||||
NULL, /* prediction_allow_set */
|
NULL, /* prediction_allow_set */
|
||||||
NULL, /* autocapital_type_set */
|
NULL, /* autocapital_type_set */
|
||||||
NULL, /* control panel show */
|
NULL, /* control panel show */
|
||||||
NULL, /* control panel hide */
|
NULL, /* control panel hide */
|
||||||
NULL, /* input_panel_layout_set */
|
NULL, /* input_panel_layout_set */
|
||||||
NULL, /* ibus_im_context_input_panel_layout_get, */
|
NULL, /* ecore_imf_context_ibus_input_panel_layout_get, */
|
||||||
NULL, /* ibus_im_context_input_panel_language_set, */
|
NULL, /* ecore_imf_context_ibus_input_panel_language_set, */
|
||||||
NULL, /* ibus_im_context_input_panel_language_get, */
|
NULL, /* ecore_imf_context_ibus_input_panel_language_get, */
|
||||||
ibus_im_context_cursor_location_set, /* cursor_location_set */
|
ecore_imf_context_ibus_cursor_location_set, /* cursor_location_set */
|
||||||
NULL, /* input_panel_imdata_set */
|
NULL, /* input_panel_imdata_set */
|
||||||
NULL, /* input_panel_imdata_get */
|
NULL, /* input_panel_imdata_get */
|
||||||
NULL, /* input_panel_return_key_type_set */
|
NULL, /* input_panel_return_key_type_set */
|
||||||
NULL, /* input_panel_return_key_disabled_set */
|
NULL, /* input_panel_return_key_disabled_set */
|
||||||
NULL, /* input_panel_caps_lock_mode_set */
|
NULL, /* input_panel_caps_lock_mode_set */
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
NULL,
|
NULL,
|
||||||
|
@ -86,7 +86,7 @@ im_module_create(void)
|
||||||
Ecore_IMF_Context *ctx = NULL;
|
Ecore_IMF_Context *ctx = NULL;
|
||||||
IBusIMContext *ctxd = NULL;
|
IBusIMContext *ctxd = NULL;
|
||||||
|
|
||||||
ctxd = ibus_im_context_new();
|
ctxd = ecore_imf_context_ibus_new();
|
||||||
if (!ctxd)
|
if (!ctxd)
|
||||||
{
|
{
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
Loading…
Reference in New Issue