summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--FL/fl_types.h3
-rw-r--r--ide/Xcode3.1/FLTK.xcodeproj/project.pbxproj4
-rw-r--r--test/menubar.cxx12
-rw-r--r--test/utf8.cxx10
4 files changed, 24 insertions, 5 deletions
diff --git a/FL/fl_types.h b/FL/fl_types.h
index e676a621e..d87cd7387 100644
--- a/FL/fl_types.h
+++ b/FL/fl_types.h
@@ -52,6 +52,9 @@ typedef char *Fl_String;
typedef const char *Fl_CString;
/** 24-bit Unicode character + 8-bit indicator for keyboard flags */
+typedef unsigned int Fl_Shortcut;
+
+/** 24-bit Unicode character - upper 8-bits are unused */
typedef unsigned int Fl_Char;
/*@}*/ /* group: Miscellaneous */
diff --git a/ide/Xcode3.1/FLTK.xcodeproj/project.pbxproj b/ide/Xcode3.1/FLTK.xcodeproj/project.pbxproj
index e1d60772d..9440718d0 100644
--- a/ide/Xcode3.1/FLTK.xcodeproj/project.pbxproj
+++ b/ide/Xcode3.1/FLTK.xcodeproj/project.pbxproj
@@ -3928,9 +3928,9 @@
C9A3E9590DD6338B00486E4F /* Library Sources */ = {
isa = PBXGroup;
children = (
- C9A3EAD60DD634CC00486E4F /* Fl_get_system_colors.cxx */,
- C9A3EAD70DD634CC00486E4F /* Fl_get_key_win32.cxx */,
C9A3EAD80DD634CC00486E4F /* Fl_get_key_mac.cxx */,
+ C9A3EAD70DD634CC00486E4F /* Fl_get_key_win32.cxx */,
+ C9A3EAD60DD634CC00486E4F /* Fl_get_system_colors.cxx */,
C9A3EAD90DD634CC00486E4F /* Fl_get_key.cxx */,
C9A3EADA0DD634CC00486E4F /* fl_font_xft.cxx */,
C9A3EADB0DD634CC00486E4F /* fl_font_x.cxx */,
diff --git a/test/menubar.cxx b/test/menubar.cxx
index eb80dd43b..6149a7ada 100644
--- a/test/menubar.cxx
+++ b/test/menubar.cxx
@@ -141,6 +141,16 @@ Fl_Menu_Item menutable[] = {
{"Shadow", 0, 0, 0, 0, FL_SHADOW_LABEL},
{"@->", 0, 0, 0, 0, FL_SYMBOL_LABEL},
{0},
+ {"&International",0,0,0,FL_SUBMENU},
+ {"Sharp Ess",0x0000df},
+ {"A Umlaut",0x0000c4},
+ {"a Umlaut",0x0000e4},
+ {"Euro currency",0x0020ac},
+ {"the &ü Umlaut"},
+ {"the capital &Ü"},
+ {"convert ¥ to &£"},
+ {"convert £ to &¥"},
+ {0},
{"E&mpty",0,0,0,FL_SUBMENU},
{0},
{"&Inactive", 0, 0, 0, FL_MENU_INACTIVE|FL_SUBMENU},
@@ -167,7 +177,7 @@ Fl_Menu_Item pulldown[] = {
{0}
};
-#define WIDTH 600
+#define WIDTH 700
Fl_Menu_* menus[4];
diff --git a/test/utf8.cxx b/test/utf8.cxx
index 40eb12c90..ee418b44b 100644
--- a/test/utf8.cxx
+++ b/test/utf8.cxx
@@ -490,9 +490,10 @@ public:
case FL_DND_RELEASE: return 1;
case FL_PASTE:
{
+ static const char lut[] = "0123456789abcdef";
const char *t = Fl::event_text();
int i, n;
- fl_utf8decode(t, t+Fl::event_length(), &n);
+ unsigned int ucode = fl_utf8decode(t, t+Fl::event_length(), &n);
if (n==0) {
value("");
return 1;
@@ -501,10 +502,15 @@ public:
for (i=0; i<n; i++) *d++ = t[i];
*d++ = ' ';
for (i=0; i<n; i++) {
- const char lut[] = "0123456789abcdef";
*d++ = '\\'; *d++ = 'x';
*d++ = lut[(t[i]>>4)&0x0f]; *d++ = lut[t[i]&0x0f];
}
+ *d++ = ' ';
+ *d++ = '0';
+ *d++ = 'x';
+ *d++ = lut[(ucode>>20)&0x0f]; *d++ = lut[(ucode>>16)&0x0f];
+ *d++ = lut[(ucode>>12)&0x0f]; *d++ = lut[(ucode>>8)&0x0f];
+ *d++ = lut[(ucode>>4)&0x0f]; *d++ = lut[ucode&0x0f];
*d++ = 0;
value(buffer);
}