X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ian/git?p=chiark-utils.git;a=blobdiff_plain;f=scripts%2Frandom-word;h=649af152a3c074a55be6e3b3ef33e081ec03881f;hp=ddd6c5205158684538fdac95268496eaed13821a;hb=704128164f85f7c3b7a1421a12f4cb11f2edcdec;hpb=83aa3f4b9c78e443ee16334449c658ba9f7e8396 diff --git a/scripts/random-word b/scripts/random-word index ddd6c52..649af15 100755 --- a/scripts/random-word +++ b/scripts/random-word @@ -1,4 +1,4 @@ -#!/usr/bin/perl +#!/usr/bin/perl -w # Copyright 2004 Ian Jackson # @@ -16,18 +16,21 @@ # with this program; if not, consult the Free Software Foundation's # website at www.fsf.org, or the GNU Project website at www.gnu.org. +use strict; + use IO::Handle; use IO::File; use POSIX; -$want= 1; -$filename= "/usr/share/dict/words"; -@randfile= ("/dev/urandom", "/dev/random"); +our $want= 1; +our $filename= "/usr/share/dict/words"; +our @randfile= ("/dev/urandom", "/dev/random"); +our $filemaxlen; sub fail ($) { die "random-word: $_[0]\n"; } open D, ">/dev/null" or fail("open /dev/null: $!"); -while ($ARGV[0] =~ m/^\-/) { +while (@ARGV && $ARGV[0] =~ m/^\-/) { $_= shift @ARGV; if (m/^\-\-?$/) { last; @@ -35,6 +38,8 @@ while ($ARGV[0] =~ m/^\-/) { $want= $1; } elsif (m/^\-f/ && length > 2) { $filename= $'; #'; + } elsif (m/^\-F(\d+)$/) { + $filemaxlen= $1; } elsif (m/^\-r/ && length > 2) { @randfile= ($'); #'); } elsif (m/^\-D$/) { @@ -49,6 +54,9 @@ sub debug ($) { or fail("write debug: $!"); } +our $randfile; +our $r; + for $randfile (@randfile) { $r= new IO::File "$randfile", 'r'; debug("open $randfile ".($r ? "ok" : "failed $!")); @@ -58,17 +66,28 @@ for $randfile (@randfile) { $r or fail("could not open any random device: $!\n (tried @randfile)"); $r->autoflush(0); -$w= new IO::File $filename, 'r'; +our $w= new IO::File $filename, 'r'; $w or fail("cannot open $filename: $!"); debug("open $filename ok"); -@words= <$w>; +our @words; +if (defined $filemaxlen) { + while (@words < $filemaxlen) { + my $l = <$w>; + last unless defined $l; + push @words, $l; + } +} else { + @words= <$w>; +} $w->error and fail("cannot read $filename: $!"); debug("read $filename ok"); +our @out; while (@out < $want) { + my $rbytes; $!=0; read $r,$rbytes,4; length $rbytes==4 or fail("cannot read $randfile: $!"); - $wordno= unpack 'L',$rbytes; + my $wordno= unpack 'L',$rbytes; $wordno &= ~0x80000000; $wordno %= @words; $_= $words[$wordno];