X-Git-Url: http://git.hungrycats.org/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=driver%2Fxset.c;h=d26ee1b25a08938164e8d2dbfa3429ed42b40616;hb=9c9d475ff889ed8be02e8ce8c17da28b93278fca;hp=eea175c8472d0ac82221fcf930fccf6fe3dec03d;hpb=c31d10b6605cd8dc1a7b61fef4256f06198767e5;p=xscreensaver diff --git a/driver/xset.c b/driver/xset.c index eea175c8..d26ee1b2 100644 --- a/driver/xset.c +++ b/driver/xset.c @@ -1,5 +1,5 @@ /* xset.c --- interacting with server extensions and the builtin screensaver. - * xscreensaver, Copyright (c) 1991-1998 Jamie Zawinski + * xscreensaver, Copyright (c) 1991-2004 Jamie Zawinski * * Permission to use, copy, modify, distribute, and sell this software and its * documentation for any purpose is hereby granted without fee, provided that @@ -129,7 +129,7 @@ init_sgi_saver_extension (saver_info *si) "%s: SGI SCREEN_SAVER extension exists, but can't be initialized;\n\ perhaps some other screensaver program is already running?\n", blurb()); - p->use_sgi_saver_extension = False; + si->using_sgi_saver_extension = False; return; } } @@ -156,6 +156,39 @@ query_xidle_extension (saver_info *si) #endif /* HAVE_XIDLE_EXTENSION */ + +/* Resize and Rotate server extension hackery. + */ + +#ifdef HAVE_RANDR + +# include + +Bool +query_randr_extension (saver_info *si) +{ + saver_preferences *p = &si->prefs; + Bool ok = XRRQueryExtension (si->dpy, + &si->randr_event_number, + &si->randr_error_number); + if (ok) + { + int nscreens = ScreenCount (si->dpy); /* number of *real* screens */ + int i; + + if (p->verbose_p) + fprintf (stderr, "%s: selecting RANDR events\n", blurb()); + for (i = 0; i < nscreens; i++) + XRRSelectInput (si->dpy, RootWindow (si->dpy, i), + RRScreenChangeNotifyMask); + } + + return ok; +} + +#endif /* HAVE_XIDLE_EXTENSION */ + + /* Figuring out what the appropriate XSetScreenSaver() parameters are (one wouldn't expect this to be rocket science.) @@ -196,13 +229,13 @@ disable_builtin_screensaver (saver_info *si, Bool unblank_screen_p) on some systems that don't support XDPMS? Who know... */ desired_allow_exp = AllowExposures; - if (p->use_mit_saver_extension || p->use_sgi_saver_extension) + if (si->using_mit_saver_extension || si->using_sgi_saver_extension) { desired_server_timeout = (p->timeout / 1000); /* The SGI extension won't give us events unless blanking is on. I think (unsure right now) that the MIT extension is the opposite. */ - if (p->use_sgi_saver_extension) + if (si->using_sgi_saver_extension) desired_prefer_blank = PreferBlanking; else desired_prefer_blank = DontPreferBlanking; @@ -223,14 +256,11 @@ disable_builtin_screensaver (saver_info *si, Bool unblank_screen_p) desired_prefer_blank != current_prefer_blank || desired_allow_exp != current_allow_exp) { - if (unblank_screen_p) - fprintf (stderr, - "%s disabling server builtin screensaver.\n" - "%s: you can re-enable it with \"xset s on\".\n", - blurb(), blurb()); - if (p->verbose_p) - fprintf (stderr, "%s: (xset s %d %d; xset s %s; xset s %s)\n", blurb(), + fprintf (stderr, + "%s: disabling server builtin screensaver:\n" + "%s: (xset s %d %d; xset s %s; xset s %s)\n", + blurb(), blurb(), desired_server_timeout, desired_server_interval, (desired_prefer_blank ? "blank" : "noblank"), (desired_allow_exp ? "expose" : "noexpose")); @@ -249,10 +279,10 @@ disable_builtin_screensaver (saver_info *si, Bool unblank_screen_p) { extension_initted = True; # ifdef HAVE_MIT_SAVER_EXTENSION - if (p->use_mit_saver_extension) init_mit_saver_extension(si); + if (si->using_mit_saver_extension) init_mit_saver_extension(si); # endif # ifdef HAVE_SGI_SAVER_EXTENSION - if (p->use_sgi_saver_extension) init_sgi_saver_extension(si); + if (si->using_sgi_saver_extension) init_sgi_saver_extension(si); # endif } }