aboutsummaryrefslogtreecommitdiff
path: root/.Sanitize
blob: f8fad1edd1b38ec1b338a3ea786dddb89b403a64 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
########################
#
#	 H    H  EEEEEE Y     Y  !!
#	 H    H  E       Y   Y   !!
#	 H    H  E        Y Y    !!
#	 H    H  E         Y     !!
#	 HHHHHH  EEEEE     Y     !!
#	 H    H  E         Y     !!
#	 H    H  E         Y     !!
#	 H    H  E         Y
#	 H    H  EEEEEE    Y     !!
#
# YO!  READ ME!!!!!!!!!
# If you're about to add a file or directory which isn't checked out as part
# of every module in devo (e.g., if "cvs co gas+utils" won't get it, or if
# "cvs co gcc" won't get it), then don't, Don't, DON'T add it to the regular
# things-to-keep or things-to-lose sections.  Instead, add it to the setting
# of keep_these_too or lose_these_too before those variables are rescanned
# to check for the existence of the items listed in them.
#
# Otherwise, somebody will check out some package that doesn't include your
# new file, and will get warnings from Sanitize when everything is really
# okay.  You don't want to get people in the habit of ignoring complaints from
# Sanitize, do you?  No, I didn't think so.
#
# If you do add a file to the regular things-to-keep section, don't forget
# to add the corresponding entry to the devo-support entry (or whatever) in
# the modules file.
#
########################

# .Sanitize for devo.

# Each directory to survive its way into a release will need a file
# like this one called "./.Sanitize".  All keyword lines must exist,
# and must exist in the order specified by this file.  Each directory
# in the tree will be processed, top down, in the following order.

# Hash started lines like this one are comments and will be deleted
# before anything else is done.  Blank lines will also be squashed
# out.

# The lines between the "Do-first:" line and the "Things-to-keep:"
# line are executed as a /bin/sh shell script before anything else is
# done in this directory.

Do-first:

keep_these_too="${keep_these_too} .cvsignore CYGNUS autoconf
	bfd binutils byacc cvs deja-gnu dejagnu diff dosrel dvips emacs emacs19
	examples expect fileutils flex
	gas gcc gdb gdbm gdbtest glob gprof grep grez groff
	include install.sh ispell
	ld libg++ libgcc libgloss libiberty libio librx libstdc++
	m4 make mmalloc move-if-change newlib opcodes
	pagas patch prms rcs readline sed send-pr shellutils sim textutils
	texinfo tgas utils uudecode wdiff xiberty
	configure.bat makeall.bat winsup
	guile perl
	mpw-README mpw-configure mpw-config.in mpw-build.in"

lose_these_too="${lose_these_too} testsuite"

cygnus_files="release release-info build-all.mk test-build.mk COPYING.NEWLIB"

if ( echo $* | grep keep\-cygnus > /dev/null) ; then
	keep_these_too="${keep_these_too} ${cygnus_files}"
else
	lose_these_too="${lose_these_too} ${cygnus_files}"
fi

gdbtk_files="tcl tk"

if ( echo $* | grep lose\-gdbtk > /dev/null) ; then
	lose_these_too="${lose_these_too} ${gdbtk_files}"
	if [ -n "${verbose}" ] ; then
		echo Deleting ${gdbtk_files}
	fi
else
	keep_these_too="${keep_these_too} ${gdbtk_files}"
	if [ -n "${verbose}" ] ; then
		echo Keeping ${gdbtk_files}
	fi
fi

# This is for newlib net releases.
newlib_file="COPYING.NEWLIB"

if (echo $* | grep keep\-newlib > /dev/null) ; then
	if (echo $* | grep -v keep\-cygnus > /dev/null) ; then
		keep_these_too="${keep_these_too} ${newlib_file}"
		lose_these_too="`echo ${lose_these_too} | sed -e s/${newlib_file}//`"
	fi
else
	true; # Let keep-cygnus handle it.
fi

# This top-level directory is special.  We often check out only subsets
# of this directory, and complaining about directories or files we didn't
# check out just gets obnoxious.

list="`(for i in ${keep_these_too}; do echo $i ; done) | sort -u`"
keep_these_too=

for file in $list ; do
	if [ -r $file ] || [ -d $file ] ; then
		keep_these_too="${keep_these_too} $file"
	fi
done

list="`(for i in ${lose_these_too}; do echo $i ; done) | sort -u` "
lose_these_too=

for file in $list ; do
	if [ -r $file ] || [ -d $file ] ; then
		lose_these_too="${lose_these_too} $file"
	fi
done

# All files listed between the "Things-to-keep:" line and the
# "Do-last:" line will be kept.  All other files will be removed.
# Directories listed in this section will have their own Sanitize
# called.  Directories not listed will be removed in their entirety
# with rm -rf.

Things-to-keep:

COPYING
COPYING.LIB
ChangeLog
Makefile.in
README
config
config-ml.in
config.guess
config.sub
configure
configure.in
etc
symlink-tree

Things-to-lose:

# The lines between the "Do-last:" line and the end of the file
# are executed as a /bin/sh shell script after everything else is
# done.

Do-last:

# Don't try to clean directories here, as the 'mv' command will fail.
# Also, grep fails on NFS mounted directories.

if ( echo $* | egrep verbose > /dev/null ) ; then
	verbose=true
