diff options
author | wiz <wiz@pkgsrc.org> | 2003-06-24 10:22:46 +0000 |
---|---|---|
committer | wiz <wiz@pkgsrc.org> | 2003-06-24 10:22:46 +0000 |
commit | 1a898aa4600aad4007beffdd372c18c955afa37b (patch) | |
tree | ba355d0e1a92995689263e68af3010552c4a5837 | |
parent | bc27e29fe2ae95b3f160c8b2d32b47ceaaf9ff7a (diff) | |
download | pkgsrc-1a898aa4600aad4007beffdd372c18c955afa37b.tar.gz |
Update to 4.11:
* New hacks, `hypertorus', `cubestorm', `glknots', `blocktube',
and `glmatrix'.
* Updates to `cloudlife', `engine', `xmatrix', and `sonar'.
* Rewrote `glslideshow': it should work on somewhat wimpier
video cards now.
* Various portability tweaks.
-rw-r--r-- | x11/xscreensaver-gnome/PLIST | 37 | ||||
-rw-r--r-- | x11/xscreensaver/Makefile.common | 4 | ||||
-rw-r--r-- | x11/xscreensaver/PLIST | 37 | ||||
-rw-r--r-- | x11/xscreensaver/distinfo | 8 | ||||
-rw-r--r-- | x11/xscreensaver/patches/patch-ae | 863 |
5 files changed, 69 insertions, 880 deletions
diff --git a/x11/xscreensaver-gnome/PLIST b/x11/xscreensaver-gnome/PLIST index db1b02de426..7d31c98d23b 100644 --- a/x11/xscreensaver-gnome/PLIST +++ b/x11/xscreensaver-gnome/PLIST @@ -1,4 +1,4 @@ -@comment $NetBSD: PLIST,v 1.13 2003/05/23 09:39:53 wiz Exp $ +@comment $NetBSD: PLIST,v 1.14 2003/06/24 10:22:47 wiz Exp $ bin/screensaver-properties-capplet bin/xscreensaver bin/xscreensaver-command @@ -18,6 +18,7 @@ libexec/xscreensaver/atunnel libexec/xscreensaver/barcode libexec/xscreensaver/blaster libexec/xscreensaver/blitspin +libexec/xscreensaver/blocktube libexec/xscreensaver/bouboule libexec/xscreensaver/bouncingcow libexec/xscreensaver/boxed @@ -35,6 +36,7 @@ libexec/xscreensaver/coral libexec/xscreensaver/critical libexec/xscreensaver/crystal libexec/xscreensaver/cubenetic +libexec/xscreensaver/cubestorm libexec/xscreensaver/cynosure libexec/xscreensaver/dangerball libexec/xscreensaver/decayscreen @@ -64,6 +66,8 @@ libexec/xscreensaver/gears libexec/xscreensaver/gflux libexec/xscreensaver/glblur libexec/xscreensaver/glforestfire +libexec/xscreensaver/glknots +libexec/xscreensaver/glmatrix libexec/xscreensaver/glplanet libexec/xscreensaver/glslideshow libexec/xscreensaver/glsnake @@ -77,6 +81,7 @@ libexec/xscreensaver/helix libexec/xscreensaver/hopalong libexec/xscreensaver/hyperball libexec/xscreensaver/hypercube +libexec/xscreensaver/hypertorus libexec/xscreensaver/ifs libexec/xscreensaver/imsmap libexec/xscreensaver/interference @@ -180,6 +185,7 @@ man/man1/atunnel.1 man/man1/barcode.1 man/man1/blaster.1 man/man1/blitspin.1 +man/man1/blocktube.1 man/man1/bouboule.1 man/man1/bouncingcow.1 man/man1/boxed.1 @@ -191,11 +197,13 @@ man/man1/bumps.1 man/man1/cage.1 man/man1/ccurve.1 man/man1/circuit.1 +man/man1/cloudlife.1 man/man1/compass.1 man/man1/coral.1 man/man1/critical.1 man/man1/crystal.1 man/man1/cubenetic.1 +man/man1/cubestorm.1 man/man1/cynosure.1 man/man1/dangerball.1 man/man1/decayscreen.1 @@ -225,6 +233,8 @@ man/man1/gears.1 man/man1/gflux.1 man/man1/glblur.1 man/man1/glforestfire.1 +man/man1/glknots.1 +man/man1/glmatrix.1 man/man1/glplanet.1 man/man1/glslideshow.1 man/man1/glsnake.1 @@ -238,6 +248,7 @@ man/man1/helix.1 man/man1/hopalong.1 man/man1/hyperball.1 man/man1/hypercube.1 +man/man1/hypertorus.1 man/man1/ifs.1 man/man1/imsmap.1 man/man1/interference.1 @@ -350,6 +361,7 @@ share/control-center/screensavers/atunnel.xml share/control-center/screensavers/barcode.xml share/control-center/screensavers/blaster.xml share/control-center/screensavers/blitspin.xml +share/control-center/screensavers/blocktube.xml share/control-center/screensavers/bouboule.xml share/control-center/screensavers/bouncingcow.xml share/control-center/screensavers/boxed.xml @@ -368,6 +380,7 @@ share/control-center/screensavers/cosmos.xml share/control-center/screensavers/critical.xml share/control-center/screensavers/crystal.xml share/control-center/screensavers/cubenetic.xml +share/control-center/screensavers/cubestorm.xml share/control-center/screensavers/cynosure.xml share/control-center/screensavers/dangerball.xml share/control-center/screensavers/decayscreen.xml @@ -398,6 +411,8 @@ share/control-center/screensavers/gears.xml share/control-center/screensavers/gflux.xml share/control-center/screensavers/glblur.xml share/control-center/screensavers/glforestfire.xml +share/control-center/screensavers/glknots.xml +share/control-center/screensavers/glmatrix.xml share/control-center/screensavers/glplanet.xml share/control-center/screensavers/glslideshow.xml share/control-center/screensavers/glsnake.xml @@ -412,6 +427,7 @@ share/control-center/screensavers/helix.xml share/control-center/screensavers/hopalong.xml share/control-center/screensavers/hyperball.xml share/control-center/screensavers/hypercube.xml +share/control-center/screensavers/hypertorus.xml share/control-center/screensavers/ifs.xml share/control-center/screensavers/imsmap.xml share/control-center/screensavers/interference.xml @@ -535,17 +551,20 @@ ${PKGLOCALEDIR}/locale/vi/LC_MESSAGES/xscreensaver.mo ${PKGLOCALEDIR}/locale/wa/LC_MESSAGES/xscreensaver.mo ${PKGLOCALEDIR}/locale/zh_CN/LC_MESSAGES/xscreensaver.mo ${PKGLOCALEDIR}/locale/zh_TW/LC_MESSAGES/xscreensaver.mo -share/xscreensaver/screensaver-cmndln.xpm -share/xscreensaver/screensaver-colorselector.xpm -share/xscreensaver/screensaver-diagnostic.xpm -share/xscreensaver/screensaver-locking.xpm -share/xscreensaver/screensaver-power.xpm -share/xscreensaver/screensaver-snap.xpm +share/pixmaps/xscreensaver.xpm +share/xscreensaver/screensaver-cmndln.png +share/xscreensaver/screensaver-colorselector.png +share/xscreensaver/screensaver-diagnostic.png +share/xscreensaver/screensaver-locking.png +share/xscreensaver/screensaver-power.png +share/xscreensaver/screensaver-snap.png share/xscreensaver/xscreensaver-demo.glade2 -share/xscreensaver/xscreensaver.xpm @dirrm share/xscreensaver +@comment in gnome-dirs: @dirrm share/gnome/apps/Settings/Desktop @dirrm share/control-center/screensavers -@comment in controlcenter: dirrm share/control-center/capplets +@comment in controlcenter: @dirrm share/control-center/capplets +@comment in controlcenter: @dirrm share/control-center/Desktop @comment in gnome2-dirs: @dirrm share/control-center-2.0/capplets @comment in gnome2-dirs: @dirrm share/control-center-2.0 +@comment in controlcenter: @dirrm share/control-center @dirrm libexec/xscreensaver diff --git a/x11/xscreensaver/Makefile.common b/x11/xscreensaver/Makefile.common index b330ff4f44f..d196214653a 100644 --- a/x11/xscreensaver/Makefile.common +++ b/x11/xscreensaver/Makefile.common @@ -1,7 +1,7 @@ -# $NetBSD: Makefile.common,v 1.50 2003/06/23 14:23:13 jschauma Exp $ +# $NetBSD: Makefile.common,v 1.51 2003/06/24 10:22:46 wiz Exp $ # -DISTNAME= xscreensaver-4.10 +DISTNAME= xscreensaver-4.11 CATEGORIES= x11 MASTER_SITES= ${HOMEPAGE} \ ftp://ftp.fu-berlin.de/unix/X11/graphics/xscreensaver/ diff --git a/x11/xscreensaver/PLIST b/x11/xscreensaver/PLIST index 6891f9a51ad..f103f057c5b 100644 --- a/x11/xscreensaver/PLIST +++ b/x11/xscreensaver/PLIST @@ -1,5 +1,4 @@ -@comment $NetBSD: PLIST,v 1.13 2003/05/23 09:39:52 wiz Exp $ -@comment bin/screensaver-properties-capplet +@comment $NetBSD: PLIST,v 1.14 2003/06/24 10:22:47 wiz Exp $ bin/xscreensaver bin/xscreensaver-command bin/xscreensaver-demo @@ -18,6 +17,7 @@ libexec/xscreensaver/atunnel libexec/xscreensaver/barcode libexec/xscreensaver/blaster libexec/xscreensaver/blitspin +libexec/xscreensaver/blocktube libexec/xscreensaver/bouboule libexec/xscreensaver/bouncingcow libexec/xscreensaver/boxed @@ -41,6 +41,7 @@ libexec/xscreensaver/config/atunnel.xml libexec/xscreensaver/config/barcode.xml libexec/xscreensaver/config/blaster.xml libexec/xscreensaver/config/blitspin.xml +libexec/xscreensaver/config/blocktube.xml libexec/xscreensaver/config/bouboule.xml libexec/xscreensaver/config/bouncingcow.xml libexec/xscreensaver/config/boxed.xml @@ -59,6 +60,7 @@ libexec/xscreensaver/config/cosmos.xml libexec/xscreensaver/config/critical.xml libexec/xscreensaver/config/crystal.xml libexec/xscreensaver/config/cubenetic.xml +libexec/xscreensaver/config/cubestorm.xml libexec/xscreensaver/config/cynosure.xml libexec/xscreensaver/config/dangerball.xml libexec/xscreensaver/config/decayscreen.xml @@ -89,6 +91,8 @@ libexec/xscreensaver/config/gears.xml libexec/xscreensaver/config/gflux.xml libexec/xscreensaver/config/glblur.xml libexec/xscreensaver/config/glforestfire.xml +libexec/xscreensaver/config/glknots.xml +libexec/xscreensaver/config/glmatrix.xml libexec/xscreensaver/config/glplanet.xml libexec/xscreensaver/config/glslideshow.xml libexec/xscreensaver/config/glsnake.xml @@ -103,6 +107,7 @@ libexec/xscreensaver/config/helix.xml libexec/xscreensaver/config/hopalong.xml libexec/xscreensaver/config/hyperball.xml libexec/xscreensaver/config/hypercube.xml +libexec/xscreensaver/config/hypertorus.xml libexec/xscreensaver/config/ifs.xml libexec/xscreensaver/config/imsmap.xml libexec/xscreensaver/config/interference.xml @@ -207,6 +212,7 @@ libexec/xscreensaver/coral libexec/xscreensaver/critical libexec/xscreensaver/crystal libexec/xscreensaver/cubenetic +libexec/xscreensaver/cubestorm libexec/xscreensaver/cynosure libexec/xscreensaver/dangerball libexec/xscreensaver/decayscreen @@ -236,6 +242,8 @@ libexec/xscreensaver/gears libexec/xscreensaver/gflux libexec/xscreensaver/glblur libexec/xscreensaver/glforestfire +libexec/xscreensaver/glknots +libexec/xscreensaver/glmatrix libexec/xscreensaver/glplanet libexec/xscreensaver/glslideshow libexec/xscreensaver/glsnake @@ -249,6 +257,7 @@ libexec/xscreensaver/helix libexec/xscreensaver/hopalong libexec/xscreensaver/hyperball libexec/xscreensaver/hypercube +libexec/xscreensaver/hypertorus libexec/xscreensaver/ifs libexec/xscreensaver/imsmap libexec/xscreensaver/interference @@ -352,6 +361,7 @@ man/man1/atunnel.1 man/man1/barcode.1 man/man1/blaster.1 man/man1/blitspin.1 +man/man1/blocktube.1 man/man1/bouboule.1 man/man1/bouncingcow.1 man/man1/boxed.1 @@ -363,11 +373,13 @@ man/man1/bumps.1 man/man1/cage.1 man/man1/ccurve.1 man/man1/circuit.1 +man/man1/cloudlife.1 man/man1/compass.1 man/man1/coral.1 man/man1/critical.1 man/man1/crystal.1 man/man1/cubenetic.1 +man/man1/cubestorm.1 man/man1/cynosure.1 man/man1/dangerball.1 man/man1/decayscreen.1 @@ -397,6 +409,8 @@ man/man1/gears.1 man/man1/gflux.1 man/man1/glblur.1 man/man1/glforestfire.1 +man/man1/glknots.1 +man/man1/glmatrix.1 man/man1/glplanet.1 man/man1/glslideshow.1 man/man1/glsnake.1 @@ -410,6 +424,7 @@ man/man1/helix.1 man/man1/hopalong.1 man/man1/hyperball.1 man/man1/hypercube.1 +man/man1/hypertorus.1 man/man1/ifs.1 man/man1/imsmap.1 man/man1/interference.1 @@ -509,10 +524,6 @@ man/man1/xspirograph.1 man/man1/xsublim.1 man/man1/xteevee.1 man/man1/zoom.1 -@comment share/applications/screensaver-properties.desktop -@comment share/control-center-2.0/capplets/screensaver-properties.desktop -@comment share/control-center/Desktop/screensaver-properties.desktop -@comment share/control-center/capplets/screensaver-properties.desktop ${PKGLOCALEDIR}/locale/ca/LC_MESSAGES/xscreensaver.mo ${PKGLOCALEDIR}/locale/da/LC_MESSAGES/xscreensaver.mo ${PKGLOCALEDIR}/locale/de/LC_MESSAGES/xscreensaver.mo @@ -535,14 +546,14 @@ ${PKGLOCALEDIR}/locale/vi/LC_MESSAGES/xscreensaver.mo ${PKGLOCALEDIR}/locale/wa/LC_MESSAGES/xscreensaver.mo ${PKGLOCALEDIR}/locale/zh_CN/LC_MESSAGES/xscreensaver.mo ${PKGLOCALEDIR}/locale/zh_TW/LC_MESSAGES/xscreensaver.mo -share/xscreensaver/screensaver-cmndln.xpm -share/xscreensaver/screensaver-colorselector.xpm -share/xscreensaver/screensaver-diagnostic.xpm -share/xscreensaver/screensaver-locking.xpm -share/xscreensaver/screensaver-power.xpm -share/xscreensaver/screensaver-snap.xpm +share/pixmaps/xscreensaver.xpm +share/xscreensaver/screensaver-cmndln.png +share/xscreensaver/screensaver-colorselector.png +share/xscreensaver/screensaver-diagnostic.png +share/xscreensaver/screensaver-locking.png +share/xscreensaver/screensaver-power.png +share/xscreensaver/screensaver-snap.png share/xscreensaver/xscreensaver-demo.glade2 -share/xscreensaver/xscreensaver.xpm @dirrm share/xscreensaver @dirrm libexec/xscreensaver/config @dirrm libexec/xscreensaver diff --git a/x11/xscreensaver/distinfo b/x11/xscreensaver/distinfo index 16028720ce4..7064a907fea 100644 --- a/x11/xscreensaver/distinfo +++ b/x11/xscreensaver/distinfo @@ -1,9 +1,9 @@ -$NetBSD: distinfo,v 1.26 2003/05/23 09:39:52 wiz Exp $ +$NetBSD: distinfo,v 1.27 2003/06/24 10:22:47 wiz Exp $ -SHA1 (xscreensaver-4.10.tar.gz) = 335680994fcd74261192cca060e2b3ffdd6f0c10 -Size (xscreensaver-4.10.tar.gz) = 3593957 bytes +SHA1 (xscreensaver-4.11.tar.gz) = 35ed2910975fe5fd565f48519b90ba6c47726145 +Size (xscreensaver-4.11.tar.gz) = 3744413 bytes SHA1 (patch-aa) = 0b4de3babe3fe191943ce31c055e8047911c1326 SHA1 (patch-ab) = 3dc02761edb19658e17935bd245208fa7387316d SHA1 (patch-ac) = 430b3318a1d1623c5ac2ba51dd531c3bff8c9a70 SHA1 (patch-ad) = 64cd7a683da1afea599d1e8b8dffd951243c9d9b -SHA1 (patch-ae) = 69b71676f23f6a6e5fb8b2d25eaf21a8388236f8 +SHA1 (patch-ae) = 16d0c8b50b2601458aaec09d1c7425fb23308225 diff --git a/x11/xscreensaver/patches/patch-ae b/x11/xscreensaver/patches/patch-ae index be8f77ceb78..c1150730270 100644 --- a/x11/xscreensaver/patches/patch-ae +++ b/x11/xscreensaver/patches/patch-ae @@ -1,853 +1,12 @@ -$NetBSD: patch-ae,v 1.8 2003/05/23 09:39:53 wiz Exp $ +$NetBSD: patch-ae,v 1.9 2003/06/24 10:22:47 wiz Exp $ ---- hacks/glx/klein.c.orig Tue May 20 13:33:47 2003 -+++ hacks/glx/klein.c -@@ -1,424 +1,424 @@ --/* -*- Mode: C; tab-width: 4 -*- */
--/* Klein --- Klein Bottle, Moebius and other parametric surfaces
-- * visualization */
--
--/*
-- * Revision History:
-- * 2000: written by Andrey Mirtchovski <mirtchov@cpsc.ucalgary.ca
-- *
-- * 01-Mar-2003 mirtchov modified as a xscreensaver hack
-- *
-- */
--
--/*-
-- * due to a Bug/feature in VMS X11/Intrinsic.h has to be placed before xlock.
-- * otherwise caddr_t is not defined correctly
-- */
--
--#include <X11/Intrinsic.h>
--
--#ifdef STANDALONE
--# define PROGCLASS "Klein"
--# define HACK_INIT init_klein
--# define HACK_DRAW draw_klein
--# define HACK_RESHAPE reshape_klein
--# define HACK_HANDLE_EVENT klein_handle_event
--# define EVENT_MASK PointerMotionMask
--# define klein_opts xlockmore_opts
--
--
--#define DEF_SPIN "True"
--#define DEF_WANDER "False"
--#define DEF_RANDOM "False"
--#define DEF_SPEED "150"
--
--# define DEFAULTS "*delay: 20000 \n" \
-- "*showFPS: False \n" \
-- "*wireframe: False \n" \
-- "*random: " DEF_RANDOM "\n" \
-- "*speed: " DEF_SPEED "\n" \
-- "*spin: " DEF_SPIN "\n" \
-- "*wander: " DEF_WANDER "\n" \
--
--# include "xlockmore.h" /* from the xscreensaver distribution */
--#else /* !STANDALONE */
--# include "xlock.h" /* from the xlockmore distribution */
--#endif /* !STANDALONE */
--
--#ifdef USE_GL
--
--#include <GL/glu.h>
--#include "rotator.h"
--#include "gltrackball.h"
--
--#undef countof
--#define countof(x) (sizeof((x))/sizeof((*x)))
--
--/* surfaces being drawn */
--enum {
-- KLEIN = 0,
-- DINI,
-- ENNEPER,
-- KUEN,
-- MOEBIUS,
-- SEASHELL,
-- SWALLOWTAIL,
-- BOHEM,
-- SURFACE_LAST,
--};
--
--/* primitives to draw with
-- * note that we skip the polygons and
-- * triangle fans -- too slow
-- *
-- * also removed triangle_strip and quads --
-- * just doesn't look good enough
-- */
--enum {
-- MY_POINTS = 0,
-- MY_LINES,
-- MY_LINE_LOOP,
-- MY_PRIM_LAST,
--};
--
--
--static Bool rand;
--static int render;
--static int speed;
--static Bool do_spin;
--static Bool do_wander;
--
--static XrmOptionDescRec opts[] = {
-- {"-speed", ".speed", XrmoptionSepArg, (caddr_t) 0 },
-- { "-spin", ".spin", XrmoptionNoArg, "True" },
-- { "+spin", ".spin", XrmoptionNoArg, "False" },
-- { "-wander", ".wander", XrmoptionNoArg, "True" },
-- { "+wander", ".wander", XrmoptionNoArg, "False" },
-- { "-random", ".rand", XrmoptionNoArg, "True" },
-- { "+random", ".rand", XrmoptionNoArg, "False" },
--};
--
--static argtype vars[] = {
-- {(caddr_t *) &rand, "rand", "Random", DEF_RANDOM, t_Bool},
-- {(caddr_t *) &do_spin, "spin", "Spin", DEF_SPIN, t_Bool},
-- {(caddr_t *) &do_wander, "wander", "Wander", DEF_WANDER, t_Bool},
-- {(caddr_t *) &speed, "speed", "Speed", DEF_SPEED, t_Int},
--};
--
--
--ModeSpecOpt klein_opts = {countof(opts), opts, countof(vars), vars, NULL};
--
--
--
--typedef struct{
-- GLfloat x;
-- GLfloat y;
-- GLfloat z;
--} GL_VECTOR;
--
--typedef struct {
-- GLXContext *glx_context;
-- Window window;
-- rotator *rot;
-- trackball_state *trackball;
-- Bool button_down_p;
--
-- int render;
-- int surface;
--
-- float du, dv;
-- float a, b, c;
--
--} kleinstruct;
--
--static kleinstruct *klein = NULL;
--
--
--static void
--draw(ModeInfo *mi)
--{
-- kleinstruct *kp = &klein[MI_SCREEN(mi)];
-- static float step = 0.0;
-- double u, v;
-- float coord[3];
--
-- glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
--
-- glEnable(GL_DEPTH_TEST);
-- glEnable(GL_NORMALIZE);
-- glEnable(GL_CULL_FACE);
--
-- glPushMatrix();
--
-- {
-- double x, y, z;
-- get_position (kp->rot, &x, &y, &z, !kp->button_down_p);
-- glTranslatef((x - 0.5) * 10,
-- (y - 0.5) * 10,
-- (z - 0.5) * 20);
--
-- gltrackball_rotate (kp->trackball);
--
-- get_rotation (kp->rot, &x, &y, &z, !kp->button_down_p);
-- glRotatef (x * 360, 1.0, 0.0, 0.0);
-- glRotatef (y * 360, 0.0, 1.0, 0.0);
-- glRotatef (z * 360, 0.0, 0.0, 1.0);
-- }
--
-- glScalef( 4.0, 4.0, 4.0 );
--
-- glBegin(kp->render);
-- switch(kp->surface) {
-- case KLEIN:
-- for(u = -M_PI; u < M_PI; u+=kp->du){
-- for(v = -M_PI; v < M_PI; v+=kp->dv){
-- coord[0] = cos(u)*(kp->a + sin(v)*cos(u/2) -
-- sin(2*v)*sin(u/2)/2);
-- coord[1] = sin(u)*(kp->a + sin(v)*cos(u/2) -
-- sin(2*v)*sin(u/2)/2);
-- coord[2] = sin(u/2)*sin(v) + cos(u/2)*sin(2*v)/2;
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- case DINI:
-- for(u = -M_PI; u < M_PI; u+=kp->du){
-- for(v = -M_PI; v < M_PI; v+=kp->dv){
-- coord[0] = kp->a*cos(u)*sin(v);
-- coord[1] = kp->a*sin(u)*sin(v);
-- coord[2] = kp->a*(cos(v) + sin(tan((v/2))))+0.2*u;
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- case ENNEPER:
-- for(u = -M_PI; u < M_PI; u+=kp->du){
-- for(v = -M_PI; v < M_PI; v+=kp->dv){
-- coord[0] = kp->a*(u-(u*u*u/3)+u*v*v);
-- coord[1] = kp->b*(v-(v*v*v/3)+u*u*v);
-- coord[2] = u*u-v*v;
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- case KUEN:
-- for(u = -M_PI; u < M_PI; u+=kp->du){
-- for(v = -M_PI; v < M_PI; v+=kp->dv){
-- coord[0] = 2*(cos(u)+u*sin(u))*sin(v)/(1+u*u*sin(v)*sin(v));
-- coord[1] = 2*(sin(u)-u*cos(u))*sin(v)/(1+u*u*sin(v)*sin(v));
-- coord[2] = sin(tan(v/2))+2*cos(v)/(1+u*u*sin(v)*sin(v));
--
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- case MOEBIUS:
-- for(u = -M_PI; u < M_PI; u+=kp->du){
-- for(v = -M_PI; v < M_PI; v+=kp->dv){
-- coord[0] = cos(u)+v*cos(u/2)*cos(u);
-- coord[1] = sin(u)+v*cos(u/2)*sin(u);
-- coord[2] = v*sin(u/2);
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- case SEASHELL:
-- for(u = 0; u < 2*M_PI; u+=kp->du){
-- for(v = 0; v < 2*M_PI; v+=kp->dv){
-- coord[0] = kp->a*(1-v/(2*M_PI))*cos(2*v)*(1+cos(u))+sin(kp->c+=0.00001)*cos(2*v);
-- coord[1] = kp->a*(1-v/(2*M_PI))*sin(2*v)*(1+cos(u))+cos(kp->c+=0.00001)*sin(2*v);
-- coord[2] = sin(kp->b+=0.00001)*v/(2*M_PI)+kp->a*(1-v/(2*M_PI))*sin(u);
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- case SWALLOWTAIL:
-- for(u = -M_PI; u < M_PI; u+=kp->du){
-- for(v = -M_PI; v < M_PI; v+=kp->dv){
-- coord[0] = u*pow(v,2) + 3*pow(v,4);
-- coord[1] = -2*u*v - 4*pow(v,3);
-- coord[2] = u;
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- case BOHEM:
-- for(u = -M_PI; u < M_PI; u+=kp->du){
-- for(v = -M_PI; v < M_PI; v+=kp->dv){
-- coord[0] = kp->a*cos(u);
-- coord[1] = 1.5*cos(v) + kp->a*sin(u);
-- coord[2] = sin(v);
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- default:
-- for(u = -M_PI; u < M_PI; u+=kp->du){
-- for(v = -M_PI; v < M_PI; v+=kp->dv){
-- coord[0] = sin(u)*kp->a;
-- coord[1] = cos(u)*kp->a;
-- coord[2] = sin(u/2)*cos(v) + cos(u/2)*sin(v);
-- glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7);
-- glVertex3fv(coord);
-- }
-- }
-- break;
-- }
-- glEnd();
-- glPopMatrix();
--
--
-- kp->a = sin(step+=0.01);
-- kp->b = cos(step+=0.01);
--}
--
--
--/* new window size or exposure */
--void
--reshape_klein(ModeInfo *mi, int width, int height)
--{
-- GLfloat h = (GLfloat) height / (GLfloat) width;
--
-- glViewport(0, 0, (GLint) width, (GLint) height);
-- glMatrixMode(GL_PROJECTION);
-- glLoadIdentity();
-- gluPerspective (30.0, 1/h, 1.0, 100.0);
--
-- glMatrixMode(GL_MODELVIEW);
-- glLoadIdentity();
-- gluLookAt( 0.0, 0.0, 30.0,
-- 0.0, 0.0, 0.0,
-- 0.0, 1.0, 0.0);
--
-- glClear(GL_COLOR_BUFFER_BIT);
--}
--
--
--Bool
--klein_handle_event (ModeInfo *mi, XEvent *event)
--{
-- kleinstruct *kp = &klein[MI_SCREEN(mi)];
--
-- if (event->xany.type == ButtonPress && event->xbutton.button & Button1) {
-- kp->button_down_p = True;
-- gltrackball_start (kp->trackball, event->xbutton.x, event->xbutton.y, MI_WIDTH (mi), MI_HEIGHT (mi));
-- return True;
-- } else if (event->xany.type == ButtonRelease && event->xbutton.button & Button1) {
-- kp->button_down_p = False;
-- return True;
-- } else if (event->xany.type == MotionNotify && kp->button_down_p) {
-- gltrackball_track (kp->trackball, event->xmotion.x, event->xmotion.y, MI_WIDTH (mi), MI_HEIGHT (mi));
-- return True;
-- }
--
-- return False;
--}
--
--
--void
--init_klein(ModeInfo *mi)
--{
-- int screen = MI_SCREEN(mi);
-- kleinstruct *kp;
--
-- if (klein == NULL) {
-- if ((klein = (kleinstruct *) calloc(MI_NUM_SCREENS(mi), sizeof (kleinstruct))) == NULL)
-- return;
-- }
-- kp = &klein[screen];
--
-- kp->window = MI_WINDOW(mi);
--
-- {
-- double spin_speed = 1.0;
-- double wander_speed = 0.03;
-- kp->rot = make_rotator (do_spin ? spin_speed : 0,
-- do_spin ? spin_speed : 0,
-- do_spin ? spin_speed : 0,
-- 1.0,
-- do_wander ? wander_speed : 0,
-- True);
-- kp->trackball = gltrackball_init ();
-- }
--
-- if(rand) {
-- render = random() % MY_PRIM_LAST;
-- kp->surface = random() % SURFACE_LAST;
-- } else {
-- render = MY_LINE_LOOP;
-- kp->surface = KLEIN;
-- }
--
-- switch (render) {
-- case MY_POINTS: kp->render = GL_POINTS; break;
-- case MY_LINES: kp->render = GL_LINES; break;
-- case MY_LINE_LOOP: kp->render = GL_LINE_LOOP; break;
-- default:
-- kp->render = GL_LINE_LOOP;
-- }
--/*kp->render=GL_TRIANGLE_FAN;*/
--/*kp->render=GL_POLYGON;*/
--
-- kp->du = 0.07;
-- kp->dv = 0.07;
-- kp->a = kp->b = 1;
-- kp->c = 0.1;
--
--
-- if ((kp->glx_context = init_GL(mi)) != NULL) {
-- reshape_klein(mi, MI_WIDTH(mi), MI_HEIGHT(mi));
-- } else {
-- MI_CLEARWINDOW(mi);
-- }
--}
--
--void
--draw_klein(ModeInfo * mi)
--{
-- kleinstruct *kp = &klein[MI_SCREEN(mi)];
-- Display *display = MI_DISPLAY(mi);
-- Window window = MI_WINDOW(mi);
--
-- if (!kp->glx_context) return;
--
-- glDrawBuffer(GL_BACK);
--
-- glXMakeCurrent(display, window, *(kp->glx_context));
-- draw(mi);
-- if (mi->fps_p) do_fps (mi);
-- glFinish();
-- glXSwapBuffers(display, window);
--}
--
--void
--release_klein(ModeInfo * mi)
--{
-- if (klein != NULL) {
-- int screen;
--
-- for (screen = 0; screen < MI_NUM_SCREENS(mi); screen++) {
-- kleinstruct *kp = &klein[screen];
--
-- if (kp->glx_context) {
-- /* Display lists MUST be freed while their glXContext is current. */
-- glXMakeCurrent(MI_DISPLAY(mi), kp->window, *(kp->glx_context));
-- }
-- }
-- (void) free((void *) klein);
-- klein = NULL;
-- }
-- FreeAllGL(mi);
--}
--
--
--/*********************************************************/
--
--#endif
-+/* -*- Mode: C; tab-width: 4 -*- */ -+/* Klein --- Klein Bottle, Moebius and other parametric surfaces -+ * visualization */ -+ -+/* -+ * Revision History: -+ * 2000: written by Andrey Mirtchovski <mirtchov@cpsc.ucalgary.ca -+ * -+ * 01-Mar-2003 mirtchov modified as a xscreensaver hack -+ * -+ */ -+ -+/*- -+ * due to a Bug/feature in VMS X11/Intrinsic.h has to be placed before xlock. -+ * otherwise caddr_t is not defined correctly -+ */ -+ -+#include <X11/Intrinsic.h> -+ -+#ifdef STANDALONE -+# define PROGCLASS "Klein" -+# define HACK_INIT init_klein -+# define HACK_DRAW draw_klein -+# define HACK_RESHAPE reshape_klein -+# define HACK_HANDLE_EVENT klein_handle_event -+# define EVENT_MASK PointerMotionMask -+# define klein_opts xlockmore_opts -+ -+ -+#define DEF_SPIN "True" -+#define DEF_WANDER "False" -+#define DEF_RANDOM "False" -+#define DEF_SPEED "150" -+ -+# define DEFAULTS "*delay: 20000 \n" \ -+ "*showFPS: False \n" \ -+ "*wireframe: False \n" \ -+ "*random: " DEF_RANDOM "\n" \ -+ "*speed: " DEF_SPEED "\n" \ -+ "*spin: " DEF_SPIN "\n" \ -+ "*wander: " DEF_WANDER "\n" \ -+ -+# include "xlockmore.h" /* from the xscreensaver distribution */ -+#else /* !STANDALONE */ -+# include "xlock.h" /* from the xlockmore distribution */ -+#endif /* !STANDALONE */ -+ -+#ifdef USE_GL -+ -+#include <GL/glu.h> -+#include "rotator.h" -+#include "gltrackball.h" -+ -+#undef countof -+#define countof(x) (sizeof((x))/sizeof((*x))) -+ -+/* surfaces being drawn */ -+enum { -+ KLEIN = 0, -+ DINI, -+ ENNEPER, -+ KUEN, -+ MOEBIUS, -+ SEASHELL, -+ SWALLOWTAIL, -+ BOHEM, -+ SURFACE_LAST, -+}; -+ -+/* primitives to draw with -+ * note that we skip the polygons and -+ * triangle fans -- too slow -+ * -+ * also removed triangle_strip and quads -- -+ * just doesn't look good enough -+ */ -+enum { -+ MY_POINTS = 0, -+ MY_LINES, -+ MY_LINE_LOOP, -+ MY_PRIM_LAST, -+}; -+ -+ -+static Bool rand; -+static int render; -+static int speed; -+static Bool do_spin; -+static Bool do_wander; -+ -+static XrmOptionDescRec opts[] = { -+ {"-speed", ".speed", XrmoptionSepArg, (caddr_t) 0 }, -+ { "-spin", ".spin", XrmoptionNoArg, "True" }, -+ { "+spin", ".spin", XrmoptionNoArg, "False" }, -+ { "-wander", ".wander", XrmoptionNoArg, "True" }, -+ { "+wander", ".wander", XrmoptionNoArg, "False" }, -+ { "-random", ".rand", XrmoptionNoArg, "True" }, -+ { "+random", ".rand", XrmoptionNoArg, "False" }, -+}; -+ -+static argtype vars[] = { -+ {(caddr_t *) &rand, "rand", "Random", DEF_RANDOM, t_Bool}, -+ {(caddr_t *) &do_spin, "spin", "Spin", DEF_SPIN, t_Bool}, -+ {(caddr_t *) &do_wander, "wander", "Wander", DEF_WANDER, t_Bool}, -+ {(caddr_t *) &speed, "speed", "Speed", DEF_SPEED, t_Int}, -+}; -+ -+ -+ModeSpecOpt klein_opts = {countof(opts), opts, countof(vars), vars, NULL}; -+ -+ -+ -+typedef struct{ -+ GLfloat x; -+ GLfloat y; -+ GLfloat z; -+} GL_VECTOR; -+ -+typedef struct { -+ GLXContext *glx_context; -+ Window window; -+ rotator *rot; -+ trackball_state *trackball; -+ Bool button_down_p; -+ -+ int render; -+ int surface; -+ -+ float du, dv; -+ float a, b, c; -+ -+} kleinstruct; -+ -+static kleinstruct *klein = NULL; -+ -+ -+static void -+draw(ModeInfo *mi) -+{ -+ kleinstruct *kp = &klein[MI_SCREEN(mi)]; -+ static float step = 0.0; -+ double u, v; -+ float coord[3]; -+ -+ glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT); -+ -+ glEnable(GL_DEPTH_TEST); -+ glEnable(GL_NORMALIZE); -+ glEnable(GL_CULL_FACE); -+ -+ glPushMatrix(); -+ -+ { -+ double x, y, z; -+ get_position (kp->rot, &x, &y, &z, !kp->button_down_p); -+ glTranslatef((x - 0.5) * 10, -+ (y - 0.5) * 10, -+ (z - 0.5) * 20); -+ -+ gltrackball_rotate (kp->trackball); -+ -+ get_rotation (kp->rot, &x, &y, &z, !kp->button_down_p); -+ glRotatef (x * 360, 1.0, 0.0, 0.0); -+ glRotatef (y * 360, 0.0, 1.0, 0.0); -+ glRotatef (z * 360, 0.0, 0.0, 1.0); -+ } -+ -+ glScalef( 4.0, 4.0, 4.0 ); -+ -+ glBegin(kp->render); -+ switch(kp->surface) { -+ case KLEIN: -+ for(u = -M_PI; u < M_PI; u+=kp->du){ -+ for(v = -M_PI; v < M_PI; v+=kp->dv){ -+ coord[0] = cos(u)*(kp->a + sin(v)*cos(u/2) - -+ sin(2*v)*sin(u/2)/2); -+ coord[1] = sin(u)*(kp->a + sin(v)*cos(u/2) - -+ sin(2*v)*sin(u/2)/2); -+ coord[2] = sin(u/2)*sin(v) + cos(u/2)*sin(2*v)/2; -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ case DINI: -+ for(u = -M_PI; u < M_PI; u+=kp->du){ -+ for(v = -M_PI; v < M_PI; v+=kp->dv){ -+ coord[0] = kp->a*cos(u)*sin(v); -+ coord[1] = kp->a*sin(u)*sin(v); -+ coord[2] = kp->a*(cos(v) + sin(tan((v/2))))+0.2*u; -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ case ENNEPER: -+ for(u = -M_PI; u < M_PI; u+=kp->du){ -+ for(v = -M_PI; v < M_PI; v+=kp->dv){ -+ coord[0] = kp->a*(u-(u*u*u/3)+u*v*v); -+ coord[1] = kp->b*(v-(v*v*v/3)+u*u*v); -+ coord[2] = u*u-v*v; -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ case KUEN: -+ for(u = -M_PI; u < M_PI; u+=kp->du){ -+ for(v = -M_PI; v < M_PI; v+=kp->dv){ -+ coord[0] = 2*(cos(u)+u*sin(u))*sin(v)/(1+u*u*sin(v)*sin(v)); -+ coord[1] = 2*(sin(u)-u*cos(u))*sin(v)/(1+u*u*sin(v)*sin(v)); -+ coord[2] = sin(tan(v/2))+2*cos(v)/(1+u*u*sin(v)*sin(v)); -+ -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ case MOEBIUS: -+ for(u = -M_PI; u < M_PI; u+=kp->du){ -+ for(v = -M_PI; v < M_PI; v+=kp->dv){ -+ coord[0] = cos(u)+v*cos(u/2)*cos(u); -+ coord[1] = sin(u)+v*cos(u/2)*sin(u); -+ coord[2] = v*sin(u/2); -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ case SEASHELL: -+ for(u = 0; u < 2*M_PI; u+=kp->du){ -+ for(v = 0; v < 2*M_PI; v+=kp->dv){ -+ coord[0] = kp->a*(1-v/(2*M_PI))*cos(2*v)*(1+cos(u))+sin(kp->c+=0.00001)*cos(2*v); -+ coord[1] = kp->a*(1-v/(2*M_PI))*sin(2*v)*(1+cos(u))+cos(kp->c+=0.00001)*sin(2*v); -+ coord[2] = sin(kp->b+=0.00001)*v/(2*M_PI)+kp->a*(1-v/(2*M_PI))*sin(u); -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ case SWALLOWTAIL: -+ for(u = -M_PI; u < M_PI; u+=kp->du){ -+ for(v = -M_PI; v < M_PI; v+=kp->dv){ -+ coord[0] = u*pow(v,2) + 3*pow(v,4); -+ coord[1] = -2*u*v - 4*pow(v,3); -+ coord[2] = u; -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ case BOHEM: -+ for(u = -M_PI; u < M_PI; u+=kp->du){ -+ for(v = -M_PI; v < M_PI; v+=kp->dv){ -+ coord[0] = kp->a*cos(u); -+ coord[1] = 1.5*cos(v) + kp->a*sin(u); -+ coord[2] = sin(v); -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ default: -+ for(u = -M_PI; u < M_PI; u+=kp->du){ -+ for(v = -M_PI; v < M_PI; v+=kp->dv){ -+ coord[0] = sin(u)*kp->a; -+ coord[1] = cos(u)*kp->a; -+ coord[2] = sin(u/2)*cos(v) + cos(u/2)*sin(v); -+ glColor3f(coord[0]+0.7, coord[1]+0.7, coord[2]+0.7); -+ glVertex3fv(coord); -+ } -+ } -+ break; -+ } -+ glEnd(); -+ glPopMatrix(); -+ -+ -+ kp->a = sin(step+=0.01); -+ kp->b = cos(step+=0.01); -+} -+ -+ -+/* new window size or exposure */ -+void -+reshape_klein(ModeInfo *mi, int width, int height) -+{ -+ GLfloat h = (GLfloat) height / (GLfloat) width; -+ -+ glViewport(0, 0, (GLint) width, (GLint) height); -+ glMatrixMode(GL_PROJECTION); -+ glLoadIdentity(); -+ gluPerspective (30.0, 1/h, 1.0, 100.0); -+ -+ glMatrixMode(GL_MODELVIEW); -+ glLoadIdentity(); -+ gluLookAt( 0.0, 0.0, 30.0, -+ 0.0, 0.0, 0.0, -+ 0.0, 1.0, 0.0); -+ -+ glClear(GL_COLOR_BUFFER_BIT); -+} -+ -+ -+Bool -+klein_handle_event (ModeInfo *mi, XEvent *event) -+{ -+ kleinstruct *kp = &klein[MI_SCREEN(mi)]; -+ -+ if (event->xany.type == ButtonPress && event->xbutton.button & Button1) { -+ kp->button_down_p = True; -+ gltrackball_start (kp->trackball, event->xbutton.x, event->xbutton.y, MI_WIDTH (mi), MI_HEIGHT (mi)); -+ return True; -+ } else if (event->xany.type == ButtonRelease && event->xbutton.button & Button1) { -+ kp->button_down_p = False; -+ return True; -+ } else if (event->xany.type == MotionNotify && kp->button_down_p) { -+ gltrackball_track (kp->trackball, event->xmotion.x, event->xmotion.y, MI_WIDTH (mi), MI_HEIGHT (mi)); -+ return True; -+ } -+ -+ return False; -+} -+ -+ -+void -+init_klein(ModeInfo *mi) -+{ -+ int screen = MI_SCREEN(mi); -+ kleinstruct *kp; -+ -+ if (klein == NULL) { -+ if ((klein = (kleinstruct *) calloc(MI_NUM_SCREENS(mi), sizeof (kleinstruct))) == NULL) -+ return; -+ } -+ kp = &klein[screen]; -+ -+ kp->window = MI_WINDOW(mi); -+ -+ { -+ double spin_speed = 1.0; -+ double wander_speed = 0.03; -+ kp->rot = make_rotator (do_spin ? spin_speed : 0, -+ do_spin ? spin_speed : 0, -+ do_spin ? spin_speed : 0, -+ 1.0, -+ do_wander ? wander_speed : 0, -+ True); -+ kp->trackball = gltrackball_init (); -+ } -+ -+ if(rand) { -+ render = random() % MY_PRIM_LAST; -+ kp->surface = random() % SURFACE_LAST; -+ } else { -+ render = MY_LINE_LOOP; -+ kp->surface = KLEIN; -+ } -+ -+ switch (render) { -+ case MY_POINTS: kp->render = GL_POINTS; break; -+ case MY_LINES: kp->render = GL_LINES; break; -+ case MY_LINE_LOOP: kp->render = GL_LINE_LOOP; break; -+ default: -+ kp->render = GL_LINE_LOOP; -+ } -+/*kp->render=GL_TRIANGLE_FAN;*/ -+/*kp->render=GL_POLYGON;*/ -+ -+ kp->du = 0.07; -+ kp->dv = 0.07; -+ kp->a = kp->b = 1; -+ kp->c = 0.1; -+ -+ -+ if ((kp->glx_context = init_GL(mi)) != NULL) { -+ reshape_klein(mi, MI_WIDTH(mi), MI_HEIGHT(mi)); -+ } else { -+ MI_CLEARWINDOW(mi); -+ } -+} -+ -+void -+draw_klein(ModeInfo * mi) -+{ -+ kleinstruct *kp = &klein[MI_SCREEN(mi)]; -+ Display *display = MI_DISPLAY(mi); -+ Window window = MI_WINDOW(mi); -+ -+ if (!kp->glx_context) return; -+ -+ glDrawBuffer(GL_BACK); -+ -+ glXMakeCurrent(display, window, *(kp->glx_context)); -+ draw(mi); -+ if (mi->fps_p) do_fps (mi); -+ glFinish(); -+ glXSwapBuffers(display, window); -+} -+ -+void -+release_klein(ModeInfo * mi) -+{ -+ if (klein != NULL) { -+ int screen; -+ -+ for (screen = 0; screen < MI_NUM_SCREENS(mi); screen++) { -+ kleinstruct *kp = &klein[screen]; -+ -+ if (kp->glx_context) { -+ /* Display lists MUST be freed while their glXContext is current. */ -+ glXMakeCurrent(MI_DISPLAY(mi), kp->window, *(kp->glx_context)); -+ } -+ } -+ (void) free((void *) klein); -+ klein = NULL; -+ } -+ FreeAllGL(mi); -+} -+ -+ -+/*********************************************************/ -+ -+#endif +--- driver/xscreensaver.h.orig Sat Jun 7 10:22:21 2003 ++++ driver/xscreensaver.h +@@ -12,6 +12,7 @@ + #ifndef __XSCREENSAVER_H__ + #define __XSCREENSAVER_H__ + ++#include <signal.h> + #include <stdlib.h> + #ifdef HAVE_UNISTD_H + # include <unistd.h> |