From http://www.jwz.org/xscreensaver/xscreensaver-5.38.tar.gz
[xscreensaver] / hacks / laser.c
index e681f99def3015ad538962e0e8451d4a8a4c04c0..8ee02193e4043a1770af2b1579f8b05a1ab8873e 100644 (file)
@@ -35,6 +35,7 @@ static const char sccsid[] = "@(#)laser.c     5.00 2000/11/01 xlockmore";
                                        "*fpsSolid: true \n" \
 
 # define BRIGHT_COLORS
+# define release_laser 0
 # define reshape_laser 0
 # define laser_handle_event 0
 # include "xlockmore.h"                /* in xscreensaver distribution */
@@ -49,8 +50,8 @@ ENTRYPOINT ModeSpecOpt laser_opts =
 
 #ifdef USE_MODULES
 ModStruct   laser_description =
-{"laser", "init_laser", "draw_laser", "release_laser",
- "refresh_laser", "init_laser", (char *) NULL, &laser_opts,
+{"laser", "init_laser", "draw_laser", (char *) NULL,
+ "refresh_laser", "init_laser", "free_laser", &laser_opts,
  20000, -10, 200, 1, 64, 1.0, "",
  "Shows spinning lasers", 0, NULL};
 
@@ -106,9 +107,12 @@ typedef struct {
 
 static lasersstruct *lasers = (lasersstruct *) NULL;
 
-static void
-free_laser(Display *display, lasersstruct *lp)
+ENTRYPOINT void
+free_laser(ModeInfo * mi)
 {
+       Display *display = MI_DISPLAY(mi);
+       lasersstruct *lp = &lasers[MI_SCREEN(mi)];
+
        if (lp->laser != NULL) {
                (void) free((void *) lp->laser);
                lp->laser = (laserstruct *) NULL;
@@ -126,11 +130,7 @@ init_laser(ModeInfo * mi)
        int         i, c = 0;
        lasersstruct *lp;
 
-       if (lasers == NULL) {
-               if ((lasers = (lasersstruct *) calloc(MI_NUM_SCREENS(mi),
-                                            sizeof (lasersstruct))) == NULL)
-                       return;
-       }
+       MI_INIT (mi, lasers);
        lp = &lasers[MI_SCREEN(mi)];
 
        lp->width = MI_WIDTH(mi);
@@ -151,7 +151,7 @@ init_laser(ModeInfo * mi)
        if (lp->laser == NULL) {
                if ((lp->laser = (laserstruct *) malloc(lp->ln *
                                sizeof (laserstruct))) == NULL) {
-                       free_laser(display, lp);
+                       free_laser(mi);
                        return;
                }
        }
@@ -163,10 +163,10 @@ init_laser(ModeInfo * mi)
                lp->gcv_black.foreground = MI_BLACK_PIXEL(mi);
                if ((lp->stippledGC = XCreateGC(display, MI_WINDOW(mi),
                                GCForeground | GCBackground, &gcv)) == None) {
-                       free_laser(display, lp);
+                       free_laser(mi);
                        return;
                }
-# ifdef HAVE_COCOA
+# ifdef HAVE_JWXYZ
     jwxyz_XSetAntiAliasing (MI_DISPLAY(mi), lp->stippledGC, False);
 # endif
        }
@@ -342,24 +342,13 @@ draw_laser(ModeInfo * mi)
                init_laser(mi);
 }
 
-ENTRYPOINT void
-release_laser(ModeInfo * mi)
-{
-       if (lasers != NULL) {
-               int         screen;
-
-               for (screen = 0; screen < MI_NUM_SCREENS(mi); screen++)
-                       free_laser(MI_DISPLAY(mi), &lasers[screen]);
-               (void) free((void *) lasers);
-               lasers = (lasersstruct *) NULL;
-       }
-}
-
+#ifndef STANDALONE
 ENTRYPOINT void
 refresh_laser(ModeInfo * mi)
 {
        MI_CLEARWINDOW(mi);
 }
+#endif
 
 XSCREENSAVER_MODULE ("Laser", laser)