else
	verbose=
fi

# Remove "sanitize-Sanitize" lines.
if [ -n "${verbose}" ] ; then
	echo Cleaning unconditional sanitizations out of Makefile.in...
fi
cp Makefile.in new
sed '/start\-sanitize\-Sanitize/,/end-\sanitize\-Sanitize/d' < Makefile.in > new
if [ -n "${safe}" -a ! -f .Recover/Makefile.in ] ; then
	mv Makefile.in .Recover
fi
mv new Makefile.in

if [ -n "${verbose}" ] ; then
	echo Thawing away the \"chill\"...
fi

if ( echo $* | grep keep\-chill > /dev/null ) ; then
	for i in * ; do
		if test ! -d $i && (grep sanitize-chill $i > /dev/null) ; then
			if [ -n "${verbose}" ] ; then
				echo Keeping chill stuff in $i
			fi
		fi
	done
else
	for i in * ; do
		if test ! -d $i && (grep sanitize-chill $i > /dev/null) ; then
			if [ -n "${verbose}" ] ; then
				echo Thawing the \"chill\" out of $i...
			fi
			cp $i new
			sed '/start\-sanitize\-chill/,/end-\sanitize\-chill/d' < $i > new
			if [ -n "${safe}" -a ! -f .Recover/$i ] ; then
				if [ -n "${verbose}" ] ; then
					echo Caching $i in .Recover...
				fi
				mv $i .Recover
			fi
			mv new $i
		fi
	done
fi

if [ -n "${verbose}" ] ; then
	echo Processing \"arc\"...
fi

arc_files="config.sub configure.in config-ml.in"

if ( echo $* | grep keep\-arc > /dev/null ) ; then
	for i in $arc_files ; do
		if test ! -d $i && (grep sanitize-arc $i > /dev/null) ; then
			if [ -n "${verbose}" ] ; then
				echo Keeping arc stuff in $i
			fi
		fi
	done
else
	for i in * ; do
		if test ! -d $i && (grep sanitize-arc $i > /dev/null) ; then
			if [ -n "${verbose}" ] ; then
				echo Removing traces of \"arc\" from $i...
			fi
			cp $i new
			sed '/start\-sanitize\-arc/,/end-\sanitize\-arc/d' < $i > new
			if [ -n "${safe}" -a ! -f .Recover/$i ] ; then
				if [ -n "${verbose}" ] ; then
					echo Caching $i in .Recover...
				fi
				mv $i .Recover
			fi
			mv new $i
		fi
	done
fi

rce_files="config.sub"

if ( echo $* | grep keep\-rce > /dev/null ) ; then
	for i in $rce_files ; do
		if test ! -d $i && (grep sanitize-rce $i > /dev/null) ; then
			if [ -n "${verbose}" ] ; then
				echo Keeping rce stuff in $i
			fi
		fi
	done
else
	for i in $rce_files ; do
		if test ! -d $i && (grep sanitize-rce $i > /dev/null) ; then
			if [ -n "${verbose}" ] ; then
				echo Removing traces of \"rce\" from $i...
			fi
			cp $i new
			sed '/start\-sanitize\-rce/,/end-\sanitize\-rce/d' < $i > new
			if [ -n "${safe}" -a ! -f .Recover/$i ] ; then
				if [ -n "${verbose}" ] ; then
					echo Caching $i in .Recover...
				fi
				mv $i .Recover
			fi
			mv new $i
		fi
	done
fi

if ( echo $* | grep lose\-gdbtk > /dev/null ) ; then
	echo Catering to RMS by removing traces of \"gdbtk\"...
	if [ -n "${verbose}" ] ; then
		echo Removing traces of \"gdbtk\" from Makefile.in...
	fi
	cp Makefile.in new
	sed -e '/GDBTK_SUPPORT_DIRS=/d' -e 's/ $(GDBTK_SUPPORT_DIRS)//' < Makefile.in > new
	if [ -n "${safe}" -a ! -f .Recover/Makefile.in ] ; then
		if [ -n "${verbose}" ] ; then
			echo Caching Makefile.in in .Recover...
		fi
		mv Makefile.in .Recover
	fi
	mv new Makefile.in
fi

if ( echo $* | grep keep\-gm > /dev/null ) ; then
	for i in * ; do
		if test ! -d $i && (grep sanitize-gm $i > /dev/null) ; then
			if [ -n "${verbose}" ] ; then
				echo Keeping gm stuff in $i
			fi
		fi
	done
else
	for i in * ; do
		if test ! -d $i && (grep sanitize-gm $i > /dev/null) ; then
			if [ -n "${verbose}" ] ; then
				echo Removing traces of \"gm\" from $i...
			fi
			cp $i new
			sed '/start\-sanitize\-gm/,/end-\sanitize\-gm/d' < $i > new
			if [ -n "${safe}" -a ! -f .Recover/$i ] ; then
				if [ -n "${verbose}" ] ; then
					echo Caching $i in .Recover...
				fi
				mv $i .Recover
			fi
			mv new $i
		fi
	done
fi

# Do this check LAST!
for i in * ; do
	if test ! -d $i && (grep sanitize $i > /dev/null) ; then
		echo '***' Some mentions of Sanitize are still left in $i! 1>&2
		exit 1
	fi
done

# eof