liyujie
2025-08-28 b3810562527858a3b3d98ffa6e9c9c5b0f4a9a8e
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
/*
 * Copyright (C) 2017 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */
package android.service.autofill;
 
import static android.view.autofill.Helper.sDebug;
 
import android.annotation.NonNull;
import android.annotation.TestApi;
import android.os.Parcelable;
import android.util.Log;
import android.util.Pair;
import android.widget.RemoteViews;
 
import java.util.ArrayList;
 
/**
 * Superclass of all transformation the system understands. As this is not public all
 * subclasses have to implement {@link Transformation} again.
 *
 * @hide
 */
@TestApi
public abstract class InternalTransformation implements Transformation, Parcelable {
 
    private static final String TAG = "InternalTransformation";
 
    /**
     * Applies this transformation to a child view of a {@link android.widget.RemoteViews
     * presentation template}.
     *
     * @param finder object used to find the value of a field in the screen.
     * @param template the {@link RemoteViews presentation template}.
     * @param childViewId resource id of the child view inside the template.
     */
    abstract void apply(@NonNull ValueFinder finder, @NonNull RemoteViews template,
            int childViewId) throws Exception;
 
    /**
     * Applies multiple transformations to the children views of a
     * {@link android.widget.RemoteViews presentation template}.
     *
     * @param finder object used to find the value of a field in the screen.
     * @param template the {@link RemoteViews presentation template}.
     * @param transformations map of resource id of the child view inside the template to
     * transformation.
     */
    public static boolean batchApply(@NonNull ValueFinder finder, @NonNull RemoteViews template,
            @NonNull ArrayList<Pair<Integer, InternalTransformation>> transformations) {
        final int size = transformations.size();
        if (sDebug) Log.d(TAG, "getPresentation(): applying " + size + " transformations");
        for (int i = 0; i < size; i++) {
            final Pair<Integer, InternalTransformation> pair = transformations.get(i);
            final int id = pair.first;
            final InternalTransformation transformation = pair.second;
            if (sDebug) Log.d(TAG, "#" + i + ": " + transformation);
 
            try {
                transformation.apply(finder, template, id);
            } catch (Exception e) {
                // Do not log full exception to avoid PII leaking
                Log.e(TAG, "Could not apply transformation " + transformation + ": "
                        + e.getClass());
                return false;
            }
        }
        return true;
    }
}