1 /* $NetBSD: random.c,v 1.14 2009/08/12 08:27:24 dholland Exp $ */
5 * The Regents of the University of California. All rights reserved.
7 * This code is derived from software contributed to Berkeley by
8 * Guy Harris at Network Appliance Corp.
10 * Redistribution and use in source and binary forms, with or without
11 * modification, are permitted provided that the following conditions
13 * 1. Redistributions of source code must retain the above copyright
14 * notice, this list of conditions and the following disclaimer.
15 * 2. Redistributions in binary form must reproduce the above copyright
16 * notice, this list of conditions and the following disclaimer in the
17 * documentation and/or other materials provided with the distribution.
18 * 3. Neither the name of the University nor the names of its contributors
19 * may be used to endorse or promote products derived from this software
20 * without specific prior written permission.
22 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
35 #include <sys/cdefs.h>
37 __COPYRIGHT("@(#) Copyright (c) 1994\
38 The Regents of the University of California. All rights reserved.");
43 static char sccsid
[] = "@(#)random.c 8.6 (Berkeley) 6/1/94";
45 __RCSID("$NetBSD: random.c,v 1.14 2009/08/12 08:27:24 dholland Exp $");
49 #include <sys/types.h>
60 static void usage(void) __dead
;
63 main(int argc
, char *argv
[])
67 int ch
, random_exit
, selected
, unbuffer_output
;
71 random_exit
= unbuffer_output
= 0;
72 while ((ch
= getopt(argc
, argv
, "er")) != -1)
95 denom
= strtod(*argv
, &ep
);
98 if (denom
== 0 || *ep
!= '\0')
99 errx(1, "denominator is not valid.");
106 (void)gettimeofday(&tp
, NULL
);
107 srandom((unsigned long)tp
.tv_usec
+ tp
.tv_sec
+ getpid());
109 /* Compute a random exit status between 0 and denom - 1. */
111 return ((denom
* random()) / RANDOM_MAX
);
114 * Act as a filter, randomly choosing lines of the standard input
115 * to write to the standard output.
118 setbuf(stdout
, NULL
);
121 * Select whether to print the first line. (Prime the pump.)
122 * We find a random number between 0 and denom - 1 and, if it's
123 * 0 (which has a 1 / denom chance of being true), we select the
126 selected
= (int)(denom
* random() / RANDOM_MAX
) == 0;
127 while ((ch
= getchar()) != EOF
) {
131 /* End of that line. See if we got an error. */
135 /* Now see if the next line is to be printed. */
136 selected
= (int)(denom
* random() / RANDOM_MAX
) == 0;
150 (void)fprintf(stderr
, "usage: random [-er] [denominator]\n");