Expose onEmergencyNumberListChanged, semantics change am: e182543791
Original change: https://android-review.googlesource.com/c/platform/frameworks/base/+/1469715 Change-Id: I00eef453ff044c5c5bc6878b61277c5e133b3dbe
This commit is contained in:
@@ -47801,6 +47801,7 @@ package android.telephony {
|
||||
method public void onDataConnectionStateChanged(int);
|
||||
method public void onDataConnectionStateChanged(int, int);
|
||||
method @RequiresPermission("android.permission.READ_PHONE_STATE") public void onDisplayInfoChanged(@NonNull android.telephony.TelephonyDisplayInfo);
|
||||
method public void onEmergencyNumberListChanged(@NonNull java.util.Map<java.lang.Integer,java.util.List<android.telephony.emergency.EmergencyNumber>>);
|
||||
method @RequiresPermission("android.permission.READ_PRECISE_PHONE_STATE") public void onImsCallDisconnectCauseChanged(@NonNull android.telephony.ims.ImsReasonInfo);
|
||||
method public void onMessageWaitingIndicatorChanged(boolean);
|
||||
method @RequiresPermission("android.permission.MODIFY_PHONE_STATE") public void onPreciseDataConnectionStateChanged(@NonNull android.telephony.PreciseDataConnectionState);
|
||||
|
||||
@@ -10814,7 +10814,8 @@ package android.telephony {
|
||||
|
||||
public class PhoneStateListener {
|
||||
method public void onCallAttributesChanged(@NonNull android.telephony.CallAttributes);
|
||||
method public void onOutgoingEmergencyCall(@NonNull android.telephony.emergency.EmergencyNumber);
|
||||
method @Deprecated public void onOutgoingEmergencyCall(@NonNull android.telephony.emergency.EmergencyNumber);
|
||||
method public void onOutgoingEmergencyCall(@NonNull android.telephony.emergency.EmergencyNumber, int);
|
||||
method public void onOutgoingEmergencySms(@NonNull android.telephony.emergency.EmergencyNumber);
|
||||
method @RequiresPermission("android.permission.READ_PRECISE_PHONE_STATE") public void onPreciseCallStateChanged(@NonNull android.telephony.PreciseCallState);
|
||||
method public void onRadioPowerStateChanged(int);
|
||||
|
||||
@@ -1627,6 +1627,10 @@ package android.telephony {
|
||||
method public static void setMinMatchForTest(int);
|
||||
}
|
||||
|
||||
public class PhoneStateListener {
|
||||
method public void onOutgoingEmergencyCall(@NonNull android.telephony.emergency.EmergencyNumber, int);
|
||||
}
|
||||
|
||||
public final class PreciseDataConnectionState implements android.os.Parcelable {
|
||||
ctor @Deprecated public PreciseDataConnectionState(int, int, int, @NonNull String, @Nullable android.net.LinkProperties, int);
|
||||
}
|
||||
|
||||
@@ -20,6 +20,7 @@ import android.Manifest;
|
||||
import android.annotation.NonNull;
|
||||
import android.annotation.RequiresPermission;
|
||||
import android.annotation.SystemApi;
|
||||
import android.annotation.TestApi;
|
||||
import android.compat.annotation.ChangeId;
|
||||
import android.compat.annotation.UnsupportedAppUsage;
|
||||
import android.os.Binder;
|
||||
@@ -935,7 +936,6 @@ public class PhoneStateListener {
|
||||
* {@link SubscriptionManager#getDefaultSubscriptionId})
|
||||
* and the value as the list of {@link EmergencyNumber};
|
||||
* null if this information is not available.
|
||||
* @hide
|
||||
*/
|
||||
public void onEmergencyNumberListChanged(
|
||||
@NonNull Map<Integer, List<EmergencyNumber>> emergencyNumberList) {
|
||||
@@ -945,15 +945,48 @@ public class PhoneStateListener {
|
||||
/**
|
||||
* Callback invoked when an outgoing call is placed to an emergency number.
|
||||
*
|
||||
* @param placedEmergencyNumber the emergency number {@link EmergencyNumber} the call is placed
|
||||
* to.
|
||||
* This method will be called when an emergency call is placed on any subscription (including
|
||||
* the no-SIM case), regardless of which subscription this listener was registered on.
|
||||
*
|
||||
* This method is deprecated. Both this method and the new
|
||||
* {@link #onOutgoingEmergencyCall(EmergencyNumber, int)} will be called when an outgoing
|
||||
* emergency call is placed.
|
||||
*
|
||||
* @param placedEmergencyNumber The {@link EmergencyNumber} the emergency call was placed to.
|
||||
*
|
||||
* @deprecated Use {@link #onOutgoingEmergencyCall(EmergencyNumber, int)}.
|
||||
* @hide
|
||||
*/
|
||||
@SystemApi
|
||||
@Deprecated
|
||||
public void onOutgoingEmergencyCall(@NonNull EmergencyNumber placedEmergencyNumber) {
|
||||
// default implementation empty
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback invoked when an outgoing call is placed to an emergency number.
|
||||
*
|
||||
* This method will be called when an emergency call is placed on any subscription (including
|
||||
* the no-SIM case), regardless of which subscription this listener was registered on.
|
||||
*
|
||||
* Both this method and the deprecated {@link #onOutgoingEmergencyCall(EmergencyNumber)} will be
|
||||
* called when an outgoing emergency call is placed. You should only implement one of these
|
||||
* methods.
|
||||
*
|
||||
* @param placedEmergencyNumber The {@link EmergencyNumber} the emergency call was placed to.
|
||||
* @param subscriptionId The subscription ID used to place the emergency call. If the
|
||||
* emergency call was placed without a valid subscription (e.g. when there
|
||||
* are no SIM cards in the device), this will be equal to
|
||||
* {@link SubscriptionManager#INVALID_SUBSCRIPTION_ID}.
|
||||
*
|
||||
* @hide
|
||||
*/
|
||||
@SystemApi
|
||||
@TestApi
|
||||
public void onOutgoingEmergencyCall(@NonNull EmergencyNumber placedEmergencyNumber,
|
||||
int subscriptionId) {
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback invoked when an outgoing SMS is placed to an emergency number.
|
||||
*
|
||||
@@ -1331,13 +1364,19 @@ public class PhoneStateListener {
|
||||
() -> psl.onEmergencyNumberListChanged(emergencyNumberList)));
|
||||
}
|
||||
|
||||
public void onOutgoingEmergencyCall(@NonNull EmergencyNumber placedEmergencyNumber) {
|
||||
public void onOutgoingEmergencyCall(@NonNull EmergencyNumber placedEmergencyNumber,
|
||||
int subscriptionId) {
|
||||
PhoneStateListener psl = mPhoneStateListenerWeakRef.get();
|
||||
if (psl == null) return;
|
||||
|
||||
Binder.withCleanCallingIdentity(
|
||||
() -> mExecutor.execute(
|
||||
() -> psl.onOutgoingEmergencyCall(placedEmergencyNumber)));
|
||||
|
||||
Binder.withCleanCallingIdentity(
|
||||
() -> mExecutor.execute(
|
||||
() -> psl.onOutgoingEmergencyCall(placedEmergencyNumber,
|
||||
subscriptionId)));
|
||||
}
|
||||
|
||||
public void onOutgoingEmergencySms(@NonNull EmergencyNumber sentEmergencyNumber) {
|
||||
|
||||
@@ -61,7 +61,7 @@ oneway interface IPhoneStateListener {
|
||||
void onRadioPowerStateChanged(in int state);
|
||||
void onCallAttributesChanged(in CallAttributes callAttributes);
|
||||
void onEmergencyNumberListChanged(in Map emergencyNumberList);
|
||||
void onOutgoingEmergencyCall(in EmergencyNumber placedEmergencyNumber);
|
||||
void onOutgoingEmergencyCall(in EmergencyNumber placedEmergencyNumber, int subscriptionId);
|
||||
void onOutgoingEmergencySms(in EmergencyNumber sentEmergencyNumber);
|
||||
void onCallDisconnectCauseChanged(in int disconnectCause, in int preciseDisconnectCause);
|
||||
void onImsCallDisconnectCauseChanged(in ImsReasonInfo imsReasonInfo);
|
||||
|
||||
@@ -45969,6 +45969,7 @@ package android.telephony {
|
||||
method public void onDataConnectionStateChanged(int);
|
||||
method public void onDataConnectionStateChanged(int, int);
|
||||
method @RequiresPermission("android.permission.READ_PHONE_STATE") public void onDisplayInfoChanged(@NonNull android.telephony.TelephonyDisplayInfo);
|
||||
method public void onEmergencyNumberListChanged(@NonNull java.util.Map<java.lang.Integer,java.util.List<android.telephony.emergency.EmergencyNumber>>);
|
||||
method @RequiresPermission("android.permission.READ_PRECISE_PHONE_STATE") public void onImsCallDisconnectCauseChanged(@NonNull android.telephony.ims.ImsReasonInfo);
|
||||
method public void onMessageWaitingIndicatorChanged(boolean);
|
||||
method @RequiresPermission("android.permission.MODIFY_PHONE_STATE") public void onPreciseDataConnectionStateChanged(@NonNull android.telephony.PreciseDataConnectionState);
|
||||
|
||||
@@ -9696,7 +9696,8 @@ package android.telephony {
|
||||
|
||||
public class PhoneStateListener {
|
||||
method public void onCallAttributesChanged(@NonNull android.telephony.CallAttributes);
|
||||
method public void onOutgoingEmergencyCall(@NonNull android.telephony.emergency.EmergencyNumber);
|
||||
method @Deprecated public void onOutgoingEmergencyCall(@NonNull android.telephony.emergency.EmergencyNumber);
|
||||
method public void onOutgoingEmergencyCall(@NonNull android.telephony.emergency.EmergencyNumber, int);
|
||||
method public void onOutgoingEmergencySms(@NonNull android.telephony.emergency.EmergencyNumber);
|
||||
method @RequiresPermission("android.permission.READ_PRECISE_PHONE_STATE") public void onPreciseCallStateChanged(@NonNull android.telephony.PreciseCallState);
|
||||
method public void onRadioPowerStateChanged(int);
|
||||
|
||||
@@ -2101,20 +2101,20 @@ public class TelephonyRegistry extends ITelephonyRegistry.Stub {
|
||||
synchronized (mRecords) {
|
||||
if (validatePhoneId(phoneId)) {
|
||||
mOutgoingCallEmergencyNumber[phoneId] = emergencyNumber;
|
||||
for (Record r : mRecords) {
|
||||
if (r.matchPhoneStateListenerEvent(
|
||||
PhoneStateListener.LISTEN_OUTGOING_EMERGENCY_CALL)
|
||||
&& idMatch(r.subId, subId, phoneId)) {
|
||||
try {
|
||||
r.callback.onOutgoingEmergencyCall(emergencyNumber);
|
||||
} catch (RemoteException ex) {
|
||||
mRemoveList.add(r.binder);
|
||||
}
|
||||
}
|
||||
for (Record r : mRecords) {
|
||||
// Send to all listeners regardless of subscription
|
||||
if (r.matchPhoneStateListenerEvent(
|
||||
PhoneStateListener.LISTEN_OUTGOING_EMERGENCY_CALL)) {
|
||||
try {
|
||||
r.callback.onOutgoingEmergencyCall(emergencyNumber, subId);
|
||||
} catch (RemoteException ex) {
|
||||
mRemoveList.add(r.binder);
|
||||
}
|
||||
}
|
||||
}
|
||||
handleRemoveListLocked();
|
||||
}
|
||||
handleRemoveListLocked();
|
||||
}
|
||||
|
||||
@Override
|
||||
|
||||
Reference in New Issue
Block a user