tst.include.ksh revision 9512fe850e98fdd448c638ca63fdd92a8a510255
#
# CDDL HEADER START
#
# The contents of this file are subject to the terms of the
# Common Development and Distribution License (the "License").
# You may not use this file except in compliance with the License.
#
# You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
# See the License for the specific language governing permissions
# and limitations under the License.
#
# When distributing Covered Code, include this CDDL HEADER in each
# file and include the License file at usr/src/OPENSOLARIS.LICENSE.
# If applicable, add the following below this CDDL HEADER, with the
# fields enclosed by brackets "[]" replaced with your own identifying
# information: Portions Copyright [yyyy] [name of copyright owner]
#
# CDDL HEADER END
#
#
# Copyright 2006 Sun Microsystems, Inc. All rights reserved.
# Use is subject to license terms.
#
#pragma ident "%Z%%M% %I% %E% SMI"
doit()
{
file=$1
ofile=$2
errfile=$3
#include <sys/$file>
void
main()
{}
EOF
#include <sys/$file>
BEGIN
{
exit(0);
}
EOF
if [ $? -ne 0 ]; then
else
fi
fi
}
if [ ! -x $CC ]; then
echo "$0: bad compiler: $CC" >& 2
exit 1
fi
concurrency=`psrinfo | wc -l`
let i=0
#
# because they include static globals (!) or function bodies (!!) in the header
# file. Hopefully these remain sufficiently few that the O(#files * #badfiles)
# algorithm, below, doesn't become a problem. (And yes, writing scripts in
# something other than ksh1888 would probably be a good idea.) If this script
# becomes a problem, kindly fix it by reducing the number of bad files! (That
# is, fix it by fixing the broken file, not the broken script.)
#
continue 2
fi
done
let i=i+1
if [ $i -eq $concurrency ]; then
#
# This isn't optimal -- it creates a highly fluctuating load
# as we wait for all work to complete -- but it's an easy
# way of parallelizing work.
#
wait
let i=0
fi
done
wait
if [ -f $ofile ]; then
fi
done
exit $status