/* This file is part of
- * ======================================================
- *
+ * ======================================================
+ *
* LyX, The Document Processor
- *
- * Copyright 1995 Matthias Ettrich
- * Copyright 1995-2000 The LyX team.
+ *
+ * Copyright 1995 Matthias Ettrich
+ * Copyright 1995-2001 The LyX team.
*
* ====================================================== */
#ifdef HAVE_XOPENIM
// This part is the full blown Input Method manager for X11R5 and up.
// For the plain-and-old-X11R4 version, see later.
-#include FORMS_H_LOCATION
-//#include <X11/Xlib.h>
-//#include <X11/Xutil.h>
-//#include <X11/keysym.h>
-#if FL_REVISION < 89
+#include <X11/Xlib.h>
+#include <X11/Xutil.h>
+#include <X11/keysym.h>
#ifdef HAVE_LOCALE_H
#include <locale.h>
#endif
using std::endl;
-static XIM xim;
-static XIC xic;
+namespace {
+
+XIM xim;
+XIC xic;
XComposeStatus compose_status= {0, 0};
+} // namespace anon
+
+
// This is called after the main LyX window has been created
-void InitLyXLookup(Display * display, Window window)
+void InitLyXLookup(Display * display, Window window)
{
xic = 0;
-
+
+ lyxerr[Debug::KEY]
+ << "InitLyXLookup: creating an input context."
+ << endl;
+
// This part could be done before opening display
+ string oldlocale = setlocale(LC_CTYPE, 0);
setlocale(LC_CTYPE, "");
- if (!XSupportsLocale()) {
+ if (!XSupportsLocale()) {
lyxerr[Debug::KEY]
<< "InitLyXLookup: X does not support this locale."
<< endl;
return;
- }
- if (!XSetLocaleModifiers("")) {
+ }
+ // reset the LC_CTYPE locale to previous value.
+ setlocale(LC_CTYPE, oldlocale.c_str());
+
+ char const * locmod;
+ if (!(locmod = XSetLocaleModifiers(""))) {
lyxerr[Debug::KEY] << "InitLyXLookup: Could not set modifiers "
"for this locale." << endl;
return;
}
-
+ else
+ lyxerr[Debug::KEY] << "InitLyXLookup: X locale modifiers are `"
+ << locmod << '\'' << endl;
+
// This part will have to be done for each frame
xim = XOpenIM (display, 0, 0, 0);
if (xim) {
- xic = XCreateIC(xim, XNInputStyle,
- XIMPreeditNothing | XIMStatusNothing,
+ xic = XCreateIC(xim,
+ XNInputStyle,
+ XIMPreeditNothing|XIMStatusNothing,
XNClientWindow, window,
- XNFocusWindow, window,
+ XNFocusWindow, window,
0);
-
+
if (!xic) {
- lyxerr[Debug::KEY] << "InitLyXLookup: could not create "
- "an input context" << endl;
+ lyxerr[Debug::KEY] << "InitLyXLookup: "
+ "could not create an input context" << endl;
XCloseIM (xim);
xim = 0;
- }
+ }
}
- else
+ else
lyxerr[Debug::KEY] << "InitLyXLookup: could not open "
"an input method." << endl;
}
-static
-bool isDeadEvent(XEvent * event,
- char * buffer_return, int bytes_buffer,
- KeySym * keysym_return)
-{
- XLookupString(&event->xkey, buffer_return,
- bytes_buffer, keysym_return,
- 0);
-
- // somehow it is necessary to do the lookup. Why? (JMarc)
- if (!lyxrc.override_x_deadkeys)
- return false;
+namespace {
+bool isDeadEvent(KeySym keysym)
+{
// Can this be done safely in any other way?
// This is all the dead keys I know of in X11R6.1
- switch (*keysym_return) {
+ switch (keysym) {
#ifdef XK_dead_grave
case XK_dead_grave:
#endif
}
}
+} // namespace anon
+
// This is called instead of XLookupString()
-int LyXLookupString(XEvent * event,
+int LyXLookupString(XEvent * event,
char * buffer_return, int bytes_buffer,
- KeySym * keysym_return)
+ KeySym * keysym_return)
{
+ if (event->type != KeyPress) {
+ lyxerr << "LyXLookupString: wrong event type: "
+ << event->type << endl;
+ return 0;
+ }
+
int result = 0;
if (xic) {
- if (isDeadEvent(event, buffer_return, bytes_buffer,
- keysym_return)) {
- lyxerr[Debug::KEY]
+#if 1
+ // somehow it is necessary to do the lookup. Why? (JMarc)
+ XLookupString(&event->xkey, buffer_return,
+ bytes_buffer, keysym_return,
+ 0);
+
+ if (lyxrc.override_x_deadkeys &&
+ isDeadEvent(*keysym_return)) {
+ lyxerr[Debug::KEY]
<< "LyXLookupString: found DeadEvent" << endl;
return 0;
}
+#endif
#if 1
if (XFilterEvent (event, None)) {
lyxerr[Debug::KEY] <<"XFilterEvent" << endl;
*keysym_return = NoSymbol;
- return 0;
+ return 0;
}
#endif
- if (event->type != KeyPress)
- lyxerr << "LyXLookupString: wrong event type"
- << event->type << endl;
Status status_return = 0;
-
+
result = XmbLookupString(xic, &event->xkey, buffer_return,
bytes_buffer, keysym_return,
&status_return);
lyxerr[Debug::KEY] << "XBufferOverflow" << endl;
break;
case XLookupBoth:
- lyxerr[Debug::KEY] << "XLookupBoth"
+ lyxerr[Debug::KEY] << "XLookupBoth "
<< string(buffer_return, result)
<< endl;
break;
lyxerr[Debug::KEY] << "XLookupChars "
<< string(buffer_return, result)
<< endl;
-
+
*keysym_return = NoSymbol;
break;
case XLookupKeySym:
// This is called after the main window has been destroyed
-void CloseLyXLookup()
+void CloseLyXLookup()
{
if (xic) {
lyxerr[Debug::KEY] << "CloseLyXLookup: destroying input context"
XComposeStatus compose_status= {0, 0};
// This is called after the main LyX window has been created
-void InitLyXLookup(Display *, Window )
+void InitLyXLookup(Display *, Window)
{
//Nothing to do.
}
// This is called instead of XLookupString(). I this particular case,
// this *is* XLookupString...
-int LyXLookupString(XEvent * event,
+int LyXLookupString(XEvent * event,
char * buffer_return, int bytes_buffer,
- KeySym * keysym_return)
+ KeySym * keysym_return)
{
return XLookupString(&event->xkey, buffer_return,
bytes_buffer, keysym_return,
}
// This is called after the main window has been destroyed
-void CloseLyXLookup()
+void CloseLyXLookup()
{
// Nothing to do
}
#endif // HAVE_XOPENIM
-
-#endif