summaryrefslogtreecommitdiffstats
path: root/platform/haiku/os_haiku.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'platform/haiku/os_haiku.cpp')
-rw-r--r--platform/haiku/os_haiku.cpp46
1 files changed, 38 insertions, 8 deletions
diff --git a/platform/haiku/os_haiku.cpp b/platform/haiku/os_haiku.cpp
index 7c207f265b..103b1ac748 100644
--- a/platform/haiku/os_haiku.cpp
+++ b/platform/haiku/os_haiku.cpp
@@ -1,3 +1,5 @@
+#include "servers/visual/visual_server_raster.h"
+#include "drivers/gles2/rasterizer_gles2.h"
#include "os_haiku.h"
OS_Haiku::OS_Haiku() {
@@ -5,17 +7,13 @@ OS_Haiku::OS_Haiku() {
};
void OS_Haiku::run() {
-
+
}
String OS_Haiku::get_name() {
return "Haiku";
}
-void OS_Haiku::delete_main_loop() {
-
-}
-
int OS_Haiku::get_video_driver_count() const {
}
@@ -29,19 +27,51 @@ OS::VideoMode OS_Haiku::get_default_video_mode() const {
}
void OS_Haiku::initialize(const VideoMode& p_desired, int p_video_driver, int p_audio_driver) {
-
+ main_loop = NULL;
+
+#if defined(OPENGL_ENABLED) || defined(LEGACYGL_ENABLED)
+ //context_gl = memnew( ContextGL_X11( x11_display, x11_window,current_videomode, false ) );
+ //context_gl->initialize();
+
+ rasterizer = memnew(RasterizerGLES2);
+#endif
+
+ visual_server = memnew(VisualServerRaster(rasterizer));
+
+ if (get_render_thread_mode() != RENDER_THREAD_UNSAFE) {
+ visual_server = memnew(VisualServerWrapMT(visual_server, get_render_thread_mode() == RENDER_SEPARATE_THREAD));
+ }
}
void OS_Haiku::finalize() {
-
+ if (main_loop) {
+ memdelete(main_loop);
+ }
+
+ main_loop = NULL;
+
+ visual_server->finish();
+ memdelete(visual_server);
+ memdelete(rasterizer);
}
void OS_Haiku::set_main_loop(MainLoop* p_main_loop) {
+ main_loop = p_main_loop;
+ // TODO: enable
+ //input->set_main_loop(p_main_loop);
}
MainLoop* OS_Haiku::get_main_loop() const {
-
+ return main_loop;
+}
+
+void OS_Haiku::delete_main_loop() {
+ if (main_loop) {
+ memdelete(main_loop);
+ }
+
+ main_loop = NULL;
}
bool OS_Haiku::can_draw() const {