summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--c_fl_button.cpp15
-rw-r--r--c_fl_button.h4
-rw-r--r--c_fl_check_button.cpp16
-rw-r--r--c_fl_check_button.h15
-rw-r--r--c_fl_light_button.cpp16
-rw-r--r--c_fl_light_button.h15
-rw-r--r--c_fl_radio_button.cpp16
-rw-r--r--c_fl_radio_button.h15
-rw-r--r--c_fl_radio_light_button.cpp16
-rw-r--r--c_fl_radio_light_button.h15
-rw-r--r--c_fl_radio_round_button.cpp16
-rw-r--r--c_fl_radio_round_button.h15
-rw-r--r--c_fl_repeat_button.cpp16
-rw-r--r--c_fl_repeat_button.h15
-rw-r--r--c_fl_return_button.cpp16
-rw-r--r--c_fl_return_button.h15
-rw-r--r--c_fl_round_button.cpp16
-rw-r--r--c_fl_round_button.h15
-rw-r--r--c_fl_toggle_button.cpp16
-rw-r--r--c_fl_toggle_button.h15
-rw-r--r--c_fl_widget.cpp20
-rw-r--r--c_fl_widget.h4
-rw-r--r--fltk-enums.ads12
-rw-r--r--fltk-widget-button-light-check.adb53
-rw-r--r--fltk-widget-button-light-check.ads25
-rw-r--r--fltk-widget-button-light-radio.adb53
-rw-r--r--fltk-widget-button-light-radio.ads25
-rw-r--r--fltk-widget-button-light-round-radio.adb53
-rw-r--r--fltk-widget-button-light-round-radio.ads25
-rw-r--r--fltk-widget-button-light-round.adb53
-rw-r--r--fltk-widget-button-light-round.ads25
-rw-r--r--fltk-widget-button-light.adb53
-rw-r--r--fltk-widget-button-light.ads25
-rw-r--r--fltk-widget-button-radio.adb53
-rw-r--r--fltk-widget-button-radio.ads25
-rw-r--r--fltk-widget-button-repeat.adb53
-rw-r--r--fltk-widget-button-repeat.ads25
-rw-r--r--fltk-widget-button-ret.adb53
-rw-r--r--fltk-widget-button-ret.ads26
-rw-r--r--fltk-widget-button-toggle.adb53
-rw-r--r--fltk-widget-button-toggle.ads25
-rw-r--r--fltk-widget-button.adb48
-rw-r--r--fltk-widget-button.ads20
-rw-r--r--fltk-widget.adb60
-rw-r--r--fltk-widget.ads28
45 files changed, 1187 insertions, 6 deletions
diff --git a/c_fl_button.cpp b/c_fl_button.cpp
index 935a14b..dd4286e 100644
--- a/c_fl_button.cpp
+++ b/c_fl_button.cpp
@@ -14,3 +14,18 @@ void free_fl_button(my_fl_button f) {
delete reinterpret_cast<Fl_Button*>(f);
}
+
+int fl_button_get_state(my_fl_button b) {
+ return reinterpret_cast<Fl_Button*>(b)->value();
+}
+
+
+void fl_button_set_state(my_fl_button b, int s) {
+ reinterpret_cast<Fl_Button*>(b)->value(s);
+}
+
+
+void fl_button_set_only(my_fl_button b) {
+ reinterpret_cast<Fl_Button*>(b)->setonly();
+}
+
diff --git a/c_fl_button.h b/c_fl_button.h
index a83e3d8..21e18dc 100644
--- a/c_fl_button.h
+++ b/c_fl_button.h
@@ -10,6 +10,10 @@ typedef void* my_fl_button;
extern "C" my_fl_button new_fl_button(int x, int y, int w, int h, char * label);
extern "C" void free_fl_button(my_fl_button f);
+extern "C" int fl_button_get_state(my_fl_button b);
+extern "C" void fl_button_set_state(my_fl_button b, int s);
+extern "C" void fl_button_set_only(my_fl_button b);
+
#endif
diff --git a/c_fl_check_button.cpp b/c_fl_check_button.cpp
new file mode 100644
index 0000000..2eafd0f
--- /dev/null
+++ b/c_fl_check_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Check_Button.H>
+#include "c_fl_check_button.h"
+
+
+my_fl_check_button new_fl_check_button(int x, int y, int w, int h, char * label) {
+ Fl_Check_Button *button = new Fl_Check_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_check_button(my_fl_check_button b) {
+ delete reinterpret_cast<Fl_Check_Button*>(b);
+}
+
diff --git a/c_fl_check_button.h b/c_fl_check_button.h
new file mode 100644
index 0000000..23834df
--- /dev/null
+++ b/c_fl_check_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_CHECK_BUTTON_GUARD
+#define FL_CHECK_BUTTON_GUARD
+
+
+typedef void* my_fl_check_button;
+
+
+extern "C" my_fl_check_button new_fl_check_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_check_button(my_fl_check_button b);
+
+
+#endif
+
diff --git a/c_fl_light_button.cpp b/c_fl_light_button.cpp
new file mode 100644
index 0000000..31faff3
--- /dev/null
+++ b/c_fl_light_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Light_Button.H>
+#include "c_fl_light_button.h"
+
+
+my_fl_light_button new_fl_light_button(int x, int y, int w, int h, char * label) {
+ Fl_Light_Button *button = new Fl_Light_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_light_button(my_fl_light_button b) {
+ delete reinterpret_cast<Fl_Light_Button*>(b);
+}
+
diff --git a/c_fl_light_button.h b/c_fl_light_button.h
new file mode 100644
index 0000000..0aa8bd8
--- /dev/null
+++ b/c_fl_light_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_LIGHT_BUTTON_GUARD
+#define FL_LIGHT_BUTTON_GUARD
+
+
+typedef void* my_fl_light_button;
+
+
+extern "C" my_fl_light_button new_fl_light_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_light_button(my_fl_light_button b);
+
+
+#endif
+
diff --git a/c_fl_radio_button.cpp b/c_fl_radio_button.cpp
new file mode 100644
index 0000000..56f16c9
--- /dev/null
+++ b/c_fl_radio_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Radio_Button.H>
+#include "c_fl_radio_button.h"
+
+
+my_fl_radio_button new_fl_radio_button(int x, int y, int w, int h, char * label) {
+ Fl_Radio_Button *button = new Fl_Radio_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_radio_button(my_fl_radio_button b) {
+ delete reinterpret_cast<Fl_Radio_Button*>(b);
+}
+
diff --git a/c_fl_radio_button.h b/c_fl_radio_button.h
new file mode 100644
index 0000000..06c3afc
--- /dev/null
+++ b/c_fl_radio_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_RADIO_BUTTON_GUARD
+#define FL_RADIO_BUTTON_GUARD
+
+
+typedef void* my_fl_radio_button;
+
+
+extern "C" my_fl_radio_button new_fl_radio_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_radio_button(my_fl_radio_button b);
+
+
+#endif
+
diff --git a/c_fl_radio_light_button.cpp b/c_fl_radio_light_button.cpp
new file mode 100644
index 0000000..82fafd6
--- /dev/null
+++ b/c_fl_radio_light_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Radio_Light_Button.H>
+#include "c_fl_radio_light_button.h"
+
+
+my_fl_radio_light_button new_fl_radio_light_button(int x, int y, int w, int h, char * label) {
+ Fl_Radio_Light_Button *button = new Fl_Radio_Light_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_radio_light_button(my_fl_radio_light_button b) {
+ delete reinterpret_cast<Fl_Radio_Light_Button*>(b);
+}
+
diff --git a/c_fl_radio_light_button.h b/c_fl_radio_light_button.h
new file mode 100644
index 0000000..21bc675
--- /dev/null
+++ b/c_fl_radio_light_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_RADIO_LIGHT_BUTTON_GUARD
+#define FL_RADIO_LIGHT_BUTTON_GUARD
+
+
+typedef void* my_fl_radio_light_button;
+
+
+extern "C" my_fl_radio_light_button new_fl_radio_light_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_radio_light_button(my_fl_radio_light_button b);
+
+
+#endif
+
diff --git a/c_fl_radio_round_button.cpp b/c_fl_radio_round_button.cpp
new file mode 100644
index 0000000..9e7943c
--- /dev/null
+++ b/c_fl_radio_round_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Radio_Round_Button.H>
+#include "c_fl_radio_round_button.h"
+
+
+my_fl_radio_round_button new_fl_radio_round_button(int x, int y, int w, int h, char * label) {
+ Fl_Radio_Round_Button *button = new Fl_Radio_Round_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_radio_round_button(my_fl_radio_round_button b) {
+ delete reinterpret_cast<Fl_Radio_Round_Button*>(b);
+}
+
diff --git a/c_fl_radio_round_button.h b/c_fl_radio_round_button.h
new file mode 100644
index 0000000..acf3936
--- /dev/null
+++ b/c_fl_radio_round_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_RADIO_ROUND_BUTTON_GUARD
+#define FL_RADIO_ROUND_BUTTON_GUARD
+
+
+typedef void* my_fl_radio_round_button;
+
+
+extern "C" my_fl_radio_round_button new_fl_radio_round_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_radio_round_button(my_fl_radio_round_button b);
+
+
+#endif
+
diff --git a/c_fl_repeat_button.cpp b/c_fl_repeat_button.cpp
new file mode 100644
index 0000000..d81f301
--- /dev/null
+++ b/c_fl_repeat_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Repeat_Button.H>
+#include "c_fl_repeat_button.h"
+
+
+my_fl_repeat_button new_fl_repeat_button(int x, int y, int w, int h, char * label) {
+ Fl_Repeat_Button *button = new Fl_Repeat_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_repeat_button(my_fl_repeat_button b) {
+ delete reinterpret_cast<Fl_Repeat_Button*>(b);
+}
+
diff --git a/c_fl_repeat_button.h b/c_fl_repeat_button.h
new file mode 100644
index 0000000..9712f41
--- /dev/null
+++ b/c_fl_repeat_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_REPEAT_BUTTON_GUARD
+#define FL_REPEAT_BUTTON_GUARD
+
+
+typedef void* my_fl_repeat_button;
+
+
+extern "C" my_fl_repeat_button new_fl_repeat_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_repeat_button(my_fl_repeat_button b);
+
+
+#endif
+
diff --git a/c_fl_return_button.cpp b/c_fl_return_button.cpp
new file mode 100644
index 0000000..fb0ade2
--- /dev/null
+++ b/c_fl_return_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Return_Button.H>
+#include "c_fl_return_button.h"
+
+
+my_fl_return_button new_fl_return_button(int x, int y, int w, int h, char * label) {
+ Fl_Return_Button *button = new Fl_Return_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_return_button(my_fl_return_button b) {
+ delete reinterpret_cast<Fl_Return_Button*>(b);
+}
+
diff --git a/c_fl_return_button.h b/c_fl_return_button.h
new file mode 100644
index 0000000..84274af
--- /dev/null
+++ b/c_fl_return_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_RETURN_BUTTON_GUARD
+#define FL_RETURN_BUTTON_GUARD
+
+
+typedef void* my_fl_return_button;
+
+
+extern "C" my_fl_return_button new_fl_return_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_return_button(my_fl_return_button b);
+
+
+#endif
+
diff --git a/c_fl_round_button.cpp b/c_fl_round_button.cpp
new file mode 100644
index 0000000..aec7ada
--- /dev/null
+++ b/c_fl_round_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Round_Button.H>
+#include "c_fl_round_button.h"
+
+
+my_fl_round_button new_fl_round_button(int x, int y, int w, int h, char * label) {
+ Fl_Round_Button *button = new Fl_Round_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_round_button(my_fl_round_button b) {
+ delete reinterpret_cast<Fl_Round_Button*>(b);
+}
+
diff --git a/c_fl_round_button.h b/c_fl_round_button.h
new file mode 100644
index 0000000..3cca483
--- /dev/null
+++ b/c_fl_round_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_ROUND_BUTTON_GUARD
+#define FL_ROUND_BUTTON_GUARD
+
+
+typedef void* my_fl_round_button;
+
+
+extern "C" my_fl_round_button new_fl_round_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_round_button(my_fl_round_button b);
+
+
+#endif
+
diff --git a/c_fl_toggle_button.cpp b/c_fl_toggle_button.cpp
new file mode 100644
index 0000000..db89a86
--- /dev/null
+++ b/c_fl_toggle_button.cpp
@@ -0,0 +1,16 @@
+
+
+#include <FL/Fl_Toggle_Button.H>
+#include "c_fl_toggle_button.h"
+
+
+my_fl_toggle_button new_fl_toggle_button(int x, int y, int w, int h, char * label) {
+ Fl_Toggle_Button *button = new Fl_Toggle_Button(x, y, w, h, label);
+ return button;
+}
+
+
+void free_fl_toggle_button(my_fl_toggle_button b) {
+ delete reinterpret_cast<Fl_Toggle_Button*>(b);
+}
+
diff --git a/c_fl_toggle_button.h b/c_fl_toggle_button.h
new file mode 100644
index 0000000..a5d7f13
--- /dev/null
+++ b/c_fl_toggle_button.h
@@ -0,0 +1,15 @@
+
+
+#ifndef FL_TOGGLE_BUTTON_GUARD
+#define FL_TOGGLE_BUTTON_GUARD
+
+
+typedef void* my_fl_toggle_button;
+
+
+extern "C" my_fl_toggle_button new_fl_toggle_button(int x, int y, int w, int h, char * label);
+extern "C" void free_fl_toggle_button(my_fl_toggle_button b);
+
+
+#endif
+
diff --git a/c_fl_widget.cpp b/c_fl_widget.cpp
index cf99c41..8a9e897 100644
--- a/c_fl_widget.cpp
+++ b/c_fl_widget.cpp
@@ -23,3 +23,23 @@ void fl_widget_set_label_font(my_fl_widget w, int f) {
reinterpret_cast<Fl_Widget*>(w)->labelfont(static_cast<Fl_Font>(f));
}
+
+int fl_widget_get_label_size(my_fl_widget w) {
+ return reinterpret_cast<Fl_Widget*>(w)->labelsize();
+}
+
+
+void fl_widget_set_label_size(my_fl_widget w, int s) {
+ reinterpret_cast<Fl_Widget*>(w)->labelsize(static_cast<Fl_Fontsize>(s));
+}
+
+
+int fl_widget_get_label_type(my_fl_widget w) {
+ return reinterpret_cast<Fl_Widget*>(w)->labeltype();
+}
+
+
+void fl_widget_set_label_type(my_fl_widget w, int l) {
+ reinterpret_cast<Fl_Widget*>(w)->labeltype(static_cast<Fl_Labeltype>(l));
+}
+
diff --git a/c_fl_widget.h b/c_fl_widget.h
index 40d22f3..9fb5385 100644
--- a/c_fl_widget.h
+++ b/c_fl_widget.h
@@ -11,6 +11,10 @@ extern "C" int fl_widget_get_box(my_fl_widget w);
extern "C" void fl_widget_set_box(my_fl_widget w, int b);
extern "C" int fl_widget_get_label_font(my_fl_widget w);
extern "C" void fl_widget_set_label_font(my_fl_widget w, int f);
+extern "C" int fl_widget_get_label_size(my_fl_widget w);
+extern "C" void fl_widget_set_label_size(my_fl_widget w, int s);
+extern "C" int fl_widget_get_label_type(my_fl_widget w);
+extern "C" void fl_widget_set_label_type(my_fl_widget w, int l);
#endif
diff --git a/fltk-enums.ads b/fltk-enums.ads
index da4920d..00a56c2 100644
--- a/fltk-enums.ads
+++ b/fltk-enums.ads
@@ -83,5 +83,17 @@ package FLTK.Enums is
Free_Font);
+ type Label_Kind is
+ (Normal_Label,
+ No_Label,
+ Shadow_Label,
+ Engraved_Label,
+ Embossed_Label,
+ Multi_Label,
+ Icon_Label,
+ Image_Label,
+ Free_Label);
+
+
end FLTK.Enums;
diff --git a/fltk-widget-button-light-check.adb b/fltk-widget-button-light-check.adb
new file mode 100644
index 0000000..0be477e
--- /dev/null
+++ b/fltk-widget-button-light-check.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Light.Check is
+
+
+ function new_fl_check_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_check_button, "new_fl_check_button");
+
+ procedure free_fl_check_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_check_button, "free_fl_check_button");
+
+
+
+
+ procedure Finalize (This : in out Check_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_check_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Check_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_check_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Light.Check;
+
diff --git a/fltk-widget-button-light-check.ads b/fltk-widget-button-light-check.ads
new file mode 100644
index 0000000..14eab60
--- /dev/null
+++ b/fltk-widget-button-light-check.ads
@@ -0,0 +1,25 @@
+
+
+package FLTK.Widget.Button.Light.Check is
+
+
+ type Check_Type is new Light_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Check_Type;
+
+
+private
+
+
+ type Check_Type is new Light_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Check_Type);
+
+
+end FLTK.Widget.Button.Light.Check;
+
diff --git a/fltk-widget-button-light-radio.adb b/fltk-widget-button-light-radio.adb
new file mode 100644
index 0000000..d3a5e48
--- /dev/null
+++ b/fltk-widget-button-light-radio.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Light.Radio is
+
+
+ function new_fl_radio_light_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_radio_light_button, "new_fl_radio_light_button");
+
+ procedure free_fl_radio_light_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_radio_light_button, "free_fl_radio_light_button");
+
+
+
+
+ procedure Finalize (This : in out Radio_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_radio_light_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Radio_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_radio_light_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Light.Radio;
+
diff --git a/fltk-widget-button-light-radio.ads b/fltk-widget-button-light-radio.ads
new file mode 100644
index 0000000..bf78d65
--- /dev/null
+++ b/fltk-widget-button-light-radio.ads
@@ -0,0 +1,25 @@
+
+
+package FLTK.Widget.Button.Light.Radio is
+
+
+ type Radio_Type is new Light_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Radio_Type;
+
+
+private
+
+
+ type Radio_Type is new Light_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Radio_Type);
+
+
+end FLTK.Widget.Button.Light.Radio;
+
diff --git a/fltk-widget-button-light-round-radio.adb b/fltk-widget-button-light-round-radio.adb
new file mode 100644
index 0000000..d3a857d
--- /dev/null
+++ b/fltk-widget-button-light-round-radio.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Light.Round.Radio is
+
+
+ function new_fl_radio_round_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_radio_round_button, "new_fl_radio_round_button");
+
+ procedure free_fl_radio_round_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_radio_round_button, "free_fl_radio_round_button");
+
+
+
+
+ procedure Finalize (This : in out Radio_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_radio_round_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Radio_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_radio_round_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Light.Round.Radio;
+
diff --git a/fltk-widget-button-light-round-radio.ads b/fltk-widget-button-light-round-radio.ads
new file mode 100644
index 0000000..c0e4f38
--- /dev/null
+++ b/fltk-widget-button-light-round-radio.ads
@@ -0,0 +1,25 @@
+
+
+package FLTK.Widget.Button.Light.Round.Radio is
+
+
+ type Radio_Type is new Round_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Radio_Type;
+
+
+private
+
+
+ type Radio_Type is new Round_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Radio_Type);
+
+
+end FLTK.Widget.Button.Light.Round.Radio;
+
diff --git a/fltk-widget-button-light-round.adb b/fltk-widget-button-light-round.adb
new file mode 100644
index 0000000..bda70f4
--- /dev/null
+++ b/fltk-widget-button-light-round.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Light.Round is
+
+
+ function new_fl_round_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_round_button, "new_fl_round_button");
+
+ procedure free_fl_round_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_round_button, "free_fl_round_button");
+
+
+
+
+ procedure Finalize (This : in out Round_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_round_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Round_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_round_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Light.Round;
+
diff --git a/fltk-widget-button-light-round.ads b/fltk-widget-button-light-round.ads
new file mode 100644
index 0000000..e440b1a
--- /dev/null
+++ b/fltk-widget-button-light-round.ads
@@ -0,0 +1,25 @@
+
+
+package FLTK.Widget.Button.Light.Round is
+
+
+ type Round_Type is new Light_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Round_Type;
+
+
+private
+
+
+ type Round_Type is new Light_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Round_Type);
+
+
+end FLTK.Widget.Button.Light.Round;
+
diff --git a/fltk-widget-button-light.adb b/fltk-widget-button-light.adb
new file mode 100644
index 0000000..6f76890
--- /dev/null
+++ b/fltk-widget-button-light.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Light is
+
+
+ function new_fl_light_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_light_button, "new_fl_light_button");
+
+ procedure free_fl_light_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_light_button, "free_fl_light_button");
+
+
+
+
+ procedure Finalize (This : in out Light_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_light_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Light_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_light_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Light;
+
diff --git a/fltk-widget-button-light.ads b/fltk-widget-button-light.ads
new file mode 100644
index 0000000..bbc2c9e
--- /dev/null
+++ b/fltk-widget-button-light.ads
@@ -0,0 +1,25 @@
+
+
+package FLTK.Widget.Button.Light is
+
+
+ type Light_Type is new Button_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Light_Type;
+
+
+private
+
+
+ type Light_Type is new Button_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Light_Type);
+
+
+end FLTK.Widget.Button.Light;
+
diff --git a/fltk-widget-button-radio.adb b/fltk-widget-button-radio.adb
new file mode 100644
index 0000000..4af17e4
--- /dev/null
+++ b/fltk-widget-button-radio.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Radio is
+
+
+ function new_fl_radio_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_radio_button, "new_fl_radio_button");
+
+ procedure free_fl_radio_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_radio_button, "free_fl_radio_button");
+
+
+
+
+ procedure Finalize (This : in out Radio_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_radio_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Radio_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_radio_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Radio;
+
diff --git a/fltk-widget-button-radio.ads b/fltk-widget-button-radio.ads
new file mode 100644
index 0000000..2c36c77
--- /dev/null
+++ b/fltk-widget-button-radio.ads
@@ -0,0 +1,25 @@
+
+
+package FLTK.Widget.Button.Radio is
+
+
+ type Radio_Type is new Button_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Radio_Type;
+
+
+private
+
+
+ type Radio_Type is new Button_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Radio_Type);
+
+
+end FLTK.Widget.Button.Radio;
+
diff --git a/fltk-widget-button-repeat.adb b/fltk-widget-button-repeat.adb
new file mode 100644
index 0000000..3bdc52b
--- /dev/null
+++ b/fltk-widget-button-repeat.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Repeat is
+
+
+ function new_fl_repeat_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_repeat_button, "new_fl_repeat_button");
+
+ procedure free_fl_repeat_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_repeat_button, "free_fl_repeat_button");
+
+
+
+
+ procedure Finalize (This : in out Repeat_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_repeat_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Repeat_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_repeat_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Repeat;
+
diff --git a/fltk-widget-button-repeat.ads b/fltk-widget-button-repeat.ads
new file mode 100644
index 0000000..d7cd383
--- /dev/null
+++ b/fltk-widget-button-repeat.ads
@@ -0,0 +1,25 @@
+
+
+package FLTK.Widget.Button.Repeat is
+
+
+ type Repeat_Type is new Button_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Repeat_Type;
+
+
+private
+
+
+ type Repeat_Type is new Button_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Repeat_Type);
+
+
+end FLTK.Widget.Button.Repeat;
+
diff --git a/fltk-widget-button-ret.adb b/fltk-widget-button-ret.adb
new file mode 100644
index 0000000..8f68341
--- /dev/null
+++ b/fltk-widget-button-ret.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Ret is
+
+
+ function new_fl_return_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_return_button, "new_fl_return_button");
+
+ procedure free_fl_return_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_return_button, "free_fl_return_button");
+
+
+
+
+ procedure Finalize (This : in out Return_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_return_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Return_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_return_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Ret;
+
diff --git a/fltk-widget-button-ret.ads b/fltk-widget-button-ret.ads
new file mode 100644
index 0000000..ed0da3c
--- /dev/null
+++ b/fltk-widget-button-ret.ads
@@ -0,0 +1,26 @@
+
+
+-- FLTK.Widget.Button.Return, but return is a reserved word
+package FLTK.Widget.Button.Ret is
+
+
+ type Return_Type is new Button_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Return_Type;
+
+
+private
+
+
+ type Return_Type is new Button_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Return_Type);
+
+
+end FLTK.Widget.Button.Ret;
+
diff --git a/fltk-widget-button-toggle.adb b/fltk-widget-button-toggle.adb
new file mode 100644
index 0000000..3bd692c
--- /dev/null
+++ b/fltk-widget-button-toggle.adb
@@ -0,0 +1,53 @@
+
+
+with Interfaces.C;
+with System;
+use type System.Address;
+
+
+package body FLTK.Widget.Button.Toggle is
+
+
+ function new_fl_toggle_button
+ (X, Y, W, H : in Interfaces.C.int;
+ L : in Interfaces.C.char_array)
+ return System.Address;
+ pragma Import (C, new_fl_toggle_button, "new_fl_toggle_button");
+
+ procedure free_fl_toggle_button
+ (B : in System.Address);
+ pragma Import (C, free_fl_toggle_button, "free_fl_toggle_button");
+
+
+
+
+ procedure Finalize (This : in out Toggle_Type) is
+ begin
+ if (This.Void_Ptr /= System.Null_Address) then
+ free_fl_toggle_button (This.Void_Ptr);
+ end if;
+ end Finalize;
+
+
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Toggle_Type is
+
+ VP : System.Address;
+
+ begin
+ VP := new_fl_toggle_button
+ (Interfaces.C.int (X),
+ Interfaces.C.int (Y),
+ Interfaces.C.int (W),
+ Interfaces.C.int (H),
+ Interfaces.C.To_C (Label));
+ return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
+ end Create;
+
+
+end FLTK.Widget.Button.Toggle;
+
diff --git a/fltk-widget-button-toggle.ads b/fltk-widget-button-toggle.ads
new file mode 100644
index 0000000..e9d185e
--- /dev/null
+++ b/fltk-widget-button-toggle.ads
@@ -0,0 +1,25 @@
+
+
+package FLTK.Widget.Button.Toggle is
+
+
+ type Toggle_Type is new Button_Type with private;
+
+
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Toggle_Type;
+
+
+private
+
+
+ type Toggle_Type is new Button_Type with null record;
+
+
+ overriding procedure Finalize (This : in out Toggle_Type);
+
+
+end FLTK.Widget.Button.Toggle;
+
diff --git a/fltk-widget-button.adb b/fltk-widget-button.adb
index 8ec03ce..238e761 100644
--- a/fltk-widget-button.adb
+++ b/fltk-widget-button.adb
@@ -14,9 +14,24 @@ package body FLTK.Widget.Button is
return System.Address;
pragma Import (C, new_fl_button, "new_fl_button");
- procedure free_fl_button (B : in System.Address);
+ procedure free_fl_button
+ (B : in System.Address);
pragma Import (C, free_fl_button, "free_fl_button");
+ function fl_button_get_state
+ (B : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_button_get_state, "fl_button_get_state");
+
+ procedure fl_button_set_state
+ (B : in System.Address;
+ S : in Interfaces.C.int);
+ pragma Import (C, fl_button_set_state, "fl_button_set_state");
+
+ procedure fl_button_set_only
+ (B : in System.Address);
+ pragma Import (C, fl_button_set_only, "fl_button_set_only");
+
@@ -38,7 +53,6 @@ package body FLTK.Widget.Button is
VP : System.Address;
begin
-
VP := new_fl_button
(Interfaces.C.int (X),
Interfaces.C.int (Y),
@@ -46,9 +60,37 @@ package body FLTK.Widget.Button is
Interfaces.C.int (H),
Interfaces.C.To_C (Label));
return (Ada.Finalization.Limited_Controlled with Void_Ptr => VP);
-
end Create;
+
+
+ function Get_State
+ (B : in Button_Type'Class)
+ return State is
+ begin
+ return State'Val (fl_button_get_state (B.Void_Ptr));
+ end Get_State;
+
+
+
+
+ procedure Set_State
+ (B : in Button_Type'Class;
+ S : in State) is
+ begin
+ fl_button_set_state (B.Void_Ptr, State'Pos (S));
+ end Set_State;
+
+
+
+
+ procedure Set_Only
+ (B : in Button_Type'Class) is
+ begin
+ fl_button_set_only (B.Void_Ptr);
+ end Set_Only;
+
+
end FLTK.Widget.Button;
diff --git a/fltk-widget-button.ads b/fltk-widget-button.ads
index 8212fe3..14762bf 100644
--- a/fltk-widget-button.ads
+++ b/fltk-widget-button.ads
@@ -4,9 +4,27 @@ package FLTK.Widget.Button is
type Button_Type is new Widget_Type with private;
+ type State is (On, Off);
- function Create (X, Y, W, H : Integer; Label : String) return Button_Type;
+ function Create
+ (X, Y, W, H : Integer;
+ Label : String)
+ return Button_Type;
+
+
+ function Get_State
+ (B : in Button_Type'Class)
+ return State;
+
+
+ procedure Set_State
+ (B : in Button_Type'Class;
+ S : in State);
+
+
+ procedure Set_Only
+ (B : in Button_Type'Class);
private
diff --git a/fltk-widget.adb b/fltk-widget.adb
index 7f3edd6..a19969f 100644
--- a/fltk-widget.adb
+++ b/fltk-widget.adb
@@ -27,6 +27,26 @@ package body FLTK.Widget is
F : in Interfaces.C.int);
pragma Import (C, fl_widget_set_label_font, "fl_widget_set_label_font");
+ function fl_widget_get_label_size
+ (W : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_widget_get_label_size, "fl_widget_get_label_size");
+
+ procedure fl_widget_set_label_size
+ (W : in System.Address;
+ S : in Interfaces.C.int);
+ pragma Import (C, fl_widget_set_label_size, "fl_widget_set_label_size");
+
+ function fl_widget_get_label_type
+ (W : in System.Address)
+ return Interfaces.C.int;
+ pragma Import (C, fl_widget_get_label_type, "fl_widget_get_label_type");
+
+ procedure fl_widget_set_label_type
+ (W : in System.Address;
+ L : in Interfaces.C.int);
+ pragma Import (C, fl_widget_set_label_type, "fl_widget_set_label_type");
+
@@ -76,5 +96,45 @@ package body FLTK.Widget is
end Set_Label_Font;
+
+
+ function Get_Label_Size
+ (W : in Widget_Type'Class)
+ return Font_Size is
+ begin
+ return Font_Size (fl_widget_get_label_size (W.Void_Ptr));
+ end Get_Label_Size;
+
+
+
+
+ procedure Set_Label_Size
+ (W : in Widget_Type'Class;
+ S : in Font_Size) is
+ begin
+ fl_widget_set_label_size (W.Void_Ptr, Interfaces.C.int (S));
+ end Set_Label_Size;
+
+
+
+
+ function Get_Label_Type
+ (W : in Widget_Type'Class)
+ return Label_Kind is
+ begin
+ return Label_Kind'Val (fl_widget_get_label_type (W.Void_Ptr));
+ end Get_Label_Type;
+
+
+
+
+ procedure Set_Label_Type
+ (W : in Widget_Type'Class;
+ L : in Label_Kind) is
+ begin
+ fl_widget_set_label_type (W.Void_Ptr, Label_Kind'Pos (L));
+ end Set_Label_Type;
+
+
end FLTK.Widget;
diff --git a/fltk-widget.ads b/fltk-widget.ads
index 1e56c4f..a8b2b27 100644
--- a/fltk-widget.ads
+++ b/fltk-widget.ads
@@ -1,14 +1,18 @@
with FLTK.Enums; use FLTK.Enums;
-private with Ada.Finalization;
+with Ada.Finalization;
private with System;
package FLTK.Widget is
- type Widget_Type is abstract tagged limited private;
+ type Widget_Type is abstract new Ada.Finalization.Limited_Controlled with private;
+
+
+ type Font_Size is new Natural;
+ Normal_Size : constant Font_Size := 14;
function Create
@@ -37,6 +41,26 @@ package FLTK.Widget is
F : in Font_Kind);
+ function Get_Label_Size
+ (W : in Widget_Type'Class)
+ return Font_Size;
+
+
+ procedure Set_Label_Size
+ (W : in Widget_Type'Class;
+ S : in Font_Size);
+
+
+ function Get_Label_Type
+ (W : in Widget_Type'Class)
+ return Label_Kind;
+
+
+ procedure Set_Label_Type
+ (W : in Widget_Type'Class;
+ L : in Label_Kind);
+
+
private