File: TimeZoneProviderSuggestion.java

package info (click to toggle)
android-platform-frameworks-base 1%3A14~beta1-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 326,092 kB
  • sloc: java: 2,032,373; xml: 343,016; cpp: 304,181; python: 3,683; ansic: 2,090; sh: 1,871; makefile: 117; sed: 19
file content (204 lines) | stat: -rw-r--r-- 7,184 bytes parent folder | download | duplicates (2)
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
/*
 * Copyright (C) 2020 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.timezone;

import android.annotation.ElapsedRealtimeLong;
import android.annotation.NonNull;
import android.annotation.Nullable;
import android.annotation.SystemApi;
import android.os.Parcel;
import android.os.Parcelable;
import android.os.SystemClock;

import java.time.Duration;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import java.util.Objects;

/**
 * A suggestion from a {@link TimeZoneProviderService} containing zero or more time zones.
 *
 * @hide
 */
@SystemApi
public final class TimeZoneProviderSuggestion implements Parcelable {

    @NonNull
    private final List<String> mTimeZoneIds;

    @ElapsedRealtimeLong
    private final long mElapsedRealtimeMillis;

    private TimeZoneProviderSuggestion(@NonNull List<String> timeZoneIds,
            @ElapsedRealtimeLong long elapsedRealtimeMillis) {
        mTimeZoneIds = immutableList(timeZoneIds);
        mElapsedRealtimeMillis = elapsedRealtimeMillis;
    }

    /**
     * Returns the time of the suggestion in elapsed real-time since system boot. Where possible,
     * the time should be based on the time of the data used when determining time zone. For
     * example, if it was based on a {@link android.location.Location} then it should be the time
     * associated with that location.
     *
     * <p>This value is compared to {@link
     * android.os.SystemClock#elapsedRealtime()}, to calculate the age of a fix and to compare
     * {@link TimeZoneProviderSuggestion} instances.
     *
     * @return elapsed real-time of fix, in milliseconds
     */
    @ElapsedRealtimeLong
    public long getElapsedRealtimeMillis() {
        return mElapsedRealtimeMillis;
    }

    /**
     * Returns the zero or more time zone IDs for this suggestion.
     *
     * <p>Time zone IDs are TZDB IDs like "America/Los_Angeles" that would be accepted by {@link
     * java.util.TimeZone#getTimeZone(String)}.
     *
     * <p>Most often a suggestion will contain a single time zone ID but other possibilities are
     * valid. A suggestion with zero time zone IDs means the provider is certain there are no time
     * zones for the current location, e.g. for oceans, boundaries or disputed areas. A suggestion
     * with multiple IDs can occur on boundaries or disputed areas. The ordering should be in order
     * of likelihood if possible, but the time zone detection service may choose from any of the
     * zones suggested if it has other supporting information available.
     */
    @NonNull
    public List<String> getTimeZoneIds() {
        return mTimeZoneIds;
    }

    @Override
    public String toString() {
        return "TimeZoneProviderSuggestion{"
                + "mTimeZoneIds=" + mTimeZoneIds
                + ", mElapsedRealtimeMillis=" + mElapsedRealtimeMillis
                + "(" + Duration.ofMillis(mElapsedRealtimeMillis) + ")"
                + '}';
    }

    public static final @NonNull Creator<TimeZoneProviderSuggestion> CREATOR =
            new Creator<TimeZoneProviderSuggestion>() {
                @Override
                public TimeZoneProviderSuggestion createFromParcel(Parcel in) {
                    @SuppressWarnings("unchecked")
                    ArrayList<String> timeZoneIds =
                            (ArrayList<String>) in.readArrayList(null /* classLoader */, java.lang.String.class);
                    long elapsedRealtimeMillis = in.readLong();
                    return new TimeZoneProviderSuggestion(timeZoneIds, elapsedRealtimeMillis);
                }

                @Override
                public TimeZoneProviderSuggestion[] newArray(int size) {
                    return new TimeZoneProviderSuggestion[size];
                }
            };

    @Override
    public int describeContents() {
        return 0;
    }

    @Override
    public void writeToParcel(@NonNull Parcel parcel, int flags) {
        parcel.writeList(mTimeZoneIds);
        parcel.writeLong(mElapsedRealtimeMillis);
    }

    /**
     * Similar to {@link #equals} except this methods checks for equivalence, not equality.
     * i.e. two suggestions are equivalent if they suggest the same time zones.
     *
     * @hide
     */
    @SuppressWarnings("ReferenceEquality")
    public boolean isEquivalentTo(@Nullable TimeZoneProviderSuggestion other) {
        if (this == other) {
            return true;
        }
        if (other == null) {
            return false;
        }
        // Only check the time zone IDs. The times can be different, but we don't mind.
        return mTimeZoneIds.equals(other.mTimeZoneIds);
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) {
            return true;
        }
        if (o == null || getClass() != o.getClass()) {
            return false;
        }
        TimeZoneProviderSuggestion that = (TimeZoneProviderSuggestion) o;
        return mElapsedRealtimeMillis == that.mElapsedRealtimeMillis
                && mTimeZoneIds.equals(that.mTimeZoneIds);
    }

    @Override
    public int hashCode() {
        return Objects.hash(mTimeZoneIds, mElapsedRealtimeMillis);
    }

    /** A builder for {@link TimeZoneProviderSuggestion}. */
    public static final class Builder {

        private @NonNull List<String> mTimeZoneIds = Collections.emptyList();
        @ElapsedRealtimeLong
        private long mElapsedRealtimeMillis = SystemClock.elapsedRealtime();

        /**
         * Sets the time zone IDs of this suggestion.
         */
        @NonNull
        public Builder setTimeZoneIds(@NonNull List<String> timeZoneIds) {
            mTimeZoneIds = Objects.requireNonNull(timeZoneIds);
            return this;
        }

        /**
         * Sets the time of this suggestion, in elapsed real-time since system boot.
         */
        @NonNull
        public Builder setElapsedRealtimeMillis(@ElapsedRealtimeLong long time) {
            mElapsedRealtimeMillis = time;
            return this;
        }

        /**
         * Builds a {@link TimeZoneProviderSuggestion} instance.
         */
        @NonNull
        public TimeZoneProviderSuggestion build() {
            return new TimeZoneProviderSuggestion(mTimeZoneIds, mElapsedRealtimeMillis);
        }
    }

    @NonNull
    private static List<String> immutableList(@NonNull List<String> list) {
        Objects.requireNonNull(list);
        if (list.isEmpty()) {
            return Collections.emptyList();
        } else {
            return Collections.unmodifiableList(new ArrayList<>(list));
        }
    }
}