xref: /aosp_15_r20/external/icu/CleanSpec.mk (revision 0e209d3975ff4a8c132096b14b0e9364a753506e)
1*0e209d39SAndroid Build Coastguard Worker# Copyright (C) 2019 The Android Open Source Project
2*0e209d39SAndroid Build Coastguard Worker#
3*0e209d39SAndroid Build Coastguard Worker# Licensed under the Apache License, Version 2.0 (the "License");
4*0e209d39SAndroid Build Coastguard Worker# you may not use this file except in compliance with the License.
5*0e209d39SAndroid Build Coastguard Worker# You may obtain a copy of the License at
6*0e209d39SAndroid Build Coastguard Worker#
7*0e209d39SAndroid Build Coastguard Worker#      http://www.apache.org/licenses/LICENSE-2.0
8*0e209d39SAndroid Build Coastguard Worker#
9*0e209d39SAndroid Build Coastguard Worker# Unless required by applicable law or agreed to in writing, software
10*0e209d39SAndroid Build Coastguard Worker# distributed under the License is distributed on an "AS IS" BASIS,
11*0e209d39SAndroid Build Coastguard Worker# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*0e209d39SAndroid Build Coastguard Worker# See the License for the specific language governing permissions and
13*0e209d39SAndroid Build Coastguard Worker# limitations under the License.
14*0e209d39SAndroid Build Coastguard Worker#
15*0e209d39SAndroid Build Coastguard Worker
16*0e209d39SAndroid Build Coastguard Worker# If you don't need to do a full clean build but would like to touch
17*0e209d39SAndroid Build Coastguard Worker# a file or delete some intermediate files, add a clean step to the end
18*0e209d39SAndroid Build Coastguard Worker# of the list.  These steps will only be run once, if they haven't been
19*0e209d39SAndroid Build Coastguard Worker# run before.
20*0e209d39SAndroid Build Coastguard Worker#
21*0e209d39SAndroid Build Coastguard Worker# E.g.:
22*0e209d39SAndroid Build Coastguard Worker#     $(call add-clean-step, touch -c external/sqlite/sqlite3.h)
23*0e209d39SAndroid Build Coastguard Worker#     $(call add-clean-step, rm -rf $(PRODUCT_OUT)/obj/STATIC_LIBRARIES/libz_intermediates)
24*0e209d39SAndroid Build Coastguard Worker#
25*0e209d39SAndroid Build Coastguard Worker# Always use "touch -c" and "rm -f" or "rm -rf" to gracefully deal with
26*0e209d39SAndroid Build Coastguard Worker# files that are missing or have been moved.
27*0e209d39SAndroid Build Coastguard Worker#
28*0e209d39SAndroid Build Coastguard Worker# Use $(PRODUCT_OUT) to get to the "out/target/product/blah/" directory.
29*0e209d39SAndroid Build Coastguard Worker# Use $(OUT_DIR) to refer to the "out" directory.
30*0e209d39SAndroid Build Coastguard Worker#
31*0e209d39SAndroid Build Coastguard Worker# If you need to re-do something that's already mentioned, just copy
32*0e209d39SAndroid Build Coastguard Worker# the command and add it to the bottom of the list.  E.g., if a change
33*0e209d39SAndroid Build Coastguard Worker# that you made last week required touching a file and a change you
34*0e209d39SAndroid Build Coastguard Worker# made today requires touching the same file, just copy the old
35*0e209d39SAndroid Build Coastguard Worker# touch step and add it to the end of the list.
36*0e209d39SAndroid Build Coastguard Worker#
37*0e209d39SAndroid Build Coastguard Worker# ************************************************
38*0e209d39SAndroid Build Coastguard Worker# NEWER CLEAN STEPS MUST BE AT THE END OF THE LIST
39*0e209d39SAndroid Build Coastguard Worker# ************************************************
40*0e209d39SAndroid Build Coastguard Worker
41*0e209d39SAndroid Build Coastguard Worker# For example:
42*0e209d39SAndroid Build Coastguard Worker#$(call add-clean-step, rm -rf $(OUT_DIR)/target/common/obj/APPS/AndroidTests_intermediates)
43*0e209d39SAndroid Build Coastguard Worker#$(call add-clean-step, rm -rf $(OUT_DIR)/target/common/obj/JAVA_LIBRARIES/core_intermediates)
44*0e209d39SAndroid Build Coastguard Worker#$(call add-clean-step, find $(OUT_DIR) -type f -name "IGTalkSession*" -print0 | xargs -0 rm -f)
45*0e209d39SAndroid Build Coastguard Worker#$(call add-clean-step, rm -rf $(PRODUCT_OUT)/data/*)
46*0e209d39SAndroid Build Coastguard Worker
47*0e209d39SAndroid Build Coastguard Worker# Clean out $(HOST_OUT)/com.android.runtime/etc/icu after
48*0e209d39SAndroid Build Coastguard Worker# http://aosp/q/topic:%22move_system_icudat%22 was reverted.
49*0e209d39SAndroid Build Coastguard Worker# In incremental builds the build system appears to remember how many clean
50*0e209d39SAndroid Build Coastguard Worker# steps there have been and only executes those in slots it has never seen
51*0e209d39SAndroid Build Coastguard Worker# before. So, we need to keep adding new entries steps. The reverted change
52*0e209d39SAndroid Build Coastguard Worker# added a single clean spec entry of its own, now rolled back, which we
53*0e209d39SAndroid Build Coastguard Worker# "mask" below with something innocuous (a dupe of the line after).
54*0e209d39SAndroid Build Coastguard Worker$(call add-clean-step, rm -rf $(OUT_DIR)/host/linux-x86/com.android.runtime/etc/icu)
55*0e209d39SAndroid Build Coastguard Worker$(call add-clean-step, rm -rf $(OUT_DIR)/host/linux-x86/com.android.runtime/etc/icu)
56*0e209d39SAndroid Build Coastguard Worker
57*0e209d39SAndroid Build Coastguard Worker# Remove the icu .dat file from /system/usr/icu and the host equivalent. 2nd attempt.
58*0e209d39SAndroid Build Coastguard Worker$(call add-clean-step, rm -rf $(PRODUCT_OUT)/system/usr/icu/*)
59*0e209d39SAndroid Build Coastguard Worker$(call add-clean-step, rm -rf $(OUT_DIR)/host/linux-x86/usr/icu/*)
60*0e209d39SAndroid Build Coastguard Worker
61*0e209d39SAndroid Build Coastguard Worker# ************************************************
62*0e209d39SAndroid Build Coastguard Worker# NEWER CLEAN STEPS MUST BE AT THE END OF THE LIST
63*0e209d39SAndroid Build Coastguard Worker# ************************************************
64