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
82
83
84
85
86
87
88
89
90
91
/*
 * Copyright (C) 2018 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.augmented;
 
import android.annotation.NonNull;
import android.annotation.Nullable;
import android.annotation.SystemApi;
import android.annotation.TestApi;
 
/**
 * Response to a {@link FillRequest}.
 *
 * @hide
 */
@SystemApi
@TestApi
public final class FillResponse {
 
    private final FillWindow mFillWindow;
 
    private FillResponse(@NonNull Builder builder) {
        mFillWindow = builder.mFillWindow;
    }
 
    /** @hide */
    @Nullable
    FillWindow getFillWindow() {
        return mFillWindow;
    }
 
    /**
     * Builder for {@link FillResponse} objects.
     *
     * @hide
     */
    @SystemApi
    @TestApi
    public static final class Builder {
 
        private FillWindow mFillWindow;
 
        /**
         * Sets the {@link FillWindow} used to display the Autofill UI.
         *
         * <p>Must be called when the service is handling the request so the Android System can
         * properly synchronize the UI.
         *
         * @return this builder
         */
        @NonNull
        public Builder setFillWindow(@NonNull FillWindow fillWindow) {
            // TODO(b/123100712): check not null / unit test / throw exception if FillWindow not
            // updated yet
            mFillWindow = fillWindow;
            return this;
        }
 
        /**
         * Builds a new {@link FillResponse} instance.
         *
         * @throws IllegalStateException if any of the following conditions occur:
         * <ol>
         *   <li>{@link #build()} was already called.
         *   <li>No call was made to {@link #setFillWindow(FillWindow)} or
         *   {@ling #setIgnoredIds(List<AutofillId>)}.
         * </ol>
         *
         * @return A built response.
         */
        @NonNull
        public FillResponse build() {
            // TODO(b/123100712): check conditions / add unit test
            return new FillResponse(this);
        }
    }
 
    // TODO(b/123100811): implement to String
}