summaryrefslogtreecommitdiff
path: root/body/c_fl_surface_device.cpp
diff options
context:
space:
mode:
authorJedidiah Barber <contact@jedbarber.id.au>2025-01-21 21:04:54 +1300
committerJedidiah Barber <contact@jedbarber.id.au>2025-01-21 21:04:54 +1300
commitb4438b2fbe895694be98e6e8426103deefc51448 (patch)
tree760d86cd7c06420a91dad102cc9546aee73146fc /body/c_fl_surface_device.cpp
parenta4703a65b015140cd4a7a985db66264875ade734 (diff)
Split public API and private implementation files into different directories
Diffstat (limited to 'body/c_fl_surface_device.cpp')
-rw-r--r--body/c_fl_surface_device.cpp58
1 files changed, 58 insertions, 0 deletions
diff --git a/body/c_fl_surface_device.cpp b/body/c_fl_surface_device.cpp
new file mode 100644
index 0000000..9836a04
--- /dev/null
+++ b/body/c_fl_surface_device.cpp
@@ -0,0 +1,58 @@
+
+
+// Programmed by Jedidiah Barber
+// Released into the public domain
+
+
+#include <FL/Fl_Device.H>
+#include "c_fl_surface_device.h"
+
+
+
+
+// Adding relevant friends
+
+class My_Surface_Device : public Fl_Surface_Device {
+public:
+ using Fl_Surface_Device::Fl_Surface_Device;
+ friend SURFACEDEVICE new_fl_surface_device(void * g);
+};
+
+
+
+
+// Flattened C API
+
+SURFACEDEVICE new_fl_surface_device(void * g) {
+ My_Surface_Device *s = new My_Surface_Device(static_cast<Fl_Graphics_Driver*>(g));
+ return s;
+}
+
+void free_fl_surface_device(SURFACEDEVICE s) {
+ delete static_cast<My_Surface_Device*>(s);
+}
+
+
+
+
+void fl_surface_device_set_current(SURFACEDEVICE s) {
+ // virtual so disable dispatch
+ static_cast<Fl_Surface_Device*>(s)->Fl_Surface_Device::set_current();
+}
+
+SURFACEDEVICE fl_surface_device_get_surface(void) {
+ return Fl_Surface_Device::surface();
+}
+
+
+
+
+void * fl_surface_device_get_driver(SURFACEDEVICE s) {
+ return static_cast<Fl_Surface_Device*>(s)->driver();
+}
+
+void fl_surface_device_set_driver(SURFACEDEVICE s, void * g) {
+ static_cast<Fl_Surface_Device*>(s)->driver(static_cast<Fl_Graphics_Driver*>(g));
+}
+
+