1*8462SApril.Chin@Sun.COM#!/usr/bin/ksh93
2*8462SApril.Chin@Sun.COM
3*8462SApril.Chin@Sun.COM#
4*8462SApril.Chin@Sun.COM# CDDL HEADER START
5*8462SApril.Chin@Sun.COM#
6*8462SApril.Chin@Sun.COM# The contents of this file are subject to the terms of the
7*8462SApril.Chin@Sun.COM# Common Development and Distribution License (the "License").
8*8462SApril.Chin@Sun.COM# You may not use this file except in compliance with the License.
9*8462SApril.Chin@Sun.COM#
10*8462SApril.Chin@Sun.COM# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
11*8462SApril.Chin@Sun.COM# or http://www.opensolaris.org/os/licensing.
12*8462SApril.Chin@Sun.COM# See the License for the specific language governing permissions
13*8462SApril.Chin@Sun.COM# and limitations under the License.
14*8462SApril.Chin@Sun.COM#
15*8462SApril.Chin@Sun.COM# When distributing Covered Code, include this CDDL HEADER in each
16*8462SApril.Chin@Sun.COM# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
17*8462SApril.Chin@Sun.COM# If applicable, add the following below this CDDL HEADER, with the
18*8462SApril.Chin@Sun.COM# fields enclosed by brackets "[]" replaced with your own identifying
19*8462SApril.Chin@Sun.COM# information: Portions Copyright [yyyy] [name of copyright owner]
20*8462SApril.Chin@Sun.COM#
21*8462SApril.Chin@Sun.COM# CDDL HEADER END
22*8462SApril.Chin@Sun.COM#
23*8462SApril.Chin@Sun.COM
24*8462SApril.Chin@Sun.COM#
25*8462SApril.Chin@Sun.COM# Copyright 2008 Sun Microsystems, Inc.  All rights reserved.
26*8462SApril.Chin@Sun.COM# Use is subject to license terms.
27*8462SApril.Chin@Sun.COM#
28*8462SApril.Chin@Sun.COM
29*8462SApril.Chin@Sun.COM#
30*8462SApril.Chin@Sun.COM# primenumbers1 - a simple prime number generator
31*8462SApril.Chin@Sun.COM#
32*8462SApril.Chin@Sun.COM
33*8462SApril.Chin@Sun.COM# Solaris needs /usr/xpg6/bin:/usr/xpg4/bin because the tools in /usr/bin are not POSIX-conformant
34*8462SApril.Chin@Sun.COMexport PATH=/usr/xpg6/bin:/usr/xpg4/bin:/bin:/usr/bin
35*8462SApril.Chin@Sun.COM
36*8462SApril.Chin@Sun.COM# Make sure all math stuff runs in the "C" locale to avoid problems
37*8462SApril.Chin@Sun.COM# with alternative # radix point representations (e.g. ',' instead of
38*8462SApril.Chin@Sun.COM# '.' in de_DE.*-locales). This needs to be set _before_ any
39*8462SApril.Chin@Sun.COM# floating-point constants are defined in this script).
40*8462SApril.Chin@Sun.COMif [[ "${LC_ALL}" != "" ]] ; then
41*8462SApril.Chin@Sun.COM    export \
42*8462SApril.Chin@Sun.COM        LC_MONETARY="${LC_ALL}" \
43*8462SApril.Chin@Sun.COM        LC_MESSAGES="${LC_ALL}" \
44*8462SApril.Chin@Sun.COM        LC_COLLATE="${LC_ALL}" \
45*8462SApril.Chin@Sun.COM        LC_CTYPE="${LC_ALL}"
46*8462SApril.Chin@Sun.COM        unset LC_ALL
47*8462SApril.Chin@Sun.COMfi
48*8462SApril.Chin@Sun.COMexport LC_NUMERIC=C
49*8462SApril.Chin@Sun.COM
50*8462SApril.Chin@Sun.COM
51*8462SApril.Chin@Sun.COM# check whether arg1 is a prime number via comparing it against the "pn" array
52*8462SApril.Chin@Sun.COMfunction is_prime
53*8462SApril.Chin@Sun.COM{
54*8462SApril.Chin@Sun.COM	integer i
55*8462SApril.Chin@Sun.COM	integer num=$1
56*8462SApril.Chin@Sun.COM	float   max_pn
57*8462SApril.Chin@Sun.COM
58*8462SApril.Chin@Sun.COM	(( max_pn=sqrt(num)+1. ))
59*8462SApril.Chin@Sun.COM
60*8462SApril.Chin@Sun.COM	for (( i=0 ; i < num_pn && pn[i] < max_pn ; i++)) ; do
61*8462SApril.Chin@Sun.COM		(( num % pn[i] == 0 )) && return 1;
62*8462SApril.Chin@Sun.COM	done
63*8462SApril.Chin@Sun.COM	return 0
64*8462SApril.Chin@Sun.COM}
65*8462SApril.Chin@Sun.COM
66*8462SApril.Chin@Sun.COM# main
67*8462SApril.Chin@Sun.COMset -o errexit
68*8462SApril.Chin@Sun.COM
69*8462SApril.Chin@Sun.COM# get arguments
70*8462SApril.Chin@Sun.COMinteger max_prime=$1 # maximum prime number
71*8462SApril.Chin@Sun.COMtypeset outputformat=$2
72*8462SApril.Chin@Sun.COM
73*8462SApril.Chin@Sun.COM# variables
74*8462SApril.Chin@Sun.COMinteger -a pn		# integer array for the prime numbers
75*8462SApril.Chin@Sun.COMinteger num_pn=1	# number of prime numbers
76*8462SApril.Chin@Sun.COMinteger n		# current number which should be tested
77*8462SApril.Chin@Sun.COMpn[0]=2			# start value
78*8462SApril.Chin@Sun.COM
79*8462SApril.Chin@Sun.COM# prechecks
80*8462SApril.Chin@Sun.COM(( max_prime > 1 )) || { print -u2 -f "%s: requires a positive integer as first input.\n" "$0" ; exit 1 ; }
81*8462SApril.Chin@Sun.COM
82*8462SApril.Chin@Sun.COM# calculate prime numbers
83*8462SApril.Chin@Sun.COMprintf $"# %s: Calculating prime numbes from 1 to %i\n" "${ date '+%T' ; }" max_prime 1>&2
84*8462SApril.Chin@Sun.COM
85*8462SApril.Chin@Sun.COMfor (( n=3 ; n < max_prime ; n+=2 )) ; do
86*8462SApril.Chin@Sun.COM	if is_prime $n ; then
87*8462SApril.Chin@Sun.COM		(( pn[num_pn++]=n ))
88*8462SApril.Chin@Sun.COM	fi
89*8462SApril.Chin@Sun.COMdone
90*8462SApril.Chin@Sun.COM
91*8462SApril.Chin@Sun.COM# print results
92*8462SApril.Chin@Sun.COMprintf $"# %s: Calculation done, printing results:\n" "${ date '+%T' ; }" 1>&2
93*8462SApril.Chin@Sun.COM
94*8462SApril.Chin@Sun.COMfor (( n=0 ; n < num_pn ; n++ )) ; do
95*8462SApril.Chin@Sun.COM	# print prime number
96*8462SApril.Chin@Sun.COM	case ${outputformat} in
97*8462SApril.Chin@Sun.COM		block)
98*8462SApril.Chin@Sun.COM			printf $"%i$( (( n % 8 == 0 )) && print -r '\n' || print -r ',\t')" pn[n]
99*8462SApril.Chin@Sun.COM			;;
100*8462SApril.Chin@Sun.COM		line)
101*8462SApril.Chin@Sun.COM			printf $"%i\n" pn[n]
102*8462SApril.Chin@Sun.COM			;;
103*8462SApril.Chin@Sun.COM		*)
104*8462SApril.Chin@Sun.COM			printf $"prime %i:\t%i\n" n pn[n]
105*8462SApril.Chin@Sun.COM			;;
106*8462SApril.Chin@Sun.COM	esac
107*8462SApril.Chin@Sun.COMdone
108*8462SApril.Chin@Sun.COM
109*8462SApril.Chin@Sun.COMif [[ ${outputformat} == "block" ]] && (( n % 8 != 1 )); then
110*8462SApril.Chin@Sun.COM	print
111*8462SApril.Chin@Sun.COMfi
112*8462SApril.Chin@Sun.COM
113*8462SApril.Chin@Sun.COMprintf $"# %s: Done.\n" "${ date '+%T' ; }" 1>&2
114*8462SApril.Chin@Sun.COM
115*8462SApril.Chin@Sun.COM#EOF.
116