imime.c 1.74 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
/*
 * gtkimmoduleime
 * Copyright (C) 2003 Takuro Ashie
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
Javier Jardón's avatar
Javier Jardón committed
16
 * License along with this library. If not, see <http://www.gnu.org/licenses/>.
17 18 19 20
 *
 * $Id$
 */

21
#include "config.h"
22 23
#include <string.h>

Matthias Clasen's avatar
Matthias Clasen committed
24 25 26 27
#include "gtk/gtkintl.h"
#include "gtk/gtkimmodule.h"
#include "gtkimcontextime.h"

28
static const GtkIMContextInfo ime_info = {
29
  "ime",
30 31
  NC_("input method menu", "Windows IME"),
  GETTEXT_PACKAGE,
32
  "",
33
  "ja:ko:zh",
34 35 36 37 38 39
};

static const GtkIMContextInfo *info_list[] = {
  &ime_info,
};

40
#ifndef INCLUDE_IM_ime
41
#define MODULE_ENTRY(type,function) G_MODULE_EXPORT type im_module_ ## function
42
#else
43
#define MODULE_ENTRY(type, function) type _gtk_immodule_ime_ ## function
44 45
#endif

46
MODULE_ENTRY (void, init) (GTypeModule * module)
47 48 49 50
{
  gtk_im_context_ime_register_type (module);
}

51
MODULE_ENTRY (void, exit) (void)
52 53 54
{
}

55
MODULE_ENTRY (void, list) (const GtkIMContextInfo *** contexts, int *n_contexts)
56 57 58 59 60
{
  *contexts = info_list;
  *n_contexts = G_N_ELEMENTS (info_list);
}

61
MODULE_ENTRY (GtkIMContext *, create) (const gchar * context_id)
62 63 64
{
  g_return_val_if_fail (context_id, NULL);

65
  if (!strcmp (context_id, "ime"))
66 67 68 69
    return g_object_new (GTK_TYPE_IM_CONTEXT_IME, NULL);
  else
    return NULL;
}