xref: /illumos-gate/usr/src/tools/scripts/checkpaths.sh (revision ead1f93ee620d7580f7e53350fe5a884fc4f158a)
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		if [ "$CLOSED_IS_PRESENT" = "yes" ]; then
95			e="$e $CODEMGR_WS/exception_lists/packaging.closed"
96		else
97			e="$e $CODEMGR_WS/exception_lists/packaging.open"
98		fi
99		for f in $e; do
100			if [ -f $f ]; then
101				nawk 'NF == 1 || /[ 	]\+'$arch'$/ { print; }' \
102				    < $f | validate_paths -b $ROOT -n $f
103			fi
104		done
105	fi
106done
107
108# Two entries in the findunref exception_list deal with things created
109# by nightly.  Otherwise, this test could be run on an unmodifed (and
110# unbuilt) workspace.  We handle this by flagging the one that is
111# present only on a built workspace (./*.out) and the one that's
112# present only after a run of findunref (./*.ref) with ISUSED, and
113# disabling all checks of them.  The assumption is that the entries
114# marked with ISUSED are always known to be good, thus the Latin quote
115# at the top of the file.
116#
117# The exception_list is generated from whichever input files are appropriate
118# for this workspace, so checking it obviates the need to check the inputs.
119
120if [ -r $SRC/tools/findunref/exception_list ]; then
121	validate_paths -k ISUSED -r -e '^\*' $SRC/tools/findunref/exception_list
122fi
123
124# These are straightforward.
125if [ -d $SRC/xmod ]; then
126	# If the closed source is not present, then don't validate it.
127	if [ "$CLOSED_IS_PRESENT" = no ]; then
128		excl_cry="-e ^usr/closed"
129		excl_xmod="-e ^../closed"
130	fi
131	validate_paths $excl_cry $SRC/xmod/cry_files
132	validate_paths $excl_xmod -b $SRC $SRC/xmod/xmod_files
133fi
134
135if [ -f $SRC/tools/opensolaris/license-list ]; then
136	excl=
137	if [ "$CLOSED_IS_PRESENT" = no ]; then
138		excl="-e ^usr/closed"
139	fi
140	sed -e 's/$/.descrip/' < $SRC/tools/opensolaris/license-list | \
141		validate_paths -n SRC/tools/opensolaris/license-list $excl
142fi
143
144# Finally, make sure the that (req|inc).flg files are in good shape.
145# If SCCS files are not expected to be present, though, then don't
146# check them.
147if [ ! -d "$CODEMGR_WS/Codemgr_wsdata" ]; then
148	f_flg='-f'
149fi
150# If the closed source is not present, then don't validate it.
151if [ "$CLOSED_IS_PRESENT" = no ]; then
152	excl="-e ^usr/closed/"
153fi
154
155validate_flg $f_flg $excl
156
157exit 0
158