xref: /titanic_50/usr/src/tools/scripts/checkpaths.sh (revision db5b5f1e7e8c59712dae4a0b5c55ecee0e4c1bfc)
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#
24# Copyright 2009 Sun Microsystems, Inc.  All rights reserved.
25# Use is subject to license terms.
26#
27
28# Quis custodiet ipsos custodies?
29
30if [ -z "$SRC" ]; then
31	SRC=$CODEMGR_WS/usr/src
32fi
33
34if [ -z "$CODEMGR_WS" -o ! -d "$CODEMGR_WS" -o ! -d "$SRC" ]; then
35	echo "$0: must be run from within a workspace."
36	exit 1
37fi
38
39cd $CODEMGR_WS || exit 1
40
41# Use -b to tell this script to ignore derived (built) objects.
42if [ "$1" = "-b" ]; then
43	b_flg=y
44fi
45
46# Not currently used; available for temporary workarounds.
47args="-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).
54if [ "$b_flg" = y ]; then
55	rootlist=
56elif [ $# -gt 0 ]; then
57	rootlist=$*
58else
59	rootlist="$CODEMGR_WS/proto/root_sparc $CODEMGR_WS/proto/root_i386"
60fi
61
62# If the closed source is not present, then exclude IKE from validation.
63if [ "$CLOSED_IS_PRESENT" = no ]; then
64	excl="-e ^usr/include/ike/"
65fi
66
67for ROOT in $rootlist
68do
69	case "$ROOT" in
70	*sparc|*sparc-nd)
71		arch=sparc
72		;;
73	*i386|*i386-nd)
74		arch=i386
75		;;
76	*)
77		echo "$ROOT has unknown architecture." >&2
78		exit 1
79		;;
80	esac
81	if [ -d $ROOT ]; then
82		#
83		# This is the old-style packaging exception list, from
84		# the svr4-specific usr/src/pkgdefs
85		#
86		[ -f $SRC/pkgdefs/etc/exception_list_$arch ] && \
87			validate_paths '-s/\s*'$arch'$//' $excl -b $ROOT \
88			    $args $SRC/pkgdefs/etc/exception_list_$arch
89		#
90		# These are the new-style packaging exception lists,
91		# from the repository-wide exception_lists/ directory.
92		#
93		e="$CODEMGR_WS/exception_lists/packaging"
94		for f in $e; do
95			if [ -f $f ]; then
96				nawk 'NF == 1 || /[ 	]\+'$arch'$/ { print; }' \
97				    < $f | validate_paths -b $ROOT -n $f
98			fi
99		done
100	fi
101done
102
103# Two entries in the findunref exception_list deal with things created
104# by nightly.  Otherwise, this test could be run on an unmodifed (and
105# unbuilt) workspace.  We handle this by flagging the one that is
106# present only on a built workspace (./*.out) and the one that's
107# present only after a run of findunref (./*.ref) with ISUSED, and
108# disabling all checks of them.  The assumption is that the entries
109# marked with ISUSED are always known to be good, thus the Latin quote
110# at the top of the file.
111#
112# The exception_list is generated from whichever input files are appropriate
113# for this workspace, so checking it obviates the need to check the inputs.
114
115if [ -r $SRC/tools/findunref/exception_list ]; then
116	validate_paths -k ISUSED -r -e '^\*' $SRC/tools/findunref/exception_list
117fi
118
119# These are straightforward.
120if [ -d $SRC/xmod ]; then
121	# If the closed source is not present, then don't validate it.
122	if [ "$CLOSED_IS_PRESENT" = no ]; then
123		excl_cry="-e ^usr/closed"
124		excl_xmod="-e ^../closed"
125	fi
126	validate_paths $excl_cry $SRC/xmod/cry_files
127	validate_paths $excl_xmod -b $SRC $SRC/xmod/xmod_files
128fi
129
130if [ -f $SRC/tools/opensolaris/license-list ]; then
131	excl=
132	if [ "$CLOSED_IS_PRESENT" = no ]; then
133		excl="-e ^usr/closed"
134	fi
135	sed -e 's/$/.descrip/' < $SRC/tools/opensolaris/license-list | \
136		validate_paths -n SRC/tools/opensolaris/license-list $excl
137fi
138
139# Finally, make sure the that (req|inc).flg files are in good shape.
140# If SCCS files are not expected to be present, though, then don't
141# check them.
142if [ ! -d "$CODEMGR_WS/Codemgr_wsdata" ]; then
143	f_flg='-f'
144fi
145# If the closed source is not present, then don't validate it.
146if [ "$CLOSED_IS_PRESENT" = no ]; then
147	excl="-e ^usr/closed/"
148fi
149
150validate_flg $f_flg $excl
151
152exit 0
153