New checkpaths.sh
  1 #!/bin/ksh -p
  2 #
  3 # CDDL HEADER START
  4 #
  5 # The contents of this file are subject to the terms of the
  6 # Common Development and Distribution License (the "License").
  7 # You may not use this file except in compliance with the License.
  8 #
  9 # You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
 10 # or http://www.opensolaris.org/os/licensing.
 11 # See the License for the specific language governing permissions
 12 # and limitations under the License.
 13 #
 14 # When distributing Covered Code, include this CDDL HEADER in each
 15 # file and include the License file at usr/src/OPENSOLARIS.LICENSE.
 16 # If applicable, add the following below this CDDL HEADER, with the
 17 # fields enclosed by brackets "[]" replaced with your own identifying
 18 # information: Portions Copyright [yyyy] [name of copyright owner]
 19 #
 20 # CDDL HEADER END
 21 #
 22 #
 23 # Copyright 2005 Sun Microsystems, Inc.  All rights reserved.
 24 # Use is subject to license terms.
 25 #
 26 #ident  "@(#)checkpaths.sh      1.5     05/11/13 SMI"
 27 
 28 # Quis custodiet ipsos custodies?
 29 
 30 if [ -z "$SRC" ]; then
 31         SRC=$CODEMGR_WS/usr/src
 32 fi
 33 
 34 if [ -z "$CODEMGR_WS" -o ! -d "$CODEMGR_WS" -o ! -d "$SRC" ]; then
 35         echo "$0: must be run from within a workspace."
 36         exit 1
 37 fi
 38 
 39 cd $CODEMGR_WS || exit 1
 40 
 41 # Use -b to tell this script to ignore derived (built) objects.
 42 if [ "$1" = "-b" ]; then
 43         b_flg=y
 44 fi
 45 
 46 # Not currently used; available for temporary workarounds.
 47 args="-k NEVER_CHECK"
 48 
 49 # We intentionally don't depend on $MACH here, and thus no $ROOT.  If
 50 # a proto area exists, then we use it.  This allows this script to be
 51 # run against gates (which should contain both SPARC and x86 proto
 52 # areas), build workspaces (which should contain just one proto area),
 53 # and unbuilt workspaces (which contain no proto areas).
 54 if [ "$b_flg" = y ]; then
 55         rootlist=
 56 elif [ $# -gt 0 ]; then
 57         rootlist=$*
 58 else
 59         rootlist="$CODEMGR_WS/proto/root_sparc $CODEMGR_WS/proto/root_i386"
 60 fi
 61 
 62 for ROOT in $rootlist
 63 do
 64         case "$ROOT" in
 65         *sparc) arch=sparc;;
 66         *i386)  arch=i386;;
 67         *)
 68                 echo "$ROOT has unknown architecture." >&2
 69                 exit 1
 70                 ;;
 71         esac
 72         if [ -d $ROOT ]; then
 73                 if [ "$CLOSED_IS_PRESENT" = no ]; then
 74                         excl="-e ^usr/include/ike/"
 75                 fi
 76                 validate_paths '-s/\s*'$arch'$//' -e '^opt/onbld' $excl \
 77                         -b $ROOT $args $SRC/pkgdefs/etc/exception_list_$arch
 78         fi
 79 done
 80 
 81 # Two entries in the findunref exception_list deal with things created
 82 # by nightly.  Otherwise, this test could be run on an unmodifed (and
 83 # unbuilt) workspace.  We handle this by flagging the one that is
 84 # present only on a built workspace (./*.out) and the one that's
 85 # present only after a run of findunref (./*.ref) with ISUSED, and
 86 # disabling all checks of them.  The assumption is that the entries
 87 # marked with ISUSED are always known to be good, thus the Latin quote
 88 # at the top of the file.
 89 if [ -r $SRC/tools/findunref/exception_list ]; then
 90         if [ "$CLOSED_IS_PRESENT" = no ]; then
 91                 excl="-e ^\./closed"
 92         fi
 93         validate_paths -k ISUSED -r -e '^\*' $excl -b $SRC/.. \
 94                 $SRC/tools/findunref/exception_list
 95 fi
 96 
 97 # These are straightforward.
 98 if [ -d $SRC/xmod ]; then
 99         if [ "$CLOSED_IS_PRESENT" = no ]; then
100                 excl="-e ^usr/closed"
101         fi
102         validate_paths $excl $SRC/xmod/cry_files
103         if [ "$CLOSED_IS_PRESENT" = no ]; then
104                 excl="-e ^../closed"
105         fi
106         validate_paths $excl -b $SRC $SRC/xmod/xmod_files
107 fi
108 
109 # Finally, make sure the that (req|inc).flg files are in good shape.
110 validate_flg
111 
112 exit 0