summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJed Barber <jjbarber@y7mail.com>2018-05-04 02:07:02 +1000
committerJed Barber <jjbarber@y7mail.com>2018-05-04 02:07:02 +1000
commit6e8b2cd87a74ac8d1366775186f35268837523e1 (patch)
tree418696736aa9ff94446796688fc7f3b905e2e84f
parent6bb8375e7f8f5a888b0fa800ba09c1e5a950399d (diff)
Finished and polished FLTK.Menu_Items
-rw-r--r--doc/fl_menu_item.html532
-rw-r--r--progress.txt2
-rw-r--r--src/c_fl_menuitem.cpp133
-rw-r--r--src/c_fl_menuitem.h49
-rw-r--r--src/fltk-menu_items.adb441
-rw-r--r--src/fltk-menu_items.ads174
-rw-r--r--src/fltk-widgets-menus.adb10
-rw-r--r--src/fltk-widgets-menus.ads27
-rw-r--r--src/fltk.adb10
-rw-r--r--src/fltk.ads24
10 files changed, 1339 insertions, 63 deletions
diff --git a/doc/fl_menu_item.html b/doc/fl_menu_item.html
new file mode 100644
index 0000000..d259fb5
--- /dev/null
+++ b/doc/fl_menu_item.html
@@ -0,0 +1,532 @@
+
+<!DOCTYPE html>
+
+<html lang="en">
+ <head>
+ <meta charset="utf-8">
+ <title>Fl_Menu_Item Binding Map</title>
+ <link href="map.css" rel="stylesheet">
+ </head>
+
+ <body>
+
+
+<h2>Fl_Menu_Item Binding Map</h2>
+
+
+<table class="package">
+ <tr><th colspan="2">Package name</th></tr>
+
+ <tr>
+ <td>Fl_Menu_Item</td>
+ <td>FLTK.Menu_Items</td>
+ </tr>
+
+</table>
+
+
+
+<table class="type">
+ <tr><th colspan="2">Types</th></tr>
+
+ <tr>
+ <td>Fl_Menu_Item</td>
+ <td>Menu_Item</td>
+ </tr>
+
+ <tr>
+ <td>&nbsp;</td>
+ <td>Menu_Item_Reference</td>
+ </tr>
+
+</table>
+
+
+
+<table class="function">
+ <tr><th colspan="2">Functions and Procedures</th></tr>
+
+ <tr>
+<td>N/A due to being a struct, not a class</td>
+<td><pre>
+function Create
+ (Text : in String;
+ Action : in FLTK.Widgets.Widget_Callback := null;
+ Shortcut : in Key_Combo := No_Key;
+ Flags : in Menu_Flag := Flag_Normal)
+ return Menu_Item;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void activate();
+</pre></td>
+<td><pre>
+procedure Activate
+ (Item : in out Menu_Item);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+int active() const;
+</pre></td>
+<td><pre>
+function Is_Active
+ (Item : in Menu_Item)
+ return Boolean;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+int activevisible() const;
+</pre></td>
+<td><pre>
+function Is_Active_And_Visible
+ (Item : in Menu_Item)
+ return Boolean;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+int add(const char *, int shortcut, Fl_Callback *, void *=0, int=0);
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+int add(const char *a, const char *b, Fl_Callback *c, void *d=0, int e=0);
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+long argument() const;
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+void argument(long v);
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+Fl_Callback_p callback() const;
+</pre></td>
+<td><pre>
+function Get_Callback
+ (Item : in Menu_Item)
+ return FLTK.Widgets.Widget_Callback;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void callback(Fl_Callback *c, void *p);
+void callback(Fl_Callback *c);
+void callback(Fl_Callback0 *c);
+void callback(Fl_Callback1 *c, long p=0);
+</pre></td>
+<td><pre>
+procedure Set_Callback
+ (Item : in out Menu_Item;
+ Func : in FLTK.Widgets.Widget_Callback);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void check();
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+int checkbox() const;
+</pre></td>
+<td><pre>
+function Has_Checkbox
+ (Item : in Menu_Item)
+ return Boolean;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+int checked() const;
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+void clear();
+</pre></td>
+<td><pre>
+procedure Set_State
+ (Item : in out Menu_Item;
+ To : in Boolean);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void deactivate();
+</pre></td>
+<td><pre>
+procedure Deactivate
+ (Item : in out Menu_Item);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void do_callback(Fl_Widget *o) const;
+void do_callback(Fl_Widget *o, void *arg) const;
+void do_callback(Fl_Widget *o, long arg) const;
+</pre></td>
+<td><pre>
+procedure Do_Callback
+ (Item : in out Menu_Item;
+ Widget : in out FLTK.Widgets.Widget'Class);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void draw(int x, int y, int w, int h, const Fl_Menu_ *, int t=0) const;
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+const Fl_Menu_Item * find_shortcut(int *ip=0, const bool require_alt=false) const;
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+const Fl_Menu_Item * first() const;
+Fl_Menu_Item * first();
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+void hide();
+</pre></td>
+<td><pre>
+procedure Hide
+ (Item : in out Menu_Item);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void image(Fl_Image *a);
+void image(Fl_Image &a);
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+int insert(int, const char *, int, Fl_Callback *, void *=0, int=0);
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+const char * label() const;
+</pre></td>
+<td><pre>
+function Get_Label
+ (Item : in Menu_Item)
+ return String;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void label(const char *a);
+</pre></td>
+<td><pre>
+procedure Set_Label
+ (Item : in out Menu_Item;
+ Text : in String);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void label(Fl_Labeltype a, const char *b);
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+Fl_Color labelcolor() const;
+</pre></td>
+<td><pre>
+function Get_Label_Color
+ (Item : in Menu_Item)
+ return Color;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void labelcolor(Fl_Color a);
+</pre></td>
+<td><pre>
+procedure Set_Label_Color
+ (Item : in out Menu_Item;
+ To : in Color);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+Fl_Font labelfont() const;
+</pre></td>
+<td><pre>
+function Get_Label_Font
+ (Item : in Menu_Item)
+ return Font_Kind;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void labelfont(Fl_Font a);
+</pre></td>
+<td><pre>
+procedure Set_Label_Font
+ (Item : in out Menu_Item;
+ To : in Font_Kind);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+Fl_Fontsize labelsize() const;
+</pre></td>
+<td><pre>
+function Get_Label_Size
+ (Item : in Menu_Item)
+ return Font_Size;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void labelsize(Fl_Fontsize a);
+</pre></td>
+<td><pre>
+procedure Set_Label_Size
+ (Item : in out Menu_Item;
+ To : in Font_Size);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+Fl_Labeltype labeltype() const;
+</pre></td>
+<td><pre>
+function Get_Label_Type
+ (Item : in Menu_Item)
+ return Label_Kind;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void labeltype(Fl_Labeltype a);
+</pre></td>
+<td><pre>
+procedure Set_Label_Type
+ (Item : in out Menu_Item;
+ To : in Label_Kind);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+int measure(int *h, const Fl_Menu_ *) const;
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+const Fl_Menu_Item * next(int=1) const;
+Fl_Menu_Item * next(int i=1);
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+const Fl_Menu_Item * popup
+ (int X, int Y, const char *title=0,
+ const Fl_Menu_Item *picked=0, const Fl_Menu_*=0) const;
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+const Fl_Menu_Item * pulldown
+ (int X, int Y, int W, int H,
+ const Fl_Menu_Item *picked=0, const Fl_Menu_*=0,
+ const Fl_Menu_Item *title=0, int menubar=0) const;
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+int radio() const;
+</pre></td>
+<td><pre>
+function Is_Radio
+ (Item : in Menu_Item)
+ return Boolean;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void set();
+</pre></td>
+<td>See void clear();</td>
+ </tr>
+
+ <tr>
+<td><pre>
+void setonly();
+</pre></td>
+<td><pre>
+procedure Set_Only
+ (Item : in out Menu_Item);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+int shortcut() const;
+</pre></td>
+<td><pre>
+function Get_Shortcut
+ (Item : in Menu_Item)
+ return Key_Combo;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void shortcut(int s);
+</pre></td>
+<td><pre>
+procedure Set_Shortcut
+ (Item : in out Menu_Item;
+ To : in Key_Combo);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+void show();
+</pre></td>
+<td><pre>
+procedure Show
+ (Item : in out Menu_Item);
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+int size() const;
+</pre></td>
+<td>See Fl_Menu</td>
+ </tr>
+
+ <tr>
+<td><pre>
+int submenu() const;
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+const Fl_Menu_Item * test_shortcut() const;
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+void uncheck();
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+void * user_data() const;
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+void user_data(void *v);
+</pre></td>
+<td>&nbsp;</td>
+ </tr>
+
+ <tr>
+<td><pre>
+int value() const;
+</pre></td>
+<td><pre>
+function Get_State
+ (Item : in Menu_Item)
+ return Boolean;
+</pre></td>
+ </tr>
+
+ <tr>
+<td><pre>
+int visible() const;
+</pre></td>
+<td><pre>
+function Is_Visible
+ (Item : in Menu_Item)
+ return Boolean;
+</pre></td>
+ </tr>
+
+</table>
+
+
+ </body>
+</html>
+
diff --git a/progress.txt b/progress.txt
index a9a1f4e..c391560 100644
--- a/progress.txt
+++ b/progress.txt
@@ -27,6 +27,7 @@ FLTK.Images.RGB.JPEG
FLTK.Images.RGB.PNG
FLTK.Images.RGB.PNM
FLTK.Images.Shared
+FLTK.Menu_Items
FLTK.Text_Buffers
FLTK.Tooltips
FLTK.Widgets.Boxes
@@ -104,7 +105,6 @@ FLTK
FLTK.Devices.Graphics
FLTK.Devices.Surfaces
FLTK.Environment
-FLTK.Menu_Items
FLTK.Widgets
FLTK.Widgets.Groups
FLTK.Widgets.Menus
diff --git a/src/c_fl_menuitem.cpp b/src/c_fl_menuitem.cpp
index 631fdd4..342f98b 100644
--- a/src/c_fl_menuitem.cpp
+++ b/src/c_fl_menuitem.cpp
@@ -1,23 +1,150 @@
#include <FL/Fl_Menu_Item.H>
+#include <FL/Fl_Widget.H>
#include "c_fl_menuitem.h"
-int fl_menuitem_value(MENUITEM mi) {
+void * new_fl_menu_item(char * t, void * c, unsigned long s, unsigned long f) {
+ Fl_Menu_Item *mi = new Fl_Menu_Item;
+ mi->callback(reinterpret_cast<Fl_Callback*>(c));
+ mi->flags = static_cast<int>(f);
+ mi->shortcut(static_cast<int>(s));
+ mi->label(t);
+ return mi;
+}
+
+void free_fl_menu_item(MENU_ITEM mi) {
+ delete reinterpret_cast<Fl_Menu_Item*>(mi);
+}
+
+
+
+
+void * fl_menu_item_get_user_data(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->user_data();
+}
+
+void fl_menu_item_set_user_data(MENU_ITEM mi, void * c) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->user_data(c);
+}
+
+void fl_menu_item_do_callback(MENU_ITEM mi, void * w) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->do_callback(reinterpret_cast<Fl_Widget*>(w));
+}
+
+
+
+
+int fl_menu_item_checkbox(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->checkbox();
+}
+
+int fl_menu_item_radio(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->radio();
+}
+
+int fl_menu_item_value(MENU_ITEM mi) {
return reinterpret_cast<Fl_Menu_Item*>(mi)->value();
}
+void fl_menu_item_set(MENU_ITEM mi) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->set();
+}
+
+void fl_menu_item_clear(MENU_ITEM mi) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->clear();
+}
+
+void fl_menu_item_setonly(MENU_ITEM mi) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->setonly();
+}
+
-void fl_menuitem_activate(MENUITEM mi) {
+const char * fl_menu_item_get_label(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->label();
+}
+
+void fl_menu_item_set_label(MENU_ITEM mi, const char *t) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->label(t);
+}
+
+unsigned int fl_menu_item_get_labelcolor(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->labelcolor();
+}
+
+void fl_menu_item_set_labelcolor(MENU_ITEM mi, unsigned int c) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->labelcolor(c);
+}
+
+int fl_menu_item_get_labelfont(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->labelfont();
+}
+
+void fl_menu_item_set_labelfont(MENU_ITEM mi, int f) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->labelfont(f);
+}
+
+int fl_menu_item_get_labelsize(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->labelsize();
+}
+
+void fl_menu_item_set_labelsize(MENU_ITEM mi, int s) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->labelsize(s);
+}
+
+int fl_menu_item_get_labeltype(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->labeltype();
+}
+
+void fl_menu_item_set_labeltype(MENU_ITEM mi, int t) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->labeltype(static_cast<Fl_Labeltype>(t));
+}
+
+
+
+
+int fl_menu_item_get_shortcut(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->shortcut();
+}
+
+void fl_menu_item_set_shortcut(MENU_ITEM mi, int s) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->shortcut(s);
+}
+
+
+
+
+void fl_menu_item_activate(MENU_ITEM mi) {
reinterpret_cast<Fl_Menu_Item*>(mi)->activate();
}
-void fl_menuitem_deactivate(MENUITEM mi) {
+void fl_menu_item_deactivate(MENU_ITEM mi) {
reinterpret_cast<Fl_Menu_Item*>(mi)->deactivate();
}
+void fl_menu_item_show(MENU_ITEM mi) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->show();
+}
+
+void fl_menu_item_hide(MENU_ITEM mi) {
+ reinterpret_cast<Fl_Menu_Item*>(mi)->hide();
+}
+
+int fl_menu_item_active(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->active();
+}
+
+int fl_menu_item_visible(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->visible();
+}
+
+int fl_menu_item_activevisible(MENU_ITEM mi) {
+ return reinterpret_cast<Fl_Menu_Item*>(mi)->activevisible();
+}
+
+
diff --git a/src/c_fl_menuitem.h b/src/c_fl_menuitem.h
index c720557..2e7127c 100644
--- a/src/c_fl_menuitem.h
+++ b/src/c_fl_menuitem.h
@@ -1,21 +1,58 @@
-#ifndef FL_MENUITEM_GUARD
-#define FL_MENUITEM_GUARD
+#ifndef FL_MENU_ITEM_GUARD
+#define FL_MENU_ITEM_GUARD
-typedef void* MENUITEM;
+typedef void* MENU_ITEM;
-extern "C" int fl_menuitem_value(MENUITEM mi);
+extern "C" inline void * new_fl_menu_item(char * t, void * c, unsigned long s, unsigned long f);
+extern "C" inline void free_fl_menu_item(MENU_ITEM mi);
-extern "C" void fl_menuitem_activate(MENUITEM mi);
-extern "C" void fl_menuitem_deactivate(MENUITEM mi);
+
+
+extern "C" inline void * fl_menu_item_get_user_data(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_set_user_data(MENU_ITEM mi, void * c);
+extern "C" inline void fl_menu_item_do_callback(MENU_ITEM mi, void * w);
+
+
+extern "C" inline int fl_menu_item_checkbox(MENU_ITEM mi);
+extern "C" inline int fl_menu_item_radio(MENU_ITEM mi);
+extern "C" inline int fl_menu_item_value(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_set(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_clear(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_setonly(MENU_ITEM mi);
+
+
+extern "C" inline const char * fl_menu_item_get_label(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_set_label(MENU_ITEM mi, const char *t);
+extern "C" inline unsigned int fl_menu_item_get_labelcolor(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_set_labelcolor(MENU_ITEM mi, unsigned int c);
+extern "C" inline int fl_menu_item_get_labelfont(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_set_labelfont(MENU_ITEM mi, int f);
+extern "C" inline int fl_menu_item_get_labelsize(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_set_labelsize(MENU_ITEM mi, int s);
+extern "C" inline int fl_menu_item_get_labeltype(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_set_labeltype(MENU_ITEM mi, int t);
+
+
+extern "C" inline int fl_menu_item_get_shortcut(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_set_shortcut(MENU_ITEM mi, int s);
+
+
+extern "C" inline void fl_menu_item_activate(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_deactivate(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_show(MENU_ITEM mi);
+extern "C" inline void fl_menu_item_hide(MENU_ITEM mi);
+extern "C" inline int fl_menu_item_active(MENU_ITEM mi);
+extern "C" inline int fl_menu_item_visible(MENU_ITEM mi);
+extern "C" inline int fl_menu_item_activevisible(MENU_ITEM mi);
#endif
diff --git a/src/fltk-menu_items.adb b/src/fltk-menu_items.adb
index 80bcea7..a94293f 100644
--- a/src/fltk-menu_items.adb
+++ b/src/fltk-menu_items.adb
@@ -2,58 +2,471 @@
with
- Interfaces.C;
+ System,
+ Interfaces.C.Strings,
+ Ada.Unchecked_Conversion;
use type
+ System.Address,
Interfaces.C.int;
package body FLTK.Menu_Items is
- function fl_menuitem_value
+ function new_fl_menu_item
+ (T : in Interfaces.C.char_array;
+ C : in System.Address;
+ S, F : in Interfaces.C.unsigned_long)
+ return System.Address;
+ pragma Import (C, new_fl_menu_item, "new_fl_menu_item");
+ pragma Inline (new_fl_menu_item);
+
+ procedure free_fl_menu_item
+ (MI : in System.Address);
+ pragma Import (C, free_fl_menu_item, "free_fl_menu_item");
+ pragma Inline (free_fl_menu_item);
+
+
+
+
+ function fl_menu_item_get_user_data
+ (MI : in System.Address)
+ return System.Address;
+ pragma Import (C, fl_menu_item_get_user_data, "fl_menu_item_get_user_data");
+ pragma Inline (fl_menu_item_get_user_data);
+
+ procedure fl_menu_item_set_user_data
+ (MI, C : in System.Address);
+ pragma Import (C, fl_menu_item_set_user_data, "fl_menu_item_set_user_data");
+ pragma Inline (fl_menu_item_set_user_data);
+
+ procedure fl_menu_item_do_callback
+ (MI, W : in System.Address);
+ pragma Import (C, fl_menu_item_do_callback, "fl_menu_item_do_callback");
+ pragma Inline (fl_menu_item_do_callback);
+
+
+
+
+ function fl_menu_item_checkbox
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_checkbox, "fl_menu_item_checkbox");
+ pragma Inline (fl_menu_item_checkbox);
+
+ function fl_menu_item_radio
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_radio, "fl_menu_item_radio");
+ pragma Inline (fl_menu_item_radio);
+
+ function fl_menu_item_value
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_value, "fl_menu_item_value");
+ pragma Inline (fl_menu_item_value);
+
+ procedure fl_menu_item_set
+ (MI : in System.Address);
+ pragma Import (C, fl_menu_item_set, "fl_menu_item_set");
+ pragma Inline (fl_menu_item_set);
+
+ procedure fl_menu_item_clear
+ (MI : in System.Address);
+ pragma Import (C, fl_menu_item_clear, "fl_menu_item_clear");
+ pragma Inline (fl_menu_item_clear);
+
+ procedure fl_menu_item_setonly
+ (MI : in System.Address);
+ pragma Import (C, fl_menu_item_setonly, "fl_menu_item_setonly");
+ pragma Inline (fl_menu_item_setonly);
+
+
+
+
+ function fl_menu_item_get_label
+ (MI : in System.Address)
+ return Interfaces.C.Strings.chars_ptr;
+ pragma Import (C, fl_menu_item_get_label, "fl_menu_item_get_label");
+ pragma Inline (fl_menu_item_get_label);
+
+ procedure fl_menu_item_set_label
+ (MI : in System.Address;
+ T : in Interfaces.C.char_array);
+ pragma Import (C, fl_menu_item_set_label, "fl_menu_item_set_label");
+ pragma Inline (fl_menu_item_set_label);
+
+ function fl_menu_item_get_labelcolor
+ (MI : in System.Address)
+ return Interfaces.C.unsigned;
+ pragma Import (C, fl_menu_item_get_labelcolor, "fl_menu_item_get_labelcolor");
+ pragma Inline (fl_menu_item_get_labelcolor);
+
+ procedure fl_menu_item_set_labelcolor
+ (MI : in System.Address;
+ C : in Interfaces.C.unsigned);
+ pragma Import (C, fl_menu_item_set_labelcolor, "fl_menu_item_set_labelcolor");
+ pragma Inline (fl_menu_item_set_labelcolor);
+
+ function fl_menu_item_get_labelfont
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_get_labelfont, "fl_menu_item_get_labelfont");
+ pragma Inline (fl_menu_item_get_labelfont);
+
+ procedure fl_menu_item_set_labelfont
+ (MI : in System.Address;
+ F : in Interfaces.C.int);
+ pragma Import (C, fl_menu_item_set_labelfont, "fl_menu_item_set_labelfont");
+ pragma Inline (fl_menu_item_set_labelfont);
+
+ function fl_menu_item_get_labelsize
(MI : in System.Address)
return Interfaces.C.int;
- pragma Import (C, fl_menuitem_value, "fl_menuitem_value");
+ pragma Import (C, fl_menu_item_get_labelsize, "fl_menu_item_get_labelsize");
+ pragma Inline (fl_menu_item_get_labelsize);
+ procedure fl_menu_item_set_labelsize
+ (MI : in System.Address;
+ S : in Interfaces.C.int);
+ pragma Import (C, fl_menu_item_set_labelsize, "fl_menu_item_set_labelsize");
+ pragma Inline (fl_menu_item_set_labelsize);
+
+ function fl_menu_item_get_labeltype
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_get_labeltype, "fl_menu_item_get_labeltype");
+ pragma Inline (fl_menu_item_get_labeltype);
+
+ procedure fl_menu_item_set_labeltype
+ (MI : in System.Address;
+ T : in Interfaces.C.int);
+ pragma Import (C, fl_menu_item_set_labeltype, "fl_menu_item_set_labeltype");
+ pragma Inline (fl_menu_item_set_labeltype);
+
+
+
+
+ function fl_menu_item_get_shortcut
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_get_shortcut, "fl_menu_item_get_shortcut");
+ pragma Inline (fl_menu_item_get_shortcut);
+
+ procedure fl_menu_item_set_shortcut
+ (MI : in System.Address;
+ S : in Interfaces.C.int);
+ pragma Import (C, fl_menu_item_set_shortcut, "fl_menu_item_set_shortcut");
+ pragma Inline (fl_menu_item_set_shortcut);
- procedure fl_menuitem_activate
+
+ procedure fl_menu_item_activate
+ (MI : in System.Address);
+ pragma Import (C, fl_menu_item_activate, "fl_menu_item_activate");
+ pragma Inline (fl_menu_item_activate);
+
+ procedure fl_menu_item_deactivate
+ (MI : in System.Address);
+ pragma Import (C, fl_menu_item_deactivate, "fl_menu_item_deactivate");
+ pragma Inline (fl_menu_item_deactivate);
+
+ procedure fl_menu_item_show
(MI : in System.Address);
- pragma Import (C, fl_menuitem_activate, "fl_menuitem_activate");
+ pragma Import (C, fl_menu_item_show, "fl_menu_item_show");
+ pragma Inline (fl_menu_item_show);
- procedure fl_menuitem_deactivate
+ procedure fl_menu_item_hide
(MI : in System.Address);
- pragma Import (C, fl_menuitem_deactivate, "fl_menuitem_deactivate");
+ pragma Import (C, fl_menu_item_hide, "fl_menu_item_hide");
+ pragma Inline (fl_menu_item_hide);
+
+ function fl_menu_item_active
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_active, "fl_menu_item_active");
+ pragma Inline (fl_menu_item_active);
+
+ function fl_menu_item_visible
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_visible, "fl_menu_item_visible");
+ pragma Inline (fl_menu_item_visible);
+
+ function fl_menu_item_activevisible
+ (MI : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_menu_item_activevisible, "fl_menu_item_activevisible");
+ pragma Inline (fl_menu_item_activevisible);
+
+
+
+
+ procedure Finalize
+ (This : in out Menu_Item) is
+ begin
+ if This.Void_Ptr /= System.Null_Address and then
+ This in Menu_Item'Class
+ then
+ if This.Needs_Dealloc then
+ free_fl_menu_item (This.Void_Ptr);
+ end if;
+ This.Void_Ptr := System.Null_Address;
+ end if;
+ end Finalize;
+
+
+
+
+ package Callback_Convert is
+ function To_Pointer is new Ada.Unchecked_Conversion
+ (System.Address, FLTK.Widgets.Widget_Callback);
+ function To_Address is new Ada.Unchecked_Conversion
+ (FLTK.Widgets.Widget_Callback, System.Address);
+ end Callback_Convert;
+
+
+
+
+ package body Forge is
+
+ function Create
+ (Text : in String;
+ Action : in FLTK.Widgets.Widget_Callback := null;
+ Shortcut : in Key_Combo := No_Key;
+ Flags : in Menu_Flag := Flag_Normal)
+ return Menu_Item is
+ begin
+ return Item : Menu_Item do
+ Item.Void_Ptr := new_fl_menu_item
+ (Interfaces.C.To_C (Text),
+ Callback_Convert.To_Address (Action),
+ To_C (Shortcut),
+ Interfaces.C.unsigned_long (Flags));
+ end return;
+ end Create;
+
+ pragma Inline (Create);
+
+ end Forge;
- function Value
+ function Get_Callback
+ (Item : in Menu_Item)
+ return FLTK.Widgets.Widget_Callback is
+ begin
+ return Callback_Convert.To_Pointer
+ (fl_menu_item_get_user_data (Item.Void_Ptr));
+ end Get_Callback;
+
+
+ procedure Set_Callback
+ (Item : in out Menu_Item;
+ Func : in FLTK.Widgets.Widget_Callback) is
+ begin
+ fl_menu_item_set_user_data
+ (Item.Void_Ptr,
+ Callback_Convert.To_Address (Func));
+ end Set_Callback;
+
+
+ procedure Do_Callback
+ (Item : in out Menu_Item;
+ Widget : in out FLTK.Widgets.Widget'Class) is
+ begin
+ fl_menu_item_do_callback (Item.Void_Ptr, Wrapper (Widget).Void_Ptr);
+ end Do_Callback;
+
+
+
+
+ function Has_Checkbox
+ (Item : in Menu_Item)
+ return Boolean is
+ begin
+ return fl_menu_item_checkbox (Item.Void_Ptr) /= 0;
+ end Has_Checkbox;
+
+ function Is_Radio
(Item : in Menu_Item)
return Boolean is
begin
- return fl_menuitem_value (Item.Void_Ptr) /= 0;
- end Value;
+ return fl_menu_item_radio (Item.Void_Ptr) /= 0;
+ end Is_Radio;
+
+ function Get_State
+ (Item : in Menu_Item)
+ return Boolean is
+ begin
+ return fl_menu_item_value (Item.Void_Ptr) /= 0;
+ end Get_State;
+
+ procedure Set_State
+ (Item : in out Menu_Item;
+ To : in Boolean) is
+ begin
+ if To then
+ fl_menu_item_set (Item.Void_Ptr);
+ else
+ fl_menu_item_clear (Item.Void_Ptr);
+ end if;
+ end Set_State;
+
+ procedure Set_Only
+ (Item : in out Menu_Item) is
+ begin
+ fl_menu_item_setonly (Item.Void_Ptr);
+ end Set_Only;
+
+
+
+
+ function Get_Label
+ (Item : in Menu_Item)
+ return String is
+ begin
+ return Interfaces.C.Strings.Value (fl_menu_item_get_label (Item.Void_Ptr));
+ end Get_Label;
+
+ procedure Set_Label
+ (Item : in out Menu_Item;
+ Text : in String) is
+ begin
+ fl_menu_item_set_label (Item.Void_Ptr, Interfaces.C.To_C (Text));
+ end Set_Label;
+
+ function Get_Label_Color
+ (Item : in Menu_Item)
+ return Color is
+ begin
+ return Color (fl_menu_item_get_labelcolor (Item.Void_Ptr));
+ end Get_Label_Color;
+
+ procedure Set_Label_Color
+ (Item : in out Menu_Item;
+ To : in Color) is
+ begin
+ fl_menu_item_set_labelcolor (Item.Void_Ptr, Interfaces.C.unsigned (To));
+ end Set_Label_Color;
+
+ function Get_Label_Font
+ (Item : in Menu_Item)
+ return Font_Kind is
+ begin
+ return Font_Kind'Val (fl_menu_item_get_labelfont (Item.Void_Ptr));
+ end Get_Label_Font;
+
+ procedure Set_Label_Font
+ (Item : in out Menu_Item;
+ To : in Font_Kind) is
+ begin
+ fl_menu_item_set_labelfont (Item.Void_Ptr, Font_Kind'Pos (To));
+ end Set_Label_Font;
+
+ function Get_Label_Size
+ (Item : in Menu_Item)
+ return Font_Size is
+ begin
+ return Font_Size (fl_menu_item_get_labelsize (Item.Void_Ptr));
+ end Get_Label_Size;
+
+ procedure Set_Label_Size
+ (Item : in out Menu_Item;
+ To : in Font_Size) is
+ begin
+ fl_menu_item_set_labelsize (Item.Void_Ptr, Interfaces.C.int (To));
+ end Set_Label_Size;
+
+ function Get_Label_Type
+ (Item : in Menu_Item)
+ return Label_Kind is
+ begin
+ return Label_Kind'Val (fl_menu_item_get_labeltype (Item.Void_Ptr));
+ end Get_Label_Type;
+
+ procedure Set_Label_Type
+ (Item : in out Menu_Item;
+ To : in Label_Kind) is
+ begin
+ fl_menu_item_set_labeltype (Item.Void_Ptr, Label_Kind'Pos (To));
+ end Set_Label_Type;
+
+
+
+
+ function Get_Shortcut
+ (Item : in Menu_Item)
+ return Key_Combo is
+ begin
+ return To_Ada (Interfaces.C.unsigned_long (fl_menu_item_get_shortcut (Item.Void_Ptr)));
+ end Get_Shortcut;
+
+ procedure Set_Shortcut
+ (Item : in out Menu_Item;
+ To : in Key_Combo) is
+ begin
+ fl_menu_item_set_shortcut (Item.Void_Ptr, Interfaces.C.int (To_C (To)));
+ end Set_Shortcut;
procedure Activate
- (Item : in Menu_Item) is
+ (Item : in out Menu_Item) is
begin
- fl_menuitem_activate (Item.Void_Ptr);
+ fl_menu_item_activate (Item.Void_Ptr);
end Activate;
procedure Deactivate
- (Item : in Menu_Item) is
+ (Item : in out Menu_Item) is
begin
- fl_menuitem_deactivate (Item.Void_Ptr);
+ fl_menu_item_deactivate (Item.Void_Ptr);
end Deactivate;
+ procedure Show
+ (Item : in out Menu_Item) is
+ begin
+ fl_menu_item_show (Item.Void_Ptr);
+ end Show;
+
+
+ procedure Hide
+ (Item : in out Menu_Item) is
+ begin
+ fl_menu_item_hide (Item.Void_Ptr);
+ end Hide;
+
+
+ function Is_Active
+ (Item : in Menu_Item)
+ return Boolean is
+ begin
+ return fl_menu_item_active (Item.Void_Ptr) /= 0;
+ end Is_Active;
+
+
+ function Is_Visible
+ (Item : in Menu_Item)
+ return Boolean is
+ begin
+ return fl_menu_item_visible (Item.Void_Ptr) /= 0;
+ end Is_Visible;
+
+
+ function Is_Active_And_Visible
+ (Item : in Menu_Item)
+ return Boolean is
+ begin
+ return fl_menu_item_activevisible (Item.Void_Ptr) /= 0;
+ end Is_Active_And_Visible;
+
+
end FLTK.Menu_Items;
diff --git a/src/fltk-menu_items.ads b/src/fltk-menu_items.ads
index 51aba8b..9f02d27 100644
--- a/src/fltk-menu_items.ads
+++ b/src/fltk-menu_items.ads
@@ -1,25 +1,151 @@
+with
+
+ FLTK.Widgets;
+
package FLTK.Menu_Items is
type Menu_Item is new Wrapper with private;
+ type Menu_Item_Reference (Data : not null access Menu_Item'Class) is limited null record
+ with Implicit_Dereference => Data;
+
+
+
+
+ package Forge is
+
+ -- Usually you don't bother with this and just add items
+ -- to Menus directly using the Add subprograms in that package.
+
+ function Create
+ (Text : in String;
+ Action : in FLTK.Widgets.Widget_Callback := null;
+ Shortcut : in Key_Combo := No_Key;
+ Flags : in Menu_Flag := Flag_Normal)
+ return Menu_Item;
+
+ end Forge;
+
- function Value
+ function Get_Callback
+ (Item : in Menu_Item)
+ return FLTK.Widgets.Widget_Callback;
+
+ procedure Set_Callback
+ (Item : in out Menu_Item;
+ Func : in FLTK.Widgets.Widget_Callback);
+
+ procedure Do_Callback
+ (Item : in out Menu_Item;
+ Widget : in out FLTK.Widgets.Widget'Class);
+
+
+
+
+ function Has_Checkbox
(Item : in Menu_Item)
return Boolean;
+ function Is_Radio
+ (Item : in Menu_Item)
+ return Boolean;
+
+ function Get_State
+ (Item : in Menu_Item)
+ return Boolean;
+
+ procedure Set_State
+ (Item : in out Menu_Item;
+ To : in Boolean);
+
+ procedure Set_Only
+ (Item : in out Menu_Item);
+
+
+
+
+ function Get_Label
+ (Item : in Menu_Item)
+ return String;
+
+ procedure Set_Label
+ (Item : in out Menu_Item;
+ Text : in String);
+
+ function Get_Label_Color
+ (Item : in Menu_Item)
+ return Color;
+
+ procedure Set_Label_Color
+ (Item : in out Menu_Item;
+ To : in Color);
+
+ function Get_Label_Font
+ (Item : in Menu_Item)
+ return Font_Kind;
+
+ procedure Set_Label_Font
+ (Item : in out Menu_Item;
+ To : in Font_Kind);
+
+ function Get_Label_Size
+ (Item : in Menu_Item)
+ return Font_Size;
+
+ procedure Set_Label_Size
+ (Item : in out Menu_Item;
+ To : in Font_Size);
+
+ function Get_Label_Type
+ (Item : in Menu_Item)
+ return Label_Kind;
+
+ procedure Set_Label_Type
+ (Item : in out Menu_Item;
+ To : in Label_Kind);
+
+
+
+
+ function Get_Shortcut
+ (Item : in Menu_Item)
+ return Key_Combo;
+
+ procedure Set_Shortcut
+ (Item : in out Menu_Item;
+ To : in Key_Combo);
+
procedure Activate
- (Item : in Menu_Item);
+ (Item : in out Menu_Item);
procedure Deactivate
- (Item : in Menu_Item);
+ (Item : in out Menu_Item);
+
+ procedure Show
+ (Item : in out Menu_Item);
+
+ procedure Hide
+ (Item : in out Menu_Item);
+
+ function Is_Active
+ (Item : in Menu_Item)
+ return Boolean;
+
+ function Is_Visible
+ (Item : in Menu_Item)
+ return Boolean;
+
+ function Is_Active_And_Visible
+ (Item : in Menu_Item)
+ return Boolean;
private
@@ -27,6 +153,48 @@ private
type Menu_Item is new Wrapper with null record;
+ overriding procedure Finalize
+ (This : in out Menu_Item);
+
+
+
+
+ pragma Inline (Get_Callback);
+ pragma Inline (Set_Callback);
+ pragma Inline (Do_Callback);
+
+
+ pragma Inline (Has_Checkbox);
+ pragma Inline (Is_Radio);
+ pragma Inline (Get_State);
+ pragma Inline (Set_State);
+ pragma Inline (Set_Only);
+
+
+ pragma Inline (Get_Label);
+ pragma Inline (Set_Label);
+ pragma Inline (Get_Label_Color);
+ pragma Inline (Set_Label_Color);
+ pragma Inline (Get_Label_Font);
+ pragma Inline (Set_Label_Font);
+ pragma Inline (Get_Label_Size);
+ pragma Inline (Set_Label_Size);
+ pragma Inline (Get_Label_Type);
+ pragma Inline (Set_Label_Type);
+
+
+ pragma Inline (Get_Shortcut);
+ pragma Inline (Set_Shortcut);
+
+
+ pragma Inline (Activate);
+ pragma Inline (Deactivate);
+ pragma Inline (Show);
+ pragma Inline (Hide);
+ pragma Inline (Is_Active);
+ pragma Inline (Is_Visible);
+ pragma Inline (Is_Active_And_Visible);
+
end FLTK.Menu_Items;
diff --git a/src/fltk-widgets-menus.adb b/src/fltk-widgets-menus.adb
index 0947003..3d8ea0c 100644
--- a/src/fltk-widgets-menus.adb
+++ b/src/fltk-widgets-menus.adb
@@ -16,16 +16,6 @@ use type
package body FLTK.Widgets.Menus is
- function "+"
- (Left, Right : in Menu_Flag)
- return Menu_Flag is
- begin
- return Left or Right;
- end "+";
-
-
-
-
procedure menu_set_draw_hook
(W, D : in System.Address);
pragma Import (C, menu_set_draw_hook, "menu_set_draw_hook");
diff --git a/src/fltk-widgets-menus.ads b/src/fltk-widgets-menus.ads
index 2d36fc9..5d3e599 100644
--- a/src/fltk-widgets-menus.ads
+++ b/src/fltk-widgets-menus.ads
@@ -18,18 +18,7 @@ package FLTK.Widgets.Menus is
type Menu_Cursor (Data : access Menu'Class) is limited null record
with Implicit_Dereference => Data;
- type Index is new Positive;
-
- type Menu_Flag is private;
- function "+" (Left, Right : in Menu_Flag) return Menu_Flag;
- Flag_Normal : constant Menu_Flag;
- Flag_Inactive : constant Menu_Flag;
- Flag_Toggle : constant Menu_Flag;
- Flag_Value : constant Menu_Flag;
- Flag_Radio : constant Menu_Flag;
- Flag_Invisible : constant Menu_Flag;
- Flag_Submenu : constant Menu_Flag;
- Flag_Divider : constant Menu_Flag;
+ subtype Index is Positive;
@@ -89,19 +78,5 @@ private
pragma Convention (C, Item_Hook);
-
-
- type Menu_Flag is new Interfaces.Unsigned_8;
- Flag_Normal : constant Menu_Flag := 2#00000000#;
- Flag_Inactive : constant Menu_Flag := 2#00000001#;
- Flag_Toggle : constant Menu_Flag := 2#00000010#;
- Flag_Value : constant Menu_Flag := 2#00000100#;
- Flag_Radio : constant Menu_Flag := 2#00001000#;
- Flag_Invisible : constant Menu_Flag := 2#00010000#;
- -- Flag_Submenu_Pointer unlikely to be used
- Flag_Submenu : constant Menu_Flag := 2#01000000#;
- Flag_Divider : constant Menu_Flag := 2#10000000#;
-
-
end FLTK.Widgets.Menus;
diff --git a/src/fltk.adb b/src/fltk.adb
index 6bfd6d6..66a4060 100644
--- a/src/fltk.adb
+++ b/src/fltk.adb
@@ -232,5 +232,15 @@ package body FLTK is
end To_Ada;
+
+
+ function "+"
+ (Left, Right : in Menu_Flag)
+ return Menu_Flag is
+ begin
+ return Left or Right;
+ end "+";
+
+
end FLTK;
diff --git a/src/fltk.ads b/src/fltk.ads
index df4967f..81a3763 100644
--- a/src/fltk.ads
+++ b/src/fltk.ads
@@ -205,6 +205,18 @@ package FLTK is
type Event_Outcome is (Not_Handled, Handled);
+ type Menu_Flag is private;
+ function "+" (Left, Right : in Menu_Flag) return Menu_Flag;
+ Flag_Normal : constant Menu_Flag;
+ Flag_Inactive : constant Menu_Flag;
+ Flag_Toggle : constant Menu_Flag;
+ Flag_Value : constant Menu_Flag;
+ Flag_Radio : constant Menu_Flag;
+ Flag_Invisible : constant Menu_Flag;
+ Flag_Submenu : constant Menu_Flag;
+ Flag_Divider : constant Menu_Flag;
+
+
private
@@ -307,5 +319,17 @@ private
Escape_Key : constant Keypress := 16#ff1b#;
+ type Menu_Flag is new Interfaces.Unsigned_8;
+ Flag_Normal : constant Menu_Flag := 2#00000000#;
+ Flag_Inactive : constant Menu_Flag := 2#00000001#;
+ Flag_Toggle : constant Menu_Flag := 2#00000010#;
+ Flag_Value : constant Menu_Flag := 2#00000100#;
+ Flag_Radio : constant Menu_Flag := 2#00001000#;
+ Flag_Invisible : constant Menu_Flag := 2#00010000#;
+ -- Flag_Submenu_Pointer unlikely to be used
+ Flag_Submenu : constant Menu_Flag := 2#01000000#;
+ Flag_Divider : constant Menu_Flag := 2#10000000#;
+
+
end FLTK;