summaryrefslogtreecommitdiffstats
path: root/hacks/glx/engine.c
diff options
context:
space:
mode:
authorSimon Rettberg2019-02-18 11:55:41 +0100
committerSimon Rettberg2019-02-18 11:55:41 +0100
commitae69a754244c4e475c8d2591772ca8e005071d83 (patch)
tree58b3fa7abc2dcfe3c23e1c0ce108950c720826ab /hacks/glx/engine.c
parentUpdate gitignore (diff)
downloadxscreensaver-ae69a754244c4e475c8d2591772ca8e005071d83.tar.gz
xscreensaver-ae69a754244c4e475c8d2591772ca8e005071d83.tar.xz
xscreensaver-ae69a754244c4e475c8d2591772ca8e005071d83.zip
Update to 5.42
Diffstat (limited to 'hacks/glx/engine.c')
-rw-r--r--hacks/glx/engine.c17
1 files changed, 15 insertions, 2 deletions
diff --git a/hacks/glx/engine.c b/hacks/glx/engine.c
index 0f39b8d..ba30d81 100644
--- a/hacks/glx/engine.c
+++ b/hacks/glx/engine.c
@@ -27,7 +27,6 @@
"*suppressRotationAnimation: True\n" \
"*titleFont: -*-helvetica-medium-r-normal-*-*-180-*-*-*-*-*-*\n" \
-# define free_engine 0
# define release_engine 0
# include "xlockmore.h" /* from the xscreensaver distribution */
#else /* !STANDALONE */
@@ -985,7 +984,7 @@ ENTRYPOINT void draw_engine(ModeInfo *mi)
if (!e->glx_context)
return;
- glXMakeCurrent(disp, w, *(e->glx_context));
+ glXMakeCurrent(disp, w, *e->glx_context);
mi->polygon_count = display(mi);
@@ -1001,6 +1000,20 @@ ENTRYPOINT void draw_engine(ModeInfo *mi)
glXSwapBuffers(disp, w);
}
+
+ENTRYPOINT void free_engine(ModeInfo *mi)
+{
+ Engine *e = &engine[MI_SCREEN(mi)];
+ if (!e->glx_context) return;
+ glXMakeCurrent (MI_DISPLAY(mi), MI_WINDOW(mi), *e->glx_context);
+ if (e->font_data) free_texture_font (e->font_data);
+ free (e->engine_name);
+ gltrackball_free (e->trackball);
+ free_rotator (e->rot);
+ if (glIsList(e->piston_list)) glDeleteLists(e->piston_list, 1);
+ if (glIsList(e->shaft_list)) glDeleteLists(e->shaft_list, 1);
+}
+
XSCREENSAVER_MODULE ("Engine", engine)
#endif