summaryrefslogtreecommitdiff
path: root/gdk/win32/gdkdrawable-win32.c
diff options
context:
space:
mode:
authorTor Lillqvist <tml@iki.fi>1999-10-31 21:35:39 +0000
committerTor Lillqvist <tml@src.gnome.org>1999-10-31 21:35:39 +0000
commit00c5e838710a01ed97a46d96910b6f118d240b99 (patch)
tree2d8a8d72f6e39231ed9fa72a09069025ff559f64 /gdk/win32/gdkdrawable-win32.c
parent241f9c9dabdd3f021adb139b25a455260dc473ae (diff)
downloadgtk+-00c5e838710a01ed97a46d96910b6f118d240b99.tar.gz
Add new keysyms from X11R6.4 (including EuroSign).
1999-10-31 Tor Lillqvist <tml@iki.fi> * gdk/gdkkeysyms.h: Add new keysyms from X11R6.4 (including EuroSign). * gdk/gdktypes.h: Add note about wchar_t not necessarily being the same type as GdkWChar, especially on Win32. * gdk/win32/*.c: Change gdk_root_parent to be a pointer. * gdk/win32/*.c: Assume all strings are UTF-8. Convert to Unicode before passing to Windows GDI for drawing etc. Convert to the system default codepage before passing to Windows as window titles. * gdk/win32/gdkprivate.h: Add more fields to GdkWindowPrivate to support changing input locale on the fly. * gdk/win32/gdkevent.c: Support input language (keyboard locale) on-the-fly changes. Convert incoming characters from the current codepage to Unicode (and then to a UTF-8 multi-byte string) based on the current input language. Use keysym<->Unicode mapping tables and functions borrowed from xterm sources. Support IMEs (Input Method Editors) for CJK languages. On non-CJK editions of Win9x, use the ActiveX-based Active IMM (Input Method Manager) if available. IMEs and the Active IMM are available under the disguise of Chinese, Korean and Japanese support for IE and Outlook Express from "Windows Update" for Win98. On Win2k, the CJK support is present in all editions (as long as you install it). Call DispatchMessage from gdk_events_queue() (and thus gdk_WindowProc()), instead of duplicating the code in gdk_WindowProc(). Reworked the grab handling and propagation code, factored out duplicated code snippets into separate functions. Other cleanups, too. * gdk/win32/surrogate-dimm.h: Provide just the bits we need from the <dimm.h> header describing the Active IMM. * gdk/win32/gdkfont.c: Pretend to support fontsets, but so far just do the same as for "single" fonts. * gdk/win32/gdk.c: Call CoInitialize() (COM initialisation) from gdk_init_check, and CoUninitialize() from gdk_exit_func. Handle the new keysyms from gdkkeysyms.h. * gtk/gtkfontsel.c (Win32): Load the font for the preview as a fontset, so that gtkentry uses wide characters. * gtk/gtkrc.c (Win32): Get the locale with gwin_getlocale(). Call GTk+'s system directory "gtk+", not "gtk".
Diffstat (limited to 'gdk/win32/gdkdrawable-win32.c')
-rw-r--r--gdk/win32/gdkdrawable-win32.c138
1 files changed, 50 insertions, 88 deletions
diff --git a/gdk/win32/gdkdrawable-win32.c b/gdk/win32/gdkdrawable-win32.c
index 593c98cd80..85ca076cce 100644
--- a/gdk/win32/gdkdrawable-win32.c
+++ b/gdk/win32/gdkdrawable-win32.c
@@ -469,47 +469,35 @@ gdk_draw_text (GdkDrawable *drawable,
if (text_length == 0)
return;
+ g_assert (font->type == GDK_FONT_FONT || font->type == GDK_FONT_FONTSET);
+
drawable_private = (GdkDrawablePrivate*) drawable;
gc_private = (GdkGCPrivate*) gc;
font_private = (GdkFontPrivate*) font;
- if (font->type == GDK_FONT_FONT)
- {
- hdc = gdk_gc_predraw (drawable_private, gc_private);
- xfont = (HFONT) font_private->xfont;
-
- GDK_NOTE (MISC, g_print ("gdk_draw_text: %#x (%d) %#x "
- "+%d+%d font: %#x \"%.*s\" length: %d\n",
- drawable_private->xwindow,
- gc_private, gc_private->xgc,
- x, y, xfont,
- (text_length > 10 ? 10 : text_length),
- text, text_length));
-
- if ((oldfont = SelectObject (hdc, xfont)) == NULL)
- g_warning ("gdk_draw_text: SelectObject failed");
- if (font_private->cpinfo.MaxCharSize > 1)
- {
- wcstr = g_new (wchar_t, text_length);
- if ((wlen = MultiByteToWideChar (font_private->codepage, 0,
- text, text_length,
- wcstr, text_length)) == 0)
- g_warning ("gdk_draw_text: MultiByteToWideChar failed");
- else if (!TextOutW (hdc, x, y, wcstr, wlen))
- g_warning ("gdk_draw_text: TextOutW failed");
- g_free (wcstr);
- }
- else
- {
- if (!TextOutA (hdc, x, y, text, text_length))
- g_warning ("gdk_draw_text: TextOutA failed");
- }
- if (oldfont != NULL)
- SelectObject (hdc, oldfont);
- gdk_gc_postdraw (drawable_private, gc_private);
- }
- else
- g_error ("undefined font type");
+ hdc = gdk_gc_predraw (drawable_private, gc_private);
+ xfont = (HFONT) font_private->xfont;
+
+ GDK_NOTE (MISC, g_print ("gdk_draw_text: %#x (%d) %#x "
+ "+%d+%d font: %#x \"%.*s\" length: %d\n",
+ drawable_private->xwindow,
+ gc_private, gc_private->xgc,
+ x, y, xfont,
+ (text_length > 10 ? 10 : text_length),
+ text, text_length));
+
+ if ((oldfont = SelectObject (hdc, xfont)) == NULL)
+ g_warning ("gdk_draw_text: SelectObject failed");
+
+ wcstr = g_new (wchar_t, text_length);
+ if ((wlen = gdk_nmbstowchar_ts (wcstr, text, text_length, text_length)) == -1)
+ g_warning ("gdk_draw_text: gdk_nmbstowchar_ts failed");
+ else if (!TextOutW (hdc, x, y, wcstr, wlen))
+ g_warning ("gdk_draw_text: TextOutW failed");
+ g_free (wcstr);
+ if (oldfont != NULL)
+ SelectObject (hdc, oldfont);
+ gdk_gc_postdraw (drawable_private, gc_private);
}
void
@@ -521,6 +509,8 @@ gdk_draw_text_wc (GdkDrawable *drawable,
const GdkWChar *text,
gint text_length)
{
+ HDC hdc;
+ HGDIOBJ oldfont;
GdkDrawablePrivate *drawable_private;
GdkFontPrivate *font_private;
GdkGCPrivate *gc_private;
@@ -539,68 +529,40 @@ gdk_draw_text_wc (GdkDrawable *drawable,
if (text_length == 0)
return;
+ g_assert (font->type == GDK_FONT_FONT || font->type == GDK_FONT_FONTSET);
+
drawable_private = (GdkDrawablePrivate*) drawable;
gc_private = (GdkGCPrivate*) gc;
font_private = (GdkFontPrivate*) font;
- if (font->type == GDK_FONT_FONT)
- {
- HDC hdc;
- HFONT xfont;
- HGDIOBJ oldfont;
+ hdc = gdk_gc_predraw (drawable_private, gc_private);
- hdc = gdk_gc_predraw (drawable_private, gc_private);
- xfont = (HFONT) font_private->xfont;
-
- GDK_NOTE (MISC, g_print ("gdk_draw_text_wc: %#x (%d) %#x "
- "+%d+%d font: %#x length: %d\n",
- drawable_private->xwindow,
- gc_private, gc_private->xgc,
- x, y, xfont,
- text_length));
+ GDK_NOTE (MISC, g_print ("gdk_draw_text_wc: %#x (%d) %#x "
+ "+%d+%d font: %#x length: %d\n",
+ drawable_private->xwindow,
+ gc_private, gc_private->xgc,
+ x, y, font_private->xfont,
+ text_length));
- if ((oldfont = SelectObject (hdc, xfont)) == NULL)
- g_warning ("gdk_draw_text_wc: SelectObject failed");
-#if 0 /* No. Don't use TextOutW directly. Compare to the X11 version,
- * it uses plain XDrawString for GDK_FONT_FONT fonts, too.
- * TextOutW by definition interprets the string as Unicode.
- * We don't have that, but either chars from some single-byte codepage
- * or from a DBCS.
- */
+ if ((oldfont = SelectObject (hdc, font_private->xfont)) == NULL)
+ g_warning ("gdk_draw_text_wc: SelectObject failed");
+ if (sizeof (wchar_t) != sizeof (GdkWChar))
+ {
wcstr = g_new (wchar_t, text_length);
for (i = 0; i < text_length; i++)
wcstr[i] = text[i];
- if (!TextOutW (hdc, x, y, wcstr, text_length))
- g_warning ("gdk_draw_text_wc: TextOutW failed");
- g_free (wcstr);
-#else
- str = g_new (guchar, text_length);
- for (i = 0; i < text_length; i++)
- str[i] = text[i];
- if (font_private->cpinfo.MaxCharSize > 1)
- {
- wcstr = g_new (wchar_t, text_length);
- if ((wlen = MultiByteToWideChar (font_private->codepage, 0,
- str, text_length,
- wcstr, text_length)) == 0)
- g_warning ("gdk_draw_text: MultiByteToWideChar failed");
- else if (!TextOutW (hdc, x, y, wcstr, wlen))
- g_warning ("gdk_draw_text_wc: TextOutW failed");
- g_free (wcstr);
- }
- else
- {
- if (!TextOutA (hdc, x, y, str, text_length))
- g_warning ("gdk_draw_text_wc: TextOutA failed");
- }
- g_free (str);
-#endif
- if (oldfont != NULL)
- SelectObject (hdc, oldfont);
- gdk_gc_postdraw (drawable_private, gc_private);
}
else
- g_error ("undefined font type");
+ wcstr = (wchar_t *) text;
+
+ if (!TextOutW (hdc, x, y, wcstr, text_length))
+ g_warning ("gdk_draw_text_wc: TextOutW failed");
+
+ if (sizeof (wchar_t) != sizeof (GdkWChar))
+ g_free (wcstr);
+ if (oldfont != NULL)
+ SelectObject (hdc, oldfont);
+ gdk_gc_postdraw (drawable_private, gc_private);
}
void