X-Git-Url: http://git.hungrycats.org/cgi-bin/gitweb.cgi?p=xscreensaver;a=blobdiff_plain;f=driver%2Fxscreensaver-getimage-video;h=6383bd85d4ee691ec089d08f67b8b409b1ea7acb;hp=6afd76112a13caf4245a7a3d17059ebbd52dbd41;hb=5f9c47ca98dd43d8f59b7c27d3fde6edfde4fe21;hpb=50be9bb40dc60130c99ffa568e6677779904ff70 diff --git a/driver/xscreensaver-getimage-video b/driver/xscreensaver-getimage-video index 6afd7611..6383bd85 100755 --- a/driver/xscreensaver-getimage-video +++ b/driver/xscreensaver-getimage-video @@ -1,5 +1,5 @@ #!/usr/bin/perl -w -# Copyright © 2001-2010 Jamie Zawinski . +# Copyright © 2001-2011 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 @@ -18,9 +18,10 @@ # "jigsaw", etc.) get the image to manipulate by running the # "xscreensaver-getimage" program. # -# "xscreensaver-getimage" will invoke this program, depending on the -# value of the "grabVideoFrames" setting in the ~/.xscreensaver file -# (or in /usr/lib/X11/app-defaults/XScreenSaver). +# The various screen savers invoke "xscreensaver-getimage", which will in +# turn invoke this program, depending on the value of the "grabVideoFrames" +# setting in the ~/.xscreensaver file (or in the app-defaults file, usually +# /usr/lib/X11/app-defaults/XScreenSaver). # # Created: 13-Apr-2001. @@ -29,7 +30,7 @@ require 5; use strict; my $progname = $0; $progname =~ s@.*/@@g; -my $version = q{ $Revision: 1.19 $ }; $version =~ s/^[^0-9]+([0-9.]+).*$/$1/; +my $version = q{ $Revision: 1.21 $ }; $version =~ s/^[^0-9]+([0-9.]+).*$/$1/; my $tmpdir = $ENV{TMPDIR} || "/tmp"; my $tmpfile = sprintf("%s/xssv.%08x.ppm", $tmpdir, rand(0xFFFFFFFF)); @@ -70,8 +71,10 @@ my @programs = ( "vidtomem -f $tmpfile 2>&- " . # Silicon Graphics "&& mv $tmpfile-00000.rgb $tmpfile", - # "mplayer tv:// -vo pnm -frames 1 2>&- " . # Maybe works with some cams? + # "mplayer -really-quiet tv://0 " . # Maybe works with some cams? + # "-ao null -vo pnm -frames 1 2>&- " . # "&& mv 00000001.ppm $tmpfile", + ); @@ -120,21 +123,21 @@ sub grab_image() { print STDOUT "$tmpfile\n"; } elsif ($use_stdout_p) { - local *IN; my $ppm = ""; my $reader = "<$tmpfile"; # horrid kludge for SGIs, since they don't use PPM... if ($cmd =~ m/^vidtomem\s/) { - $reader = "sgitopnm $tmpfile"; + $reader = "sgitopnm $tmpfile"; $reader .= " 2>/dev/null" if ($verbose <= 1); $reader .= " |"; } - open(IN, $reader) || error ("reading $tmpfile: $!"); + open (my $in, $reader) || error ("reading $tmpfile: $!"); print STDERR "$progname: reading $tmpfile\n" if ($verbose > 1); - while () { $ppm .= $_; } - close IN; + local $/ = undef; # read entire file + $ppm = <$in>; + close $in; unlink $tmpfile; print STDOUT $ppm